Home | Trees | Indices | Help |
---|
|
object --+ | DescriptorBase --+ | FieldDescriptor
Descriptor for a single field in a .proto file. A FieldDescriptor instance has the following attributes: name: (str) Name of this field, exactly as it appears in .proto. full_name: (str) Name of this field, including containing scope. This is particularly relevant for extensions. camelcase_name: (str) Camelcase name of this field. index: (int) Dense, 0-indexed index giving the order that this field textually appears within its message in the .proto file. number: (int) Tag number declared for this field in the .proto file. type: (One of the TYPE_* constants below) Declared type. cpp_type: (One of the CPPTYPE_* constants below) C++ type used to represent this field. label: (One of the LABEL_* constants below) Tells whether this field is optional, required, or repeated. has_default_value: (bool) True if this field has a default value defined, otherwise false. default_value: (Varies) Default value of this field. Only meaningful for non-repeated scalar fields. Repeated fields should always set this to [], and non-repeated composite fields should always set this to None. containing_type: (Descriptor) Descriptor of the protocol message type that contains this field. Set by the Descriptor constructor if we're passed into one. Somewhat confusingly, for extension fields, this is the descriptor of the EXTENDED message, not the descriptor of the message containing this field. (See is_extension and extension_scope below). message_type: (Descriptor) If a composite field, a descriptor of the message type contained in this field. Otherwise, this is None. enum_type: (EnumDescriptor) If this field contains an enum, a descriptor of that enum. Otherwise, this is None. is_extension: True iff this describes an extension field. extension_scope: (Descriptor) Only meaningful if is_extension is True. Gives the message that immediately contains this extension field. Will be None iff we're a top-level (file-level) extension field. options: (descriptor_pb2.FieldOptions) Protocol message field options or None to use default field options. containing_oneof: (OneofDescriptor) If the field is a member of a oneof union, contains its descriptor. Otherwise, None. file: (FileDescriptor) Reference to file descriptor.
|
|||
a new object with type S, a subtype of T |
|
||
|
|||
Inherited from Inherited from Inherited from |
|
|||
|
|
|||
TYPE_DOUBLE = 1
|
|||
TYPE_FLOAT = 2
|
|||
TYPE_INT64 = 3
|
|||
TYPE_UINT64 = 4
|
|||
TYPE_INT32 = 5
|
|||
TYPE_FIXED64 = 6
|
|||
TYPE_FIXED32 = 7
|
|||
TYPE_BOOL = 8
|
|||
TYPE_STRING = 9
|
|||
TYPE_GROUP = 10
|
|||
TYPE_MESSAGE = 11
|
|||
TYPE_BYTES = 12
|
|||
TYPE_UINT32 = 13
|
|||
TYPE_ENUM = 14
|
|||
TYPE_SFIXED32 = 15
|
|||
TYPE_SFIXED64 = 16
|
|||
TYPE_SINT32 = 17
|
|||
TYPE_SINT64 = 18
|
|||
MAX_TYPE = 18
|
|||
CPPTYPE_INT32 = 1
|
|||
CPPTYPE_INT64 = 2
|
|||
CPPTYPE_UINT32 = 3
|
|||
CPPTYPE_UINT64 = 4
|
|||
CPPTYPE_DOUBLE = 5
|
|||
CPPTYPE_FLOAT = 6
|
|||
CPPTYPE_BOOL = 7
|
|||
CPPTYPE_ENUM = 8
|
|||
CPPTYPE_STRING = 9
|
|||
CPPTYPE_MESSAGE = 10
|
|||
MAX_CPPTYPE = 10
|
|||
_PYTHON_TO_CPP_PROTO_TYPE_MAP =
|
|||
LABEL_OPTIONAL = 1
|
|||
LABEL_REQUIRED = 2
|
|||
LABEL_REPEATED = 3
|
|||
MAX_LABEL = 3
|
|||
MAX_FIELD_NUMBER = 536870911
|
|||
FIRST_RESERVED_FIELD_NUMBER = 19000
|
|||
LAST_RESERVED_FIELD_NUMBER = 19999
|
|||
_C_DESCRIPTOR_CLASS = _message.FieldDescriptor
|
|
|||
camelcase_name | |||
Inherited from |
|
|
The arguments are as described in the description of FieldDescriptor attributes above. Note that containing_type may be None, and may be set later if necessary (to deal with circular references between message types, for example). Likewise for extension_scope.
|
Converts from a Python proto type to a C++ Proto Type. The Python ProtocolBuffer classes specify both the 'Python' datatype and the 'C++' datatype - and they're not the same. This helper method should translate from one to another. Args: proto_type: the Python proto type (descriptor.FieldDescriptor.TYPE_*) Returns: descriptor.FieldDescriptor.CPPTYPE_*, the C++ type. Raises: TypeTransformationError: when the Python proto type isn't known. |
|
_PYTHON_TO_CPP_PROTO_TYPE_MAP
|
|
camelcase_name
|
Home | Trees | Indices | Help |
---|
Generated by Epydoc 3.0.1 on Fri Sep 6 13:21:35 2019 | http://epydoc.sourceforge.net |