mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-11-04 01:12:24 -06:00 
			
		
		
		
	
		
			
	
	
		
			168 lines
		
	
	
	
		
			4.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			168 lines
		
	
	
	
		
			4.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| 
								 | 
							
								// Copyright 2019 The Go Authors. All rights reserved.
							 | 
						||
| 
								 | 
							
								// Use of this source code is governed by a BSD-style
							 | 
						||
| 
								 | 
							
								// license that can be found in the LICENSE file.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// Package protoiface contains types referenced or implemented by messages.
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								// WARNING: This package should only be imported by message implementations.
							 | 
						||
| 
								 | 
							
								// The functionality found in this package should be accessed through
							 | 
						||
| 
								 | 
							
								// higher-level abstractions provided by the proto package.
							 | 
						||
| 
								 | 
							
								package protoiface
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								import (
							 | 
						||
| 
								 | 
							
									"google.golang.org/protobuf/internal/pragma"
							 | 
						||
| 
								 | 
							
									"google.golang.org/protobuf/reflect/protoreflect"
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// Methods is a set of optional fast-path implementations of various operations.
							 | 
						||
| 
								 | 
							
								type Methods = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// Flags indicate support for optional features.
							 | 
						||
| 
								 | 
							
									Flags SupportFlags
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// Size returns the size in bytes of the wire-format encoding of a message.
							 | 
						||
| 
								 | 
							
									// Marshal must be provided if a custom Size is provided.
							 | 
						||
| 
								 | 
							
									Size func(SizeInput) SizeOutput
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// Marshal formats a message in the wire-format encoding to the provided buffer.
							 | 
						||
| 
								 | 
							
									// Size should be provided if a custom Marshal is provided.
							 | 
						||
| 
								 | 
							
									// It must not return an error for a partial message.
							 | 
						||
| 
								 | 
							
									Marshal func(MarshalInput) (MarshalOutput, error)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// Unmarshal parses the wire-format encoding and merges the result into a message.
							 | 
						||
| 
								 | 
							
									// It must not reset the target message or return an error for a partial message.
							 | 
						||
| 
								 | 
							
									Unmarshal func(UnmarshalInput) (UnmarshalOutput, error)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// Merge merges the contents of a source message into a destination message.
							 | 
						||
| 
								 | 
							
									Merge func(MergeInput) MergeOutput
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// CheckInitialized returns an error if any required fields in the message are not set.
							 | 
						||
| 
								 | 
							
									CheckInitialized func(CheckInitializedInput) (CheckInitializedOutput, error)
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// SupportFlags indicate support for optional features.
							 | 
						||
| 
								 | 
							
								type SupportFlags = uint64
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const (
							 | 
						||
| 
								 | 
							
									// SupportMarshalDeterministic reports whether MarshalOptions.Deterministic is supported.
							 | 
						||
| 
								 | 
							
									SupportMarshalDeterministic SupportFlags = 1 << iota
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// SupportUnmarshalDiscardUnknown reports whether UnmarshalOptions.DiscardUnknown is supported.
							 | 
						||
| 
								 | 
							
									SupportUnmarshalDiscardUnknown
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// SizeInput is input to the Size method.
							 | 
						||
| 
								 | 
							
								type SizeInput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Message protoreflect.Message
							 | 
						||
| 
								 | 
							
									Flags   MarshalInputFlags
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// SizeOutput is output from the Size method.
							 | 
						||
| 
								 | 
							
								type SizeOutput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Size int
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// MarshalInput is input to the Marshal method.
							 | 
						||
| 
								 | 
							
								type MarshalInput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Message protoreflect.Message
							 | 
						||
| 
								 | 
							
									Buf     []byte // output is appended to this buffer
							 | 
						||
| 
								 | 
							
									Flags   MarshalInputFlags
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// MarshalOutput is output from the Marshal method.
							 | 
						||
| 
								 | 
							
								type MarshalOutput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Buf []byte // contains marshaled message
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// MarshalInputFlags configure the marshaler.
							 | 
						||
| 
								 | 
							
								// Most flags correspond to fields in proto.MarshalOptions.
							 | 
						||
| 
								 | 
							
								type MarshalInputFlags = uint8
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const (
							 | 
						||
| 
								 | 
							
									MarshalDeterministic MarshalInputFlags = 1 << iota
							 | 
						||
| 
								 | 
							
									MarshalUseCachedSize
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// UnmarshalInput is input to the Unmarshal method.
							 | 
						||
| 
								 | 
							
								type UnmarshalInput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Message  protoreflect.Message
							 | 
						||
| 
								 | 
							
									Buf      []byte // input buffer
							 | 
						||
| 
								 | 
							
									Flags    UnmarshalInputFlags
							 | 
						||
| 
								 | 
							
									Resolver interface {
							 | 
						||
| 
								 | 
							
										FindExtensionByName(field protoreflect.FullName) (protoreflect.ExtensionType, error)
							 | 
						||
| 
								 | 
							
										FindExtensionByNumber(message protoreflect.FullName, field protoreflect.FieldNumber) (protoreflect.ExtensionType, error)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// UnmarshalOutput is output from the Unmarshal method.
							 | 
						||
| 
								 | 
							
								type UnmarshalOutput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Flags UnmarshalOutputFlags
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// UnmarshalInputFlags configure the unmarshaler.
							 | 
						||
| 
								 | 
							
								// Most flags correspond to fields in proto.UnmarshalOptions.
							 | 
						||
| 
								 | 
							
								type UnmarshalInputFlags = uint8
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const (
							 | 
						||
| 
								 | 
							
									UnmarshalDiscardUnknown UnmarshalInputFlags = 1 << iota
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// UnmarshalOutputFlags are output from the Unmarshal method.
							 | 
						||
| 
								 | 
							
								type UnmarshalOutputFlags = uint8
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const (
							 | 
						||
| 
								 | 
							
									// UnmarshalInitialized may be set on return if all required fields are known to be set.
							 | 
						||
| 
								 | 
							
									// If unset, then it does not necessarily indicate that the message is uninitialized,
							 | 
						||
| 
								 | 
							
									// only that its status could not be confirmed.
							 | 
						||
| 
								 | 
							
									UnmarshalInitialized UnmarshalOutputFlags = 1 << iota
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// MergeInput is input to the Merge method.
							 | 
						||
| 
								 | 
							
								type MergeInput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Source      protoreflect.Message
							 | 
						||
| 
								 | 
							
									Destination protoreflect.Message
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// MergeOutput is output from the Merge method.
							 | 
						||
| 
								 | 
							
								type MergeOutput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Flags MergeOutputFlags
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// MergeOutputFlags are output from the Merge method.
							 | 
						||
| 
								 | 
							
								type MergeOutputFlags = uint8
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const (
							 | 
						||
| 
								 | 
							
									// MergeComplete reports whether the merge was performed.
							 | 
						||
| 
								 | 
							
									// If unset, the merger must have made no changes to the destination.
							 | 
						||
| 
								 | 
							
									MergeComplete MergeOutputFlags = 1 << iota
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// CheckInitializedInput is input to the CheckInitialized method.
							 | 
						||
| 
								 | 
							
								type CheckInitializedInput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									Message protoreflect.Message
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// CheckInitializedOutput is output from the CheckInitialized method.
							 | 
						||
| 
								 | 
							
								type CheckInitializedOutput = struct {
							 | 
						||
| 
								 | 
							
									pragma.NoUnkeyedLiterals
							 | 
						||
| 
								 | 
							
								}
							 |