Documentation ¶
Overview ¶
Package messageset encodes and decodes the obsolete MessageSet wire format.
Index ¶
- Constants
- func AppendFieldEnd(b []byte) []byte
- func AppendFieldStart(b []byte, num protowire.Number) []byte
- func AppendUnknown(b, unknown []byte) ([]byte, error)
- func ConsumeFieldValue(b []byte, wantLen bool) (typeid protowire.Number, message []byte, n int, err error)
- func FindMessageSetExtension(r preg.ExtensionTypeResolver, s pref.FullName) (pref.ExtensionType, error)
- func IsMessageSet(md pref.MessageDescriptor) bool
- func IsMessageSetExtension(fd pref.FieldDescriptor) bool
- func SizeField(num protowire.Number) int
- func SizeUnknown(unknown []byte) (size int)
- func Unmarshal(b []byte, wantLen bool, fn func(typeID protowire.Number, value []byte) error) error
Constants ¶
const ( FieldItem = protowire.Number(1) FieldTypeID = protowire.Number(2) FieldMessage = protowire.Number(3) )
The MessageSet wire format is equivalent to a message defiend as follows, where each Item defines an extension field with a field number of 'type_id' and content of 'message'. MessageSet extensions must be non-repeated message fields.
message MessageSet { repeated group Item = 1 { required int32 type_id = 2; required string message = 3; } }
const ExtensionName = "message_set_extension"
ExtensionName is the field name for extensions of MessageSet.
A valid MessageSet extension must be of the form:
message MyMessage { extend proto2.bridge.MessageSet { optional MyMessage message_set_extension = 1234; } ... }
Variables ¶
This section is empty.
Functions ¶
func AppendFieldEnd ¶
AppendFieldEnd appends the trailing end group marker for a MessageSet item field.
func AppendFieldStart ¶
AppendFieldStart appends the start of a MessageSet item field containing an extension with the given number. The caller must add the message subfield (including the tag).
func AppendUnknown ¶
AppendUnknown appends unknown fields to b in MessageSet format.
For historic reasons, unresolved items in a MessageSet are stored in a message's unknown fields section in non-MessageSet format. That is, an unknown item with typeID T and value V appears in the unknown fields as a field with number T and value V.
This function converts the unknown fields back into MessageSet form.
func ConsumeFieldValue ¶
func ConsumeFieldValue(b []byte, wantLen bool) (typeid protowire.Number, message []byte, n int, err error)
ConsumeFieldValue parses b as a MessageSet item field value until and including the trailing end group marker. It assumes the start group tag has already been parsed. It returns the contents of the type_id and message subfields and the total item length.
If wantLen is true, the returned message value includes the length prefix.
func FindMessageSetExtension ¶
func FindMessageSetExtension(r preg.ExtensionTypeResolver, s pref.FullName) (pref.ExtensionType, error)
FindMessageSetExtension locates a MessageSet extension field by name. In text and JSON formats, the extension name used is the message itself. The extension field name is derived by appending ExtensionName.
func IsMessageSet ¶
func IsMessageSet(md pref.MessageDescriptor) bool
IsMessageSet returns whether the message uses the MessageSet wire format.
func IsMessageSetExtension ¶
func IsMessageSetExtension(fd pref.FieldDescriptor) bool
IsMessageSetExtension reports this field extends a MessageSet.
func SizeField ¶
SizeField returns the size of a MessageSet item field containing an extension with the given field number, not counting the contents of the message subfield.
func SizeUnknown ¶
SizeUnknown returns the size of an unknown fields section in MessageSet format.
See AppendUnknown.
Types ¶
This section is empty.