Struct prost_types::MessageOptions [] [src]

pub struct MessageOptions {
    pub message_set_wire_format: Option<bool>,
    pub no_standard_descriptor_accessor: Option<bool>,
    pub deprecated: Option<bool>,
    pub map_entry: Option<bool>,
    pub uninterpreted_option: Vec<UninterpretedOption>,
}

Fields

Set true to use the old proto1 MessageSet wire format for extensions. This is provided for backwards-compatibility with the MessageSet wire format. You should not use this for any other reason: It's less efficient, has fewer features, and is more complicated.

The message must be defined exactly as follows: message Foo { option message_set_wire_format = true; extensions 4 to max; } Note that the message cannot have any defined fields; MessageSets only have extensions.

All extensions of your type must be singular messages; e.g. they cannot be int32s, enums, or repeated messages.

Because this is an option, the above two restrictions are not enforced by the protocol compiler.

Disables the generation of the standard "descriptor()" accessor, which can conflict with a field of the same name. This is meant to make migration from proto1 easier; new code should avoid fields named "descriptor".

Is this message deprecated? Depending on the target platform, this can emit Deprecated annotations for the message, or it will be completely ignored; in the very least, this is a formalization for deprecating messages.

Whether the message is an automatically generated map entry type for the maps field.

For maps fields: map map_field = 1; The parsed descriptor looks like: message MapFieldEntry { option map_entry = true; optional KeyType key = 1; optional ValueType value = 2; } repeated MapFieldEntry map_field = 1;

Implementations may choose not to generate the map_entry=true message, but use a native map in the target language to hold the keys and values. The reflection APIs in such implementions still need to work as if the field is a repeated message field.

NOTE: Do not set the option in .proto files. Always use the maps syntax instead. The option should only be implicitly set by the proto compiler parser.

The parser stores options it doesn't recognize here. See above.

Methods

impl MessageOptions
[src]

Trait Implementations

impl Message for MessageOptions
[src]

[src]

[src]

[src]

Returns the encoded length of the message without a length delimiter.

[src]

Clears the message, resetting all fields to their default.

[src]

Encodes the message to a buffer. Read more

[src]

Encodes the message with a length-delimiter to a buffer. Read more

[src]

Decodes an instance of the message from a buffer. Read more

[src]

Decodes a length-delimited instance of the message from the buffer.

[src]

Decodes an instance of the message from a buffer, and merges it into self. Read more

[src]

Decodes a length-delimited instance of the message from buffer, and merges it into self. Read more

impl Default for MessageOptions
[src]

[src]

Returns the "default value" for a type. Read more

impl Clone for MessageOptions
[src]

[src]

Returns a copy of the value. Read more

1.0.0
[src]

Performs copy-assignment from source. Read more

impl Debug for MessageOptions
[src]

[src]

Formats the value using the given formatter.

impl PartialEq for MessageOptions
[src]

[src]

This method tests for self and other values to be equal, and is used by ==. Read more

[src]

This method tests for !=.