123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 |
- // 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
- }
|