2019-04-01 20:31:55 +00:00
|
|
|
// 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
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/golang/protobuf/v2/internal/pragma"
|
|
|
|
"github.com/golang/protobuf/v2/reflect/protoreflect"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Methoder is an optional interface implemented by generated messages to
|
|
|
|
// provide fast-path implementations of various operations.
|
|
|
|
type Methoder interface {
|
|
|
|
XXX_Methods() *Methods // may return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Methods is a set of optional fast-path implementations of various operations.
|
|
|
|
type Methods struct {
|
|
|
|
// Flags indicate support for optional features.
|
|
|
|
Flags MethodFlag
|
|
|
|
|
|
|
|
// MarshalAppend appends the wire-format encoding of m to b, returning the result.
|
2019-04-05 20:31:40 +00:00
|
|
|
// It does not perform required field checks.
|
2019-04-01 20:31:55 +00:00
|
|
|
MarshalAppend func(b []byte, m protoreflect.ProtoMessage, opts MarshalOptions) ([]byte, error)
|
|
|
|
|
|
|
|
// Size returns the size in bytes of the wire-format encoding of m.
|
|
|
|
Size func(m protoreflect.ProtoMessage) int
|
|
|
|
|
|
|
|
// Unmarshal parses the wire-format message in b and places the result in m.
|
2019-04-05 20:31:40 +00:00
|
|
|
// It does not reset m or perform required field checks.
|
2019-04-01 20:31:55 +00:00
|
|
|
Unmarshal func(b []byte, m protoreflect.ProtoMessage, opts UnmarshalOptions) error
|
|
|
|
|
2019-04-05 20:31:40 +00:00
|
|
|
// IsInitialized returns an error if any required fields in m are not set.
|
|
|
|
IsInitialized func(m protoreflect.ProtoMessage) error
|
|
|
|
|
2019-04-01 20:31:55 +00:00
|
|
|
pragma.NoUnkeyedLiterals
|
|
|
|
}
|
|
|
|
|
|
|
|
// MethodFlag indicates support for optional fast-path features.
|
|
|
|
type MethodFlag int64
|
|
|
|
|
|
|
|
const (
|
|
|
|
// MethodFlagDeterministicMarshal indicates support for deterministic marshaling.
|
|
|
|
MethodFlagDeterministicMarshal MethodFlag = 1 << iota
|
|
|
|
)
|
|
|
|
|
|
|
|
// MarshalOptions configure the marshaler.
|
|
|
|
//
|
|
|
|
// This type is identical to the one in package proto.
|
|
|
|
type MarshalOptions struct {
|
2019-04-03 19:17:24 +00:00
|
|
|
AllowPartial bool
|
2019-04-01 20:31:55 +00:00
|
|
|
Deterministic bool
|
2019-04-08 01:18:31 +00:00
|
|
|
UseCachedSize bool
|
2019-04-01 20:31:55 +00:00
|
|
|
|
|
|
|
pragma.NoUnkeyedLiterals
|
|
|
|
}
|
|
|
|
|
|
|
|
// UnmarshalOptions configures the unmarshaler.
|
|
|
|
//
|
|
|
|
// This type is identical to the one in package proto.
|
|
|
|
type UnmarshalOptions struct {
|
2019-04-03 19:17:24 +00:00
|
|
|
AllowPartial bool
|
2019-04-01 20:31:55 +00:00
|
|
|
DiscardUnknown bool
|
|
|
|
|
|
|
|
pragma.NoUnkeyedLiterals
|
|
|
|
}
|