/// InterfaceDescriptor describes an interface type to be used with /// accepts_interface and implements_interface and declared by declare_interface. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] pub struct InterfaceDescriptor { /// name is the name of the interface. It should be a short-name (without /// a period) such that the fully qualified name of the interface will be /// package.name, ex. for the package a.b and interface named C, the /// fully-qualified name will be a.b.C. #[prost(string, tag = "1")] pub name: ::prost::alloc::string::String, /// description is a human-readable description of the interface and its /// purpose. #[prost(string, tag = "2")] pub description: ::prost::alloc::string::String, } /// ScalarDescriptor describes an scalar type to be used with /// the scalar field option and declared by declare_scalar. /// Scalars extend simple protobuf built-in types with additional /// syntax and semantics, for instance to represent big integers. /// Scalars should ideally define an encoding such that there is only one /// valid syntactical representation for a given semantic meaning, /// i.e. the encoding should be deterministic. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] pub struct ScalarDescriptor { /// name is the name of the scalar. It should be a short-name (without /// a period) such that the fully qualified name of the scalar will be /// package.name, ex. for the package a.b and scalar named C, the /// fully-qualified name will be a.b.C. #[prost(string, tag = "1")] pub name: ::prost::alloc::string::String, /// description is a human-readable description of the scalar and its /// encoding format. For instance a big integer or decimal scalar should /// specify precisely the expected encoding format. #[prost(string, tag = "2")] pub description: ::prost::alloc::string::String, /// field_type is the type of field with which this scalar can be used. /// Scalars can be used with one and only one type of field so that /// encoding standards and simple and clear. Currently only string and /// bytes fields are supported for scalars. #[prost(enumeration = "ScalarType", repeated, tag = "3")] pub field_type: ::prost::alloc::vec::Vec, } #[derive(Clone, Copy, Debug, PartialEq, Eq, Hash, PartialOrd, Ord, ::prost::Enumeration)] #[repr(i32)] pub enum ScalarType { Unspecified = 0, String = 1, Bytes = 2, } impl ScalarType { /// String value of the enum field names used in the ProtoBuf definition. /// /// The values are not transformed in any way and thus are considered stable /// (if the ProtoBuf definition does not change) and safe for programmatic use. pub fn as_str_name(&self) -> &'static str { match self { ScalarType::Unspecified => "SCALAR_TYPE_UNSPECIFIED", ScalarType::String => "SCALAR_TYPE_STRING", ScalarType::Bytes => "SCALAR_TYPE_BYTES", } } /// Creates an enum from field names used in the ProtoBuf definition. pub fn from_str_name(value: &str) -> ::core::option::Option { match value { "SCALAR_TYPE_UNSPECIFIED" => Some(Self::Unspecified), "SCALAR_TYPE_STRING" => Some(Self::String), "SCALAR_TYPE_BYTES" => Some(Self::Bytes), _ => None, } } }