Upgrade rust/crates/protobuf to 2.22.0

Test: make
Change-Id: I0967df149e3d7ca88f0abe6281adf2425adc6f1e
diff --git a/src/plugin.rs b/src/plugin.rs
index 904b0f1..007378f 100644
--- a/src/plugin.rs
+++ b/src/plugin.rs
@@ -1,4 +1,4 @@
-// This file is generated by rust-protobuf 2.19.0-pre. Do not edit
+// This file is generated by rust-protobuf 2.22.0-pre. Do not edit
 // @generated
 
 // https://github.com/rust-lang/rust-clippy/issues/702
@@ -20,12 +20,302 @@
 //! Generated file from `google/protobuf/compiler/plugin.proto`
 
 #[derive(PartialEq,Clone,Default)]
-#[cfg_attr(feature = "with-serde", derive(Serialize, Deserialize))]
+#[cfg_attr(feature = "with-serde", derive(::serde::Serialize, ::serde::Deserialize))]
+pub struct Version {
+    // message fields
+    major: ::std::option::Option<i32>,
+    minor: ::std::option::Option<i32>,
+    patch: ::std::option::Option<i32>,
+    suffix: crate::SingularField<::std::string::String>,
+    // special fields
+    #[cfg_attr(feature = "with-serde", serde(skip))]
+    pub unknown_fields: crate::UnknownFields,
+    #[cfg_attr(feature = "with-serde", serde(skip))]
+    pub cached_size: crate::CachedSize,
+}
+
+impl<'a> ::std::default::Default for &'a Version {
+    fn default() -> &'a Version {
+        <Version as crate::Message>::default_instance()
+    }
+}
+
+impl Version {
+    pub fn new() -> Version {
+        ::std::default::Default::default()
+    }
+
+    // optional int32 major = 1;
+
+
+    pub fn get_major(&self) -> i32 {
+        self.major.unwrap_or(0)
+    }
+    pub fn clear_major(&mut self) {
+        self.major = ::std::option::Option::None;
+    }
+
+    pub fn has_major(&self) -> bool {
+        self.major.is_some()
+    }
+
+    // Param is passed by value, moved
+    pub fn set_major(&mut self, v: i32) {
+        self.major = ::std::option::Option::Some(v);
+    }
+
+    // optional int32 minor = 2;
+
+
+    pub fn get_minor(&self) -> i32 {
+        self.minor.unwrap_or(0)
+    }
+    pub fn clear_minor(&mut self) {
+        self.minor = ::std::option::Option::None;
+    }
+
+    pub fn has_minor(&self) -> bool {
+        self.minor.is_some()
+    }
+
+    // Param is passed by value, moved
+    pub fn set_minor(&mut self, v: i32) {
+        self.minor = ::std::option::Option::Some(v);
+    }
+
+    // optional int32 patch = 3;
+
+
+    pub fn get_patch(&self) -> i32 {
+        self.patch.unwrap_or(0)
+    }
+    pub fn clear_patch(&mut self) {
+        self.patch = ::std::option::Option::None;
+    }
+
+    pub fn has_patch(&self) -> bool {
+        self.patch.is_some()
+    }
+
+    // Param is passed by value, moved
+    pub fn set_patch(&mut self, v: i32) {
+        self.patch = ::std::option::Option::Some(v);
+    }
+
+    // optional string suffix = 4;
+
+
+    pub fn get_suffix(&self) -> &str {
+        match self.suffix.as_ref() {
+            Some(v) => &v,
+            None => "",
+        }
+    }
+    pub fn clear_suffix(&mut self) {
+        self.suffix.clear();
+    }
+
+    pub fn has_suffix(&self) -> bool {
+        self.suffix.is_some()
+    }
+
+    // Param is passed by value, moved
+    pub fn set_suffix(&mut self, v: ::std::string::String) {
+        self.suffix = crate::SingularField::some(v);
+    }
+
+    // Mutable pointer to the field.
+    // If field is not initialized, it is initialized with default value first.
+    pub fn mut_suffix(&mut self) -> &mut ::std::string::String {
+        if self.suffix.is_none() {
+            self.suffix.set_default();
+        }
+        self.suffix.as_mut().unwrap()
+    }
+
+    // Take field
+    pub fn take_suffix(&mut self) -> ::std::string::String {
+        self.suffix.take().unwrap_or_else(|| ::std::string::String::new())
+    }
+}
+
+impl crate::Message for Version {
+    fn is_initialized(&self) -> bool {
+        true
+    }
+
+    fn merge_from(&mut self, is: &mut crate::CodedInputStream<'_>) -> crate::ProtobufResult<()> {
+        while !is.eof()? {
+            let (field_number, wire_type) = is.read_tag_unpack()?;
+            match field_number {
+                1 => {
+                    if wire_type != crate::wire_format::WireTypeVarint {
+                        return ::std::result::Result::Err(crate::rt::unexpected_wire_type(wire_type));
+                    }
+                    let tmp = is.read_int32()?;
+                    self.major = ::std::option::Option::Some(tmp);
+                },
+                2 => {
+                    if wire_type != crate::wire_format::WireTypeVarint {
+                        return ::std::result::Result::Err(crate::rt::unexpected_wire_type(wire_type));
+                    }
+                    let tmp = is.read_int32()?;
+                    self.minor = ::std::option::Option::Some(tmp);
+                },
+                3 => {
+                    if wire_type != crate::wire_format::WireTypeVarint {
+                        return ::std::result::Result::Err(crate::rt::unexpected_wire_type(wire_type));
+                    }
+                    let tmp = is.read_int32()?;
+                    self.patch = ::std::option::Option::Some(tmp);
+                },
+                4 => {
+                    crate::rt::read_singular_string_into(wire_type, is, &mut self.suffix)?;
+                },
+                _ => {
+                    crate::rt::read_unknown_or_skip_group(field_number, wire_type, is, self.mut_unknown_fields())?;
+                },
+            };
+        }
+        ::std::result::Result::Ok(())
+    }
+
+    // Compute sizes of nested messages
+    #[allow(unused_variables)]
+    fn compute_size(&self) -> u32 {
+        let mut my_size = 0;
+        if let Some(v) = self.major {
+            my_size += crate::rt::value_size(1, v, crate::wire_format::WireTypeVarint);
+        }
+        if let Some(v) = self.minor {
+            my_size += crate::rt::value_size(2, v, crate::wire_format::WireTypeVarint);
+        }
+        if let Some(v) = self.patch {
+            my_size += crate::rt::value_size(3, v, crate::wire_format::WireTypeVarint);
+        }
+        if let Some(ref v) = self.suffix.as_ref() {
+            my_size += crate::rt::string_size(4, &v);
+        }
+        my_size += crate::rt::unknown_fields_size(self.get_unknown_fields());
+        self.cached_size.set(my_size);
+        my_size
+    }
+
+    fn write_to_with_cached_sizes(&self, os: &mut crate::CodedOutputStream<'_>) -> crate::ProtobufResult<()> {
+        if let Some(v) = self.major {
+            os.write_int32(1, v)?;
+        }
+        if let Some(v) = self.minor {
+            os.write_int32(2, v)?;
+        }
+        if let Some(v) = self.patch {
+            os.write_int32(3, v)?;
+        }
+        if let Some(ref v) = self.suffix.as_ref() {
+            os.write_string(4, &v)?;
+        }
+        os.write_unknown_fields(self.get_unknown_fields())?;
+        ::std::result::Result::Ok(())
+    }
+
+    fn get_cached_size(&self) -> u32 {
+        self.cached_size.get()
+    }
+
+    fn get_unknown_fields(&self) -> &crate::UnknownFields {
+        &self.unknown_fields
+    }
+
+    fn mut_unknown_fields(&mut self) -> &mut crate::UnknownFields {
+        &mut self.unknown_fields
+    }
+
+    fn as_any(&self) -> &dyn (::std::any::Any) {
+        self as &dyn (::std::any::Any)
+    }
+    fn as_any_mut(&mut self) -> &mut dyn (::std::any::Any) {
+        self as &mut dyn (::std::any::Any)
+    }
+    fn into_any(self: ::std::boxed::Box<Self>) -> ::std::boxed::Box<dyn (::std::any::Any)> {
+        self
+    }
+
+    fn descriptor(&self) -> &'static crate::reflect::MessageDescriptor {
+        Self::descriptor_static()
+    }
+
+    fn new() -> Version {
+        Version::new()
+    }
+
+    fn descriptor_static() -> &'static crate::reflect::MessageDescriptor {
+        static descriptor: crate::rt::LazyV2<crate::reflect::MessageDescriptor> = crate::rt::LazyV2::INIT;
+        descriptor.get(|| {
+            let mut fields = ::std::vec::Vec::new();
+            fields.push(crate::reflect::accessor::make_option_accessor::<_, crate::types::ProtobufTypeInt32>(
+                "major",
+                |m: &Version| { &m.major },
+                |m: &mut Version| { &mut m.major },
+            ));
+            fields.push(crate::reflect::accessor::make_option_accessor::<_, crate::types::ProtobufTypeInt32>(
+                "minor",
+                |m: &Version| { &m.minor },
+                |m: &mut Version| { &mut m.minor },
+            ));
+            fields.push(crate::reflect::accessor::make_option_accessor::<_, crate::types::ProtobufTypeInt32>(
+                "patch",
+                |m: &Version| { &m.patch },
+                |m: &mut Version| { &mut m.patch },
+            ));
+            fields.push(crate::reflect::accessor::make_singular_field_accessor::<_, crate::types::ProtobufTypeString>(
+                "suffix",
+                |m: &Version| { &m.suffix },
+                |m: &mut Version| { &mut m.suffix },
+            ));
+            crate::reflect::MessageDescriptor::new_pb_name::<Version>(
+                "Version",
+                fields,
+                file_descriptor_proto()
+            )
+        })
+    }
+
+    fn default_instance() -> &'static Version {
+        static instance: crate::rt::LazyV2<Version> = crate::rt::LazyV2::INIT;
+        instance.get(Version::new)
+    }
+}
+
+impl crate::Clear for Version {
+    fn clear(&mut self) {
+        self.major = ::std::option::Option::None;
+        self.minor = ::std::option::Option::None;
+        self.patch = ::std::option::Option::None;
+        self.suffix.clear();
+        self.unknown_fields.clear();
+    }
+}
+
+impl ::std::fmt::Debug for Version {
+    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
+        crate::text_format::fmt(self, f)
+    }
+}
+
+impl crate::reflect::ProtobufValue for Version {
+    fn as_ref(&self) -> crate::reflect::ReflectValueRef {
+        crate::reflect::ReflectValueRef::Message(self)
+    }
+}
+
+#[derive(PartialEq,Clone,Default)]
+#[cfg_attr(feature = "with-serde", derive(::serde::Serialize, ::serde::Deserialize))]
 pub struct CodeGeneratorRequest {
     // message fields
     pub file_to_generate: crate::RepeatedField<::std::string::String>,
     parameter: crate::SingularField<::std::string::String>,
     pub proto_file: crate::RepeatedField<crate::descriptor::FileDescriptorProto>,
+    pub compiler_version: crate::SingularPtrField<Version>,
     // special fields
     #[cfg_attr(feature = "with-serde", serde(skip))]
     pub unknown_fields: crate::UnknownFields,
@@ -129,6 +419,39 @@
     pub fn take_proto_file(&mut self) -> crate::RepeatedField<crate::descriptor::FileDescriptorProto> {
         ::std::mem::replace(&mut self.proto_file, crate::RepeatedField::new())
     }
+
+    // optional .google.protobuf.compiler.Version compiler_version = 3;
+
+
+    pub fn get_compiler_version(&self) -> &Version {
+        self.compiler_version.as_ref().unwrap_or_else(|| <Version as crate::Message>::default_instance())
+    }
+    pub fn clear_compiler_version(&mut self) {
+        self.compiler_version.clear();
+    }
+
+    pub fn has_compiler_version(&self) -> bool {
+        self.compiler_version.is_some()
+    }
+
+    // Param is passed by value, moved
+    pub fn set_compiler_version(&mut self, v: Version) {
+        self.compiler_version = crate::SingularPtrField::some(v);
+    }
+
+    // Mutable pointer to the field.
+    // If field is not initialized, it is initialized with default value first.
+    pub fn mut_compiler_version(&mut self) -> &mut Version {
+        if self.compiler_version.is_none() {
+            self.compiler_version.set_default();
+        }
+        self.compiler_version.as_mut().unwrap()
+    }
+
+    // Take field
+    pub fn take_compiler_version(&mut self) -> Version {
+        self.compiler_version.take().unwrap_or_else(|| Version::new())
+    }
 }
 
 impl crate::Message for CodeGeneratorRequest {
@@ -138,6 +461,11 @@
                 return false;
             }
         };
+        for v in &self.compiler_version {
+            if !v.is_initialized() {
+                return false;
+            }
+        };
         true
     }
 
@@ -154,6 +482,9 @@
                 15 => {
                     crate::rt::read_repeated_message_into(wire_type, is, &mut self.proto_file)?;
                 },
+                3 => {
+                    crate::rt::read_singular_message_into(wire_type, is, &mut self.compiler_version)?;
+                },
                 _ => {
                     crate::rt::read_unknown_or_skip_group(field_number, wire_type, is, self.mut_unknown_fields())?;
                 },
@@ -176,6 +507,10 @@
             let len = value.compute_size();
             my_size += 1 + crate::rt::compute_raw_varint32_size(len) + len;
         };
+        if let Some(ref v) = self.compiler_version.as_ref() {
+            let len = v.compute_size();
+            my_size += 1 + crate::rt::compute_raw_varint32_size(len) + len;
+        }
         my_size += crate::rt::unknown_fields_size(self.get_unknown_fields());
         self.cached_size.set(my_size);
         my_size
@@ -193,6 +528,11 @@
             os.write_raw_varint32(v.get_cached_size())?;
             v.write_to_with_cached_sizes(os)?;
         };
+        if let Some(ref v) = self.compiler_version.as_ref() {
+            os.write_tag(3, crate::wire_format::WireTypeLengthDelimited)?;
+            os.write_raw_varint32(v.get_cached_size())?;
+            v.write_to_with_cached_sizes(os)?;
+        }
         os.write_unknown_fields(self.get_unknown_fields())?;
         ::std::result::Result::Ok(())
     }
@@ -246,6 +586,11 @@
                 |m: &CodeGeneratorRequest| { &m.proto_file },
                 |m: &mut CodeGeneratorRequest| { &mut m.proto_file },
             ));
+            fields.push(crate::reflect::accessor::make_singular_ptr_field_accessor::<_, crate::types::ProtobufTypeMessage<Version>>(
+                "compiler_version",
+                |m: &CodeGeneratorRequest| { &m.compiler_version },
+                |m: &mut CodeGeneratorRequest| { &mut m.compiler_version },
+            ));
             crate::reflect::MessageDescriptor::new_pb_name::<CodeGeneratorRequest>(
                 "CodeGeneratorRequest",
                 fields,
@@ -265,6 +610,7 @@
         self.file_to_generate.clear();
         self.parameter.clear();
         self.proto_file.clear();
+        self.compiler_version.clear();
         self.unknown_fields.clear();
     }
 }
@@ -282,10 +628,11 @@
 }
 
 #[derive(PartialEq,Clone,Default)]
-#[cfg_attr(feature = "with-serde", derive(Serialize, Deserialize))]
+#[cfg_attr(feature = "with-serde", derive(::serde::Serialize, ::serde::Deserialize))]
 pub struct CodeGeneratorResponse {
     // message fields
     error: crate::SingularField<::std::string::String>,
+    supported_features: ::std::option::Option<u64>,
     pub file: crate::RepeatedField<CodeGeneratorResponse_File>,
     // special fields
     #[cfg_attr(feature = "with-serde", serde(skip))]
@@ -341,6 +688,25 @@
         self.error.take().unwrap_or_else(|| ::std::string::String::new())
     }
 
+    // optional uint64 supported_features = 2;
+
+
+    pub fn get_supported_features(&self) -> u64 {
+        self.supported_features.unwrap_or(0)
+    }
+    pub fn clear_supported_features(&mut self) {
+        self.supported_features = ::std::option::Option::None;
+    }
+
+    pub fn has_supported_features(&self) -> bool {
+        self.supported_features.is_some()
+    }
+
+    // Param is passed by value, moved
+    pub fn set_supported_features(&mut self, v: u64) {
+        self.supported_features = ::std::option::Option::Some(v);
+    }
+
     // repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15;
 
 
@@ -384,6 +750,13 @@
                 1 => {
                     crate::rt::read_singular_string_into(wire_type, is, &mut self.error)?;
                 },
+                2 => {
+                    if wire_type != crate::wire_format::WireTypeVarint {
+                        return ::std::result::Result::Err(crate::rt::unexpected_wire_type(wire_type));
+                    }
+                    let tmp = is.read_uint64()?;
+                    self.supported_features = ::std::option::Option::Some(tmp);
+                },
                 15 => {
                     crate::rt::read_repeated_message_into(wire_type, is, &mut self.file)?;
                 },
@@ -402,6 +775,9 @@
         if let Some(ref v) = self.error.as_ref() {
             my_size += crate::rt::string_size(1, &v);
         }
+        if let Some(v) = self.supported_features {
+            my_size += crate::rt::value_size(2, v, crate::wire_format::WireTypeVarint);
+        }
         for value in &self.file {
             let len = value.compute_size();
             my_size += 1 + crate::rt::compute_raw_varint32_size(len) + len;
@@ -415,6 +791,9 @@
         if let Some(ref v) = self.error.as_ref() {
             os.write_string(1, &v)?;
         }
+        if let Some(v) = self.supported_features {
+            os.write_uint64(2, v)?;
+        }
         for v in &self.file {
             os.write_tag(15, crate::wire_format::WireTypeLengthDelimited)?;
             os.write_raw_varint32(v.get_cached_size())?;
@@ -463,6 +842,11 @@
                 |m: &CodeGeneratorResponse| { &m.error },
                 |m: &mut CodeGeneratorResponse| { &mut m.error },
             ));
+            fields.push(crate::reflect::accessor::make_option_accessor::<_, crate::types::ProtobufTypeUint64>(
+                "supported_features",
+                |m: &CodeGeneratorResponse| { &m.supported_features },
+                |m: &mut CodeGeneratorResponse| { &mut m.supported_features },
+            ));
             fields.push(crate::reflect::accessor::make_repeated_field_accessor::<_, crate::types::ProtobufTypeMessage<CodeGeneratorResponse_File>>(
                 "file",
                 |m: &CodeGeneratorResponse| { &m.file },
@@ -485,6 +869,7 @@
 impl crate::Clear for CodeGeneratorResponse {
     fn clear(&mut self) {
         self.error.clear();
+        self.supported_features = ::std::option::Option::None;
         self.file.clear();
         self.unknown_fields.clear();
     }
@@ -503,12 +888,13 @@
 }
 
 #[derive(PartialEq,Clone,Default)]
-#[cfg_attr(feature = "with-serde", derive(Serialize, Deserialize))]
+#[cfg_attr(feature = "with-serde", derive(::serde::Serialize, ::serde::Deserialize))]
 pub struct CodeGeneratorResponse_File {
     // message fields
     name: crate::SingularField<::std::string::String>,
     insertion_point: crate::SingularField<::std::string::String>,
     content: crate::SingularField<::std::string::String>,
+    pub generated_code_info: crate::SingularPtrField<crate::descriptor::GeneratedCodeInfo>,
     // special fields
     #[cfg_attr(feature = "with-serde", serde(skip))]
     pub unknown_fields: crate::UnknownFields,
@@ -634,10 +1020,48 @@
     pub fn take_content(&mut self) -> ::std::string::String {
         self.content.take().unwrap_or_else(|| ::std::string::String::new())
     }
+
+    // optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16;
+
+
+    pub fn get_generated_code_info(&self) -> &crate::descriptor::GeneratedCodeInfo {
+        self.generated_code_info.as_ref().unwrap_or_else(|| <crate::descriptor::GeneratedCodeInfo as crate::Message>::default_instance())
+    }
+    pub fn clear_generated_code_info(&mut self) {
+        self.generated_code_info.clear();
+    }
+
+    pub fn has_generated_code_info(&self) -> bool {
+        self.generated_code_info.is_some()
+    }
+
+    // Param is passed by value, moved
+    pub fn set_generated_code_info(&mut self, v: crate::descriptor::GeneratedCodeInfo) {
+        self.generated_code_info = crate::SingularPtrField::some(v);
+    }
+
+    // Mutable pointer to the field.
+    // If field is not initialized, it is initialized with default value first.
+    pub fn mut_generated_code_info(&mut self) -> &mut crate::descriptor::GeneratedCodeInfo {
+        if self.generated_code_info.is_none() {
+            self.generated_code_info.set_default();
+        }
+        self.generated_code_info.as_mut().unwrap()
+    }
+
+    // Take field
+    pub fn take_generated_code_info(&mut self) -> crate::descriptor::GeneratedCodeInfo {
+        self.generated_code_info.take().unwrap_or_else(|| crate::descriptor::GeneratedCodeInfo::new())
+    }
 }
 
 impl crate::Message for CodeGeneratorResponse_File {
     fn is_initialized(&self) -> bool {
+        for v in &self.generated_code_info {
+            if !v.is_initialized() {
+                return false;
+            }
+        };
         true
     }
 
@@ -654,6 +1078,9 @@
                 15 => {
                     crate::rt::read_singular_string_into(wire_type, is, &mut self.content)?;
                 },
+                16 => {
+                    crate::rt::read_singular_message_into(wire_type, is, &mut self.generated_code_info)?;
+                },
                 _ => {
                     crate::rt::read_unknown_or_skip_group(field_number, wire_type, is, self.mut_unknown_fields())?;
                 },
@@ -675,6 +1102,10 @@
         if let Some(ref v) = self.content.as_ref() {
             my_size += crate::rt::string_size(15, &v);
         }
+        if let Some(ref v) = self.generated_code_info.as_ref() {
+            let len = v.compute_size();
+            my_size += 2 + crate::rt::compute_raw_varint32_size(len) + len;
+        }
         my_size += crate::rt::unknown_fields_size(self.get_unknown_fields());
         self.cached_size.set(my_size);
         my_size
@@ -690,6 +1121,11 @@
         if let Some(ref v) = self.content.as_ref() {
             os.write_string(15, &v)?;
         }
+        if let Some(ref v) = self.generated_code_info.as_ref() {
+            os.write_tag(16, crate::wire_format::WireTypeLengthDelimited)?;
+            os.write_raw_varint32(v.get_cached_size())?;
+            v.write_to_with_cached_sizes(os)?;
+        }
         os.write_unknown_fields(self.get_unknown_fields())?;
         ::std::result::Result::Ok(())
     }
@@ -743,6 +1179,11 @@
                 |m: &CodeGeneratorResponse_File| { &m.content },
                 |m: &mut CodeGeneratorResponse_File| { &mut m.content },
             ));
+            fields.push(crate::reflect::accessor::make_singular_ptr_field_accessor::<_, crate::types::ProtobufTypeMessage<crate::descriptor::GeneratedCodeInfo>>(
+                "generated_code_info",
+                |m: &CodeGeneratorResponse_File| { &m.generated_code_info },
+                |m: &mut CodeGeneratorResponse_File| { &mut m.generated_code_info },
+            ));
             crate::reflect::MessageDescriptor::new_pb_name::<CodeGeneratorResponse_File>(
                 "CodeGeneratorResponse.File",
                 fields,
@@ -762,6 +1203,7 @@
         self.name.clear();
         self.insertion_point.clear();
         self.content.clear();
+        self.generated_code_info.clear();
         self.unknown_fields.clear();
     }
 }
@@ -778,194 +1220,299 @@
     }
 }
 
+#[derive(Clone,PartialEq,Eq,Debug,Hash)]
+#[cfg_attr(feature = "with-serde", derive(::serde::Serialize, ::serde::Deserialize))]
+pub enum CodeGeneratorResponse_Feature {
+    FEATURE_NONE = 0,
+    FEATURE_PROTO3_OPTIONAL = 1,
+}
+
+impl crate::ProtobufEnum for CodeGeneratorResponse_Feature {
+    fn value(&self) -> i32 {
+        *self as i32
+    }
+
+    fn from_i32(value: i32) -> ::std::option::Option<CodeGeneratorResponse_Feature> {
+        match value {
+            0 => ::std::option::Option::Some(CodeGeneratorResponse_Feature::FEATURE_NONE),
+            1 => ::std::option::Option::Some(CodeGeneratorResponse_Feature::FEATURE_PROTO3_OPTIONAL),
+            _ => ::std::option::Option::None
+        }
+    }
+
+    fn values() -> &'static [Self] {
+        static values: &'static [CodeGeneratorResponse_Feature] = &[
+            CodeGeneratorResponse_Feature::FEATURE_NONE,
+            CodeGeneratorResponse_Feature::FEATURE_PROTO3_OPTIONAL,
+        ];
+        values
+    }
+
+    fn enum_descriptor_static() -> &'static crate::reflect::EnumDescriptor {
+        static descriptor: crate::rt::LazyV2<crate::reflect::EnumDescriptor> = crate::rt::LazyV2::INIT;
+        descriptor.get(|| {
+            crate::reflect::EnumDescriptor::new_pb_name::<CodeGeneratorResponse_Feature>("CodeGeneratorResponse.Feature", file_descriptor_proto())
+        })
+    }
+}
+
+impl ::std::marker::Copy for CodeGeneratorResponse_Feature {
+}
+
+impl ::std::default::Default for CodeGeneratorResponse_Feature {
+    fn default() -> Self {
+        CodeGeneratorResponse_Feature::FEATURE_NONE
+    }
+}
+
+impl crate::reflect::ProtobufValue for CodeGeneratorResponse_Feature {
+    fn as_ref(&self) -> crate::reflect::ReflectValueRef {
+        crate::reflect::ReflectValueRef::Enum(crate::ProtobufEnum::descriptor(self))
+    }
+}
+
 static file_descriptor_proto_data: &'static [u8] = b"\
     \n%google/protobuf/compiler/plugin.proto\x12\x18google.protobuf.compiler\
-    \x1a\x20google/protobuf/descriptor.proto\"\xa3\x01\n\x14CodeGeneratorReq\
-    uest\x12(\n\x10file_to_generate\x18\x01\x20\x03(\tR\x0efileToGenerate\
+    \x1a\x20google/protobuf/descriptor.proto\"c\n\x07Version\x12\x14\n\x05ma\
+    jor\x18\x01\x20\x01(\x05R\x05major\x12\x14\n\x05minor\x18\x02\x20\x01(\
+    \x05R\x05minor\x12\x14\n\x05patch\x18\x03\x20\x01(\x05R\x05patch\x12\x16\
+    \n\x06suffix\x18\x04\x20\x01(\tR\x06suffix\"\xf1\x01\n\x14CodeGeneratorR\
+    equest\x12(\n\x10file_to_generate\x18\x01\x20\x03(\tR\x0efileToGenerate\
     \x12\x1c\n\tparameter\x18\x02\x20\x01(\tR\tparameter\x12C\n\nproto_file\
     \x18\x0f\x20\x03(\x0b2$.google.protobuf.FileDescriptorProtoR\tprotoFile\
-    \"\xd6\x01\n\x15CodeGeneratorResponse\x12\x14\n\x05error\x18\x01\x20\x01\
-    (\tR\x05error\x12H\n\x04file\x18\x0f\x20\x03(\x0b24.google.protobuf.comp\
-    iler.CodeGeneratorResponse.FileR\x04file\x1a]\n\x04File\x12\x12\n\x04nam\
-    e\x18\x01\x20\x01(\tR\x04name\x12'\n\x0finsertion_point\x18\x02\x20\x01(\
-    \tR\x0einsertionPoint\x12\x18\n\x07content\x18\x0f\x20\x01(\tR\x07conten\
-    tB7\n\x1ccom.google.protobuf.compilerB\x0cPluginProtosZ\tplugin_goJ\xd29\
-    \n\x07\x12\x05.\0\x95\x01\x01\n\xca\x11\n\x01\x0c\x12\x03.\0\x122\xc1\
-    \x0c\x20Protocol\x20Buffers\x20-\x20Google's\x20data\x20interchange\x20f\
-    ormat\n\x20Copyright\x202008\x20Google\x20Inc.\x20\x20All\x20rights\x20r\
-    eserved.\n\x20https://developers.google.com/protocol-buffers/\n\n\x20Red\
-    istribution\x20and\x20use\x20in\x20source\x20and\x20binary\x20forms,\x20\
-    with\x20or\x20without\n\x20modification,\x20are\x20permitted\x20provided\
-    \x20that\x20the\x20following\x20conditions\x20are\n\x20met:\n\n\x20\x20\
-    \x20\x20\x20*\x20Redistributions\x20of\x20source\x20code\x20must\x20reta\
-    in\x20the\x20above\x20copyright\n\x20notice,\x20this\x20list\x20of\x20co\
-    nditions\x20and\x20the\x20following\x20disclaimer.\n\x20\x20\x20\x20\x20\
-    *\x20Redistributions\x20in\x20binary\x20form\x20must\x20reproduce\x20the\
-    \x20above\n\x20copyright\x20notice,\x20this\x20list\x20of\x20conditions\
-    \x20and\x20the\x20following\x20disclaimer\n\x20in\x20the\x20documentatio\
-    n\x20and/or\x20other\x20materials\x20provided\x20with\x20the\n\x20distri\
-    bution.\n\x20\x20\x20\x20\x20*\x20Neither\x20the\x20name\x20of\x20Google\
-    \x20Inc.\x20nor\x20the\x20names\x20of\x20its\n\x20contributors\x20may\
-    \x20be\x20used\x20to\x20endorse\x20or\x20promote\x20products\x20derived\
-    \x20from\n\x20this\x20software\x20without\x20specific\x20prior\x20writte\
-    n\x20permission.\n\n\x20THIS\x20SOFTWARE\x20IS\x20PROVIDED\x20BY\x20THE\
-    \x20COPYRIGHT\x20HOLDERS\x20AND\x20CONTRIBUTORS\n\x20\"AS\x20IS\"\x20AND\
-    \x20ANY\x20EXPRESS\x20OR\x20IMPLIED\x20WARRANTIES,\x20INCLUDING,\x20BUT\
-    \x20NOT\n\x20LIMITED\x20TO,\x20THE\x20IMPLIED\x20WARRANTIES\x20OF\x20MER\
-    CHANTABILITY\x20AND\x20FITNESS\x20FOR\n\x20A\x20PARTICULAR\x20PURPOSE\
-    \x20ARE\x20DISCLAIMED.\x20IN\x20NO\x20EVENT\x20SHALL\x20THE\x20COPYRIGHT\
-    \n\x20OWNER\x20OR\x20CONTRIBUTORS\x20BE\x20LIABLE\x20FOR\x20ANY\x20DIREC\
-    T,\x20INDIRECT,\x20INCIDENTAL,\n\x20SPECIAL,\x20EXEMPLARY,\x20OR\x20CONS\
-    EQUENTIAL\x20DAMAGES\x20(INCLUDING,\x20BUT\x20NOT\n\x20LIMITED\x20TO,\
-    \x20PROCUREMENT\x20OF\x20SUBSTITUTE\x20GOODS\x20OR\x20SERVICES;\x20LOSS\
-    \x20OF\x20USE,\n\x20DATA,\x20OR\x20PROFITS;\x20OR\x20BUSINESS\x20INTERRU\
-    PTION)\x20HOWEVER\x20CAUSED\x20AND\x20ON\x20ANY\n\x20THEORY\x20OF\x20LIA\
-    BILITY,\x20WHETHER\x20IN\x20CONTRACT,\x20STRICT\x20LIABILITY,\x20OR\x20T\
-    ORT\n\x20(INCLUDING\x20NEGLIGENCE\x20OR\x20OTHERWISE)\x20ARISING\x20IN\
-    \x20ANY\x20WAY\x20OUT\x20OF\x20THE\x20USE\n\x20OF\x20THIS\x20SOFTWARE,\
-    \x20EVEN\x20IF\x20ADVISED\x20OF\x20THE\x20POSSIBILITY\x20OF\x20SUCH\x20D\
-    AMAGE.\n2\xfb\x04\x20Author:\x20kenton@google.com\x20(Kenton\x20Varda)\n\
-    \n\x20WARNING:\x20\x20The\x20plugin\x20interface\x20is\x20currently\x20E\
-    XPERIMENTAL\x20and\x20is\x20subject\x20to\n\x20\x20\x20change.\n\n\x20pr\
-    otoc\x20(aka\x20the\x20Protocol\x20Compiler)\x20can\x20be\x20extended\
-    \x20via\x20plugins.\x20\x20A\x20plugin\x20is\n\x20just\x20a\x20program\
-    \x20that\x20reads\x20a\x20CodeGeneratorRequest\x20from\x20stdin\x20and\
-    \x20writes\x20a\n\x20CodeGeneratorResponse\x20to\x20stdout.\n\n\x20Plugi\
-    ns\x20written\x20using\x20C++\x20can\x20use\x20google/protobuf/compiler/\
-    plugin.h\x20instead\n\x20of\x20dealing\x20with\x20the\x20raw\x20protocol\
-    \x20defined\x20here.\n\n\x20A\x20plugin\x20executable\x20needs\x20only\
-    \x20to\x20be\x20placed\x20somewhere\x20in\x20the\x20path.\x20\x20The\n\
-    \x20plugin\x20should\x20be\x20named\x20\"protoc-gen-$NAME\",\x20and\x20w\
-    ill\x20then\x20be\x20used\x20when\x20the\n\x20flag\x20\"--${NAME}_out\"\
-    \x20is\x20passed\x20to\x20protoc.\n\n\x08\n\x01\x02\x12\x03/\0!\n\x08\n\
-    \x01\x08\x12\x030\05\n\t\n\x02\x08\x01\x12\x030\05\n\x08\n\x01\x08\x12\
-    \x031\0-\n\t\n\x02\x08\x08\x12\x031\0-\n\x08\n\x01\x08\x12\x033\0\x20\n\
-    \t\n\x02\x08\x0b\x12\x033\0\x20\n\t\n\x02\x03\0\x12\x035\0*\nO\n\x02\x04\
-    \0\x12\x048\0M\x01\x1aC\x20An\x20encoded\x20CodeGeneratorRequest\x20is\
-    \x20written\x20to\x20the\x20plugin's\x20stdin.\n\n\n\n\x03\x04\0\x01\x12\
-    \x038\x08\x1c\n\xd1\x01\n\x04\x04\0\x02\0\x12\x03<\x02'\x1a\xc3\x01\x20T\
-    he\x20.proto\x20files\x20that\x20were\x20explicitly\x20listed\x20on\x20t\
-    he\x20command-line.\x20\x20The\n\x20code\x20generator\x20should\x20gener\
-    ate\x20code\x20only\x20for\x20these\x20files.\x20\x20Each\x20file's\n\
-    \x20descriptor\x20will\x20be\x20included\x20in\x20proto_file,\x20below.\
-    \n\n\x0c\n\x05\x04\0\x02\0\x04\x12\x03<\x02\n\n\x0c\n\x05\x04\0\x02\0\
-    \x05\x12\x03<\x0b\x11\n\x0c\n\x05\x04\0\x02\0\x01\x12\x03<\x12\"\n\x0c\n\
-    \x05\x04\0\x02\0\x03\x12\x03<%&\nB\n\x04\x04\0\x02\x01\x12\x03?\x02\x20\
-    \x1a5\x20The\x20generator\x20parameter\x20passed\x20on\x20the\x20command\
-    -line.\n\n\x0c\n\x05\x04\0\x02\x01\x04\x12\x03?\x02\n\n\x0c\n\x05\x04\0\
-    \x02\x01\x05\x12\x03?\x0b\x11\n\x0c\n\x05\x04\0\x02\x01\x01\x12\x03?\x12\
-    \x1b\n\x0c\n\x05\x04\0\x02\x01\x03\x12\x03?\x1e\x1f\n\xa9\x05\n\x04\x04\
-    \0\x02\x02\x12\x03L\x02/\x1a\x9b\x05\x20FileDescriptorProtos\x20for\x20a\
-    ll\x20files\x20in\x20files_to_generate\x20and\x20everything\n\x20they\
-    \x20import.\x20\x20The\x20files\x20will\x20appear\x20in\x20topological\
-    \x20order,\x20so\x20each\x20file\n\x20appears\x20before\x20any\x20file\
-    \x20that\x20imports\x20it.\n\n\x20protoc\x20guarantees\x20that\x20all\
-    \x20proto_files\x20will\x20be\x20written\x20after\n\x20the\x20fields\x20\
-    above,\x20even\x20though\x20this\x20is\x20not\x20technically\x20guarante\
-    ed\x20by\x20the\n\x20protobuf\x20wire\x20format.\x20\x20This\x20theoreti\
-    cally\x20could\x20allow\x20a\x20plugin\x20to\x20stream\n\x20in\x20the\
-    \x20FileDescriptorProtos\x20and\x20handle\x20them\x20one\x20by\x20one\
-    \x20rather\x20than\x20read\n\x20the\x20entire\x20set\x20into\x20memory\
-    \x20at\x20once.\x20\x20However,\x20as\x20of\x20this\x20writing,\x20this\
-    \n\x20is\x20not\x20similarly\x20optimized\x20on\x20protoc's\x20end\x20--\
-    \x20it\x20will\x20store\x20all\x20fields\x20in\n\x20memory\x20at\x20once\
-    \x20before\x20sending\x20them\x20to\x20the\x20plugin.\n\n\x0c\n\x05\x04\
-    \0\x02\x02\x04\x12\x03L\x02\n\n\x0c\n\x05\x04\0\x02\x02\x06\x12\x03L\x0b\
-    \x1e\n\x0c\n\x05\x04\0\x02\x02\x01\x12\x03L\x1f)\n\x0c\n\x05\x04\0\x02\
-    \x02\x03\x12\x03L,.\nL\n\x02\x04\x01\x12\x05P\0\x95\x01\x01\x1a?\x20The\
-    \x20plugin\x20writes\x20an\x20encoded\x20CodeGeneratorResponse\x20to\x20\
-    stdout.\n\n\n\n\x03\x04\x01\x01\x12\x03P\x08\x1d\n\xed\x03\n\x04\x04\x01\
-    \x02\0\x12\x03Y\x02\x1c\x1a\xdf\x03\x20Error\x20message.\x20\x20If\x20no\
-    n-empty,\x20code\x20generation\x20failed.\x20\x20The\x20plugin\x20proces\
-    s\n\x20should\x20exit\x20with\x20status\x20code\x20zero\x20even\x20if\
-    \x20it\x20reports\x20an\x20error\x20in\x20this\x20way.\n\n\x20This\x20sh\
-    ould\x20be\x20used\x20to\x20indicate\x20errors\x20in\x20.proto\x20files\
-    \x20which\x20prevent\x20the\n\x20code\x20generator\x20from\x20generating\
-    \x20correct\x20code.\x20\x20Errors\x20which\x20indicate\x20a\n\x20proble\
-    m\x20in\x20protoc\x20itself\x20--\x20such\x20as\x20the\x20input\x20CodeG\
-    eneratorRequest\x20being\n\x20unparseable\x20--\x20should\x20be\x20repor\
-    ted\x20by\x20writing\x20a\x20message\x20to\x20stderr\x20and\n\x20exiting\
-    \x20with\x20a\x20non-zero\x20status\x20code.\n\n\x0c\n\x05\x04\x01\x02\0\
-    \x04\x12\x03Y\x02\n\n\x0c\n\x05\x04\x01\x02\0\x05\x12\x03Y\x0b\x11\n\x0c\
-    \n\x05\x04\x01\x02\0\x01\x12\x03Y\x12\x17\n\x0c\n\x05\x04\x01\x02\0\x03\
-    \x12\x03Y\x1a\x1b\n4\n\x04\x04\x01\x03\0\x12\x05\\\x02\x93\x01\x03\x1a%\
-    \x20Represents\x20a\x20single\x20generated\x20file.\n\n\x0c\n\x05\x04\
-    \x01\x03\0\x01\x12\x03\\\n\x0e\n\xad\x05\n\x06\x04\x01\x03\0\x02\0\x12\
-    \x03h\x04\x1d\x1a\x9d\x05\x20The\x20file\x20name,\x20relative\x20to\x20t\
-    he\x20output\x20directory.\x20\x20The\x20name\x20must\x20not\n\x20contai\
-    n\x20\".\"\x20or\x20\"..\"\x20components\x20and\x20must\x20be\x20relativ\
-    e,\x20not\x20be\x20absolute\x20(so,\n\x20the\x20file\x20cannot\x20lie\
-    \x20outside\x20the\x20output\x20directory).\x20\x20\"/\"\x20must\x20be\
-    \x20used\x20as\n\x20the\x20path\x20separator,\x20not\x20\"\\\".\n\n\x20I\
-    f\x20the\x20name\x20is\x20omitted,\x20the\x20content\x20will\x20be\x20ap\
-    pended\x20to\x20the\x20previous\n\x20file.\x20\x20This\x20allows\x20the\
-    \x20generator\x20to\x20break\x20large\x20files\x20into\x20small\x20chunk\
-    s,\n\x20and\x20allows\x20the\x20generated\x20text\x20to\x20be\x20streame\
-    d\x20back\x20to\x20protoc\x20so\x20that\x20large\n\x20files\x20need\x20n\
-    ot\x20reside\x20completely\x20in\x20memory\x20at\x20one\x20time.\x20\x20\
-    Note\x20that\x20as\x20of\n\x20this\x20writing\x20protoc\x20does\x20not\
-    \x20optimize\x20for\x20this\x20--\x20it\x20will\x20read\x20the\x20entire\
-    \n\x20CodeGeneratorResponse\x20before\x20writing\x20files\x20to\x20disk.\
-    \n\n\x0e\n\x07\x04\x01\x03\0\x02\0\x04\x12\x03h\x04\x0c\n\x0e\n\x07\x04\
-    \x01\x03\0\x02\0\x05\x12\x03h\r\x13\n\x0e\n\x07\x04\x01\x03\0\x02\0\x01\
-    \x12\x03h\x14\x18\n\x0e\n\x07\x04\x01\x03\0\x02\0\x03\x12\x03h\x1b\x1c\n\
-    \xae\x10\n\x06\x04\x01\x03\0\x02\x01\x12\x04\x8f\x01\x04(\x1a\x9d\x10\
-    \x20If\x20non-empty,\x20indicates\x20that\x20the\x20named\x20file\x20sho\
-    uld\x20already\x20exist,\x20and\x20the\n\x20content\x20here\x20is\x20to\
-    \x20be\x20inserted\x20into\x20that\x20file\x20at\x20a\x20defined\x20inse\
-    rtion\n\x20point.\x20\x20This\x20feature\x20allows\x20a\x20code\x20gener\
-    ator\x20to\x20extend\x20the\x20output\n\x20produced\x20by\x20another\x20\
-    code\x20generator.\x20\x20The\x20original\x20generator\x20may\x20provide\
-    \n\x20insertion\x20points\x20by\x20placing\x20special\x20annotations\x20\
-    in\x20the\x20file\x20that\x20look\n\x20like:\n\x20\x20\x20@@protoc_inser\
-    tion_point(NAME)\n\x20The\x20annotation\x20can\x20have\x20arbitrary\x20t\
-    ext\x20before\x20and\x20after\x20it\x20on\x20the\x20line,\n\x20which\x20\
-    allows\x20it\x20to\x20be\x20placed\x20in\x20a\x20comment.\x20\x20NAME\
-    \x20should\x20be\x20replaced\x20with\n\x20an\x20identifier\x20naming\x20\
-    the\x20point\x20--\x20this\x20is\x20what\x20other\x20generators\x20will\
-    \x20use\n\x20as\x20the\x20insertion_point.\x20\x20Code\x20inserted\x20at\
-    \x20this\x20point\x20will\x20be\x20placed\n\x20immediately\x20above\x20t\
-    he\x20line\x20containing\x20the\x20insertion\x20point\x20(thus\x20multip\
-    le\n\x20insertions\x20to\x20the\x20same\x20point\x20will\x20come\x20out\
-    \x20in\x20the\x20order\x20they\x20were\x20added).\n\x20The\x20double-@\
-    \x20is\x20intended\x20to\x20make\x20it\x20unlikely\x20that\x20the\x20gen\
-    erated\x20code\n\x20could\x20contain\x20things\x20that\x20look\x20like\
-    \x20insertion\x20points\x20by\x20accident.\n\n\x20For\x20example,\x20the\
-    \x20C++\x20code\x20generator\x20places\x20the\x20following\x20line\x20in\
-    \x20the\n\x20.pb.h\x20files\x20that\x20it\x20generates:\n\x20\x20\x20//\
-    \x20@@protoc_insertion_point(namespace_scope)\n\x20This\x20line\x20appea\
-    rs\x20within\x20the\x20scope\x20of\x20the\x20file's\x20package\x20namesp\
-    ace,\x20but\n\x20outside\x20of\x20any\x20particular\x20class.\x20\x20Ano\
-    ther\x20plugin\x20can\x20then\x20specify\x20the\n\x20insertion_point\x20\
-    \"namespace_scope\"\x20to\x20generate\x20additional\x20classes\x20or\n\
-    \x20other\x20declarations\x20that\x20should\x20be\x20placed\x20in\x20thi\
-    s\x20scope.\n\n\x20Note\x20that\x20if\x20the\x20line\x20containing\x20th\
-    e\x20insertion\x20point\x20begins\x20with\n\x20whitespace,\x20the\x20sam\
-    e\x20whitespace\x20will\x20be\x20added\x20to\x20every\x20line\x20of\x20t\
-    he\n\x20inserted\x20text.\x20\x20This\x20is\x20useful\x20for\x20language\
-    s\x20like\x20Python,\x20where\n\x20indentation\x20matters.\x20\x20In\x20\
-    these\x20languages,\x20the\x20insertion\x20point\x20comment\n\x20should\
-    \x20be\x20indented\x20the\x20same\x20amount\x20as\x20any\x20inserted\x20\
-    code\x20will\x20need\x20to\x20be\n\x20in\x20order\x20to\x20work\x20corre\
-    ctly\x20in\x20that\x20context.\n\n\x20The\x20code\x20generator\x20that\
-    \x20generates\x20the\x20initial\x20file\x20and\x20the\x20one\x20which\n\
-    \x20inserts\x20into\x20it\x20must\x20both\x20run\x20as\x20part\x20of\x20\
-    a\x20single\x20invocation\x20of\x20protoc.\n\x20Code\x20generators\x20ar\
-    e\x20executed\x20in\x20the\x20order\x20in\x20which\x20they\x20appear\x20\
-    on\x20the\n\x20command\x20line.\n\n\x20If\x20|insertion_point|\x20is\x20\
-    present,\x20|name|\x20must\x20also\x20be\x20present.\n\n\x0f\n\x07\x04\
-    \x01\x03\0\x02\x01\x04\x12\x04\x8f\x01\x04\x0c\n\x0f\n\x07\x04\x01\x03\0\
-    \x02\x01\x05\x12\x04\x8f\x01\r\x13\n\x0f\n\x07\x04\x01\x03\0\x02\x01\x01\
-    \x12\x04\x8f\x01\x14#\n\x0f\n\x07\x04\x01\x03\0\x02\x01\x03\x12\x04\x8f\
-    \x01&'\n$\n\x06\x04\x01\x03\0\x02\x02\x12\x04\x92\x01\x04!\x1a\x14\x20Th\
-    e\x20file\x20contents.\n\n\x0f\n\x07\x04\x01\x03\0\x02\x02\x04\x12\x04\
-    \x92\x01\x04\x0c\n\x0f\n\x07\x04\x01\x03\0\x02\x02\x05\x12\x04\x92\x01\r\
-    \x13\n\x0f\n\x07\x04\x01\x03\0\x02\x02\x01\x12\x04\x92\x01\x14\x1b\n\x0f\
-    \n\x07\x04\x01\x03\0\x02\x02\x03\x12\x04\x92\x01\x1e\x20\n\x0c\n\x04\x04\
-    \x01\x02\x01\x12\x04\x94\x01\x02\x1a\n\r\n\x05\x04\x01\x02\x01\x04\x12\
-    \x04\x94\x01\x02\n\n\r\n\x05\x04\x01\x02\x01\x06\x12\x04\x94\x01\x0b\x0f\
-    \n\r\n\x05\x04\x01\x02\x01\x01\x12\x04\x94\x01\x10\x14\n\r\n\x05\x04\x01\
-    \x02\x01\x03\x12\x04\x94\x01\x17\x19\
+    \x12L\n\x10compiler_version\x18\x03\x20\x01(\x0b2!.google.protobuf.compi\
+    ler.VersionR\x0fcompilerVersion\"\x94\x03\n\x15CodeGeneratorResponse\x12\
+    \x14\n\x05error\x18\x01\x20\x01(\tR\x05error\x12-\n\x12supported_feature\
+    s\x18\x02\x20\x01(\x04R\x11supportedFeatures\x12H\n\x04file\x18\x0f\x20\
+    \x03(\x0b24.google.protobuf.compiler.CodeGeneratorResponse.FileR\x04file\
+    \x1a\xb1\x01\n\x04File\x12\x12\n\x04name\x18\x01\x20\x01(\tR\x04name\x12\
+    '\n\x0finsertion_point\x18\x02\x20\x01(\tR\x0einsertionPoint\x12\x18\n\
+    \x07content\x18\x0f\x20\x01(\tR\x07content\x12R\n\x13generated_code_info\
+    \x18\x10\x20\x01(\x0b2\".google.protobuf.GeneratedCodeInfoR\x11generated\
+    CodeInfo\"8\n\x07Feature\x12\x10\n\x0cFEATURE_NONE\x10\0\x12\x1b\n\x17FE\
+    ATURE_PROTO3_OPTIONAL\x10\x01BW\n\x1ccom.google.protobuf.compilerB\x0cPl\
+    uginProtosZ)google.golang.org/protobuf/types/pluginpbJ\xf9C\n\x07\x12\
+    \x05.\0\xb6\x01\x01\n\xca\x11\n\x01\x0c\x12\x03.\0\x122\xc1\x0c\x20Proto\
+    col\x20Buffers\x20-\x20Google's\x20data\x20interchange\x20format\n\x20Co\
+    pyright\x202008\x20Google\x20Inc.\x20\x20All\x20rights\x20reserved.\n\
+    \x20https://developers.google.com/protocol-buffers/\n\n\x20Redistributio\
+    n\x20and\x20use\x20in\x20source\x20and\x20binary\x20forms,\x20with\x20or\
+    \x20without\n\x20modification,\x20are\x20permitted\x20provided\x20that\
+    \x20the\x20following\x20conditions\x20are\n\x20met:\n\n\x20\x20\x20\x20\
+    \x20*\x20Redistributions\x20of\x20source\x20code\x20must\x20retain\x20th\
+    e\x20above\x20copyright\n\x20notice,\x20this\x20list\x20of\x20conditions\
+    \x20and\x20the\x20following\x20disclaimer.\n\x20\x20\x20\x20\x20*\x20Red\
+    istributions\x20in\x20binary\x20form\x20must\x20reproduce\x20the\x20abov\
+    e\n\x20copyright\x20notice,\x20this\x20list\x20of\x20conditions\x20and\
+    \x20the\x20following\x20disclaimer\n\x20in\x20the\x20documentation\x20an\
+    d/or\x20other\x20materials\x20provided\x20with\x20the\n\x20distribution.\
+    \n\x20\x20\x20\x20\x20*\x20Neither\x20the\x20name\x20of\x20Google\x20Inc\
+    .\x20nor\x20the\x20names\x20of\x20its\n\x20contributors\x20may\x20be\x20\
+    used\x20to\x20endorse\x20or\x20promote\x20products\x20derived\x20from\n\
+    \x20this\x20software\x20without\x20specific\x20prior\x20written\x20permi\
+    ssion.\n\n\x20THIS\x20SOFTWARE\x20IS\x20PROVIDED\x20BY\x20THE\x20COPYRIG\
+    HT\x20HOLDERS\x20AND\x20CONTRIBUTORS\n\x20\"AS\x20IS\"\x20AND\x20ANY\x20\
+    EXPRESS\x20OR\x20IMPLIED\x20WARRANTIES,\x20INCLUDING,\x20BUT\x20NOT\n\
+    \x20LIMITED\x20TO,\x20THE\x20IMPLIED\x20WARRANTIES\x20OF\x20MERCHANTABIL\
+    ITY\x20AND\x20FITNESS\x20FOR\n\x20A\x20PARTICULAR\x20PURPOSE\x20ARE\x20D\
+    ISCLAIMED.\x20IN\x20NO\x20EVENT\x20SHALL\x20THE\x20COPYRIGHT\n\x20OWNER\
+    \x20OR\x20CONTRIBUTORS\x20BE\x20LIABLE\x20FOR\x20ANY\x20DIRECT,\x20INDIR\
+    ECT,\x20INCIDENTAL,\n\x20SPECIAL,\x20EXEMPLARY,\x20OR\x20CONSEQUENTIAL\
+    \x20DAMAGES\x20(INCLUDING,\x20BUT\x20NOT\n\x20LIMITED\x20TO,\x20PROCUREM\
+    ENT\x20OF\x20SUBSTITUTE\x20GOODS\x20OR\x20SERVICES;\x20LOSS\x20OF\x20USE\
+    ,\n\x20DATA,\x20OR\x20PROFITS;\x20OR\x20BUSINESS\x20INTERRUPTION)\x20HOW\
+    EVER\x20CAUSED\x20AND\x20ON\x20ANY\n\x20THEORY\x20OF\x20LIABILITY,\x20WH\
+    ETHER\x20IN\x20CONTRACT,\x20STRICT\x20LIABILITY,\x20OR\x20TORT\n\x20(INC\
+    LUDING\x20NEGLIGENCE\x20OR\x20OTHERWISE)\x20ARISING\x20IN\x20ANY\x20WAY\
+    \x20OUT\x20OF\x20THE\x20USE\n\x20OF\x20THIS\x20SOFTWARE,\x20EVEN\x20IF\
+    \x20ADVISED\x20OF\x20THE\x20POSSIBILITY\x20OF\x20SUCH\x20DAMAGE.\n2\xfb\
+    \x04\x20Author:\x20kenton@google.com\x20(Kenton\x20Varda)\n\n\x20WARNING\
+    :\x20\x20The\x20plugin\x20interface\x20is\x20currently\x20EXPERIMENTAL\
+    \x20and\x20is\x20subject\x20to\n\x20\x20\x20change.\n\n\x20protoc\x20(ak\
+    a\x20the\x20Protocol\x20Compiler)\x20can\x20be\x20extended\x20via\x20plu\
+    gins.\x20\x20A\x20plugin\x20is\n\x20just\x20a\x20program\x20that\x20read\
+    s\x20a\x20CodeGeneratorRequest\x20from\x20stdin\x20and\x20writes\x20a\n\
+    \x20CodeGeneratorResponse\x20to\x20stdout.\n\n\x20Plugins\x20written\x20\
+    using\x20C++\x20can\x20use\x20google/protobuf/compiler/plugin.h\x20inste\
+    ad\n\x20of\x20dealing\x20with\x20the\x20raw\x20protocol\x20defined\x20he\
+    re.\n\n\x20A\x20plugin\x20executable\x20needs\x20only\x20to\x20be\x20pla\
+    ced\x20somewhere\x20in\x20the\x20path.\x20\x20The\n\x20plugin\x20should\
+    \x20be\x20named\x20\"protoc-gen-$NAME\",\x20and\x20will\x20then\x20be\
+    \x20used\x20when\x20the\n\x20flag\x20\"--${NAME}_out\"\x20is\x20passed\
+    \x20to\x20protoc.\n\n\x08\n\x01\x02\x12\x030\0!\n\x08\n\x01\x08\x12\x031\
+    \05\n\t\n\x02\x08\x01\x12\x031\05\n\x08\n\x01\x08\x12\x032\0-\n\t\n\x02\
+    \x08\x08\x12\x032\0-\n\x08\n\x01\x08\x12\x034\0@\n\t\n\x02\x08\x0b\x12\
+    \x034\0@\n\t\n\x02\x03\0\x12\x036\0*\n6\n\x02\x04\0\x12\x049\0@\x01\x1a*\
+    \x20The\x20version\x20number\x20of\x20protocol\x20compiler.\n\n\n\n\x03\
+    \x04\0\x01\x12\x039\x08\x0f\n\x0b\n\x04\x04\0\x02\0\x12\x03:\x02\x1b\n\
+    \x0c\n\x05\x04\0\x02\0\x04\x12\x03:\x02\n\n\x0c\n\x05\x04\0\x02\0\x05\
+    \x12\x03:\x0b\x10\n\x0c\n\x05\x04\0\x02\0\x01\x12\x03:\x11\x16\n\x0c\n\
+    \x05\x04\0\x02\0\x03\x12\x03:\x19\x1a\n\x0b\n\x04\x04\0\x02\x01\x12\x03;\
+    \x02\x1b\n\x0c\n\x05\x04\0\x02\x01\x04\x12\x03;\x02\n\n\x0c\n\x05\x04\0\
+    \x02\x01\x05\x12\x03;\x0b\x10\n\x0c\n\x05\x04\0\x02\x01\x01\x12\x03;\x11\
+    \x16\n\x0c\n\x05\x04\0\x02\x01\x03\x12\x03;\x19\x1a\n\x0b\n\x04\x04\0\
+    \x02\x02\x12\x03<\x02\x1b\n\x0c\n\x05\x04\0\x02\x02\x04\x12\x03<\x02\n\n\
+    \x0c\n\x05\x04\0\x02\x02\x05\x12\x03<\x0b\x10\n\x0c\n\x05\x04\0\x02\x02\
+    \x01\x12\x03<\x11\x16\n\x0c\n\x05\x04\0\x02\x02\x03\x12\x03<\x19\x1a\n\
+    \x80\x01\n\x04\x04\0\x02\x03\x12\x03?\x02\x1d\x1as\x20A\x20suffix\x20for\
+    \x20alpha,\x20beta\x20or\x20rc\x20release,\x20e.g.,\x20\"alpha-1\",\x20\
+    \"rc2\".\x20It\x20should\n\x20be\x20empty\x20for\x20mainline\x20stable\
+    \x20releases.\n\n\x0c\n\x05\x04\0\x02\x03\x04\x12\x03?\x02\n\n\x0c\n\x05\
+    \x04\0\x02\x03\x05\x12\x03?\x0b\x11\n\x0c\n\x05\x04\0\x02\x03\x01\x12\
+    \x03?\x12\x18\n\x0c\n\x05\x04\0\x02\x03\x03\x12\x03?\x1b\x1c\nO\n\x02\
+    \x04\x01\x12\x04C\0_\x01\x1aC\x20An\x20encoded\x20CodeGeneratorRequest\
+    \x20is\x20written\x20to\x20the\x20plugin's\x20stdin.\n\n\n\n\x03\x04\x01\
+    \x01\x12\x03C\x08\x1c\n\xd1\x01\n\x04\x04\x01\x02\0\x12\x03G\x02'\x1a\
+    \xc3\x01\x20The\x20.proto\x20files\x20that\x20were\x20explicitly\x20list\
+    ed\x20on\x20the\x20command-line.\x20\x20The\n\x20code\x20generator\x20sh\
+    ould\x20generate\x20code\x20only\x20for\x20these\x20files.\x20\x20Each\
+    \x20file's\n\x20descriptor\x20will\x20be\x20included\x20in\x20proto_file\
+    ,\x20below.\n\n\x0c\n\x05\x04\x01\x02\0\x04\x12\x03G\x02\n\n\x0c\n\x05\
+    \x04\x01\x02\0\x05\x12\x03G\x0b\x11\n\x0c\n\x05\x04\x01\x02\0\x01\x12\
+    \x03G\x12\"\n\x0c\n\x05\x04\x01\x02\0\x03\x12\x03G%&\nB\n\x04\x04\x01\
+    \x02\x01\x12\x03J\x02\x20\x1a5\x20The\x20generator\x20parameter\x20passe\
+    d\x20on\x20the\x20command-line.\n\n\x0c\n\x05\x04\x01\x02\x01\x04\x12\
+    \x03J\x02\n\n\x0c\n\x05\x04\x01\x02\x01\x05\x12\x03J\x0b\x11\n\x0c\n\x05\
+    \x04\x01\x02\x01\x01\x12\x03J\x12\x1b\n\x0c\n\x05\x04\x01\x02\x01\x03\
+    \x12\x03J\x1e\x1f\n\x87\x06\n\x04\x04\x01\x02\x02\x12\x03Z\x02/\x1a\xf9\
+    \x05\x20FileDescriptorProtos\x20for\x20all\x20files\x20in\x20files_to_ge\
+    nerate\x20and\x20everything\n\x20they\x20import.\x20\x20The\x20files\x20\
+    will\x20appear\x20in\x20topological\x20order,\x20so\x20each\x20file\n\
+    \x20appears\x20before\x20any\x20file\x20that\x20imports\x20it.\n\n\x20pr\
+    otoc\x20guarantees\x20that\x20all\x20proto_files\x20will\x20be\x20writte\
+    n\x20after\n\x20the\x20fields\x20above,\x20even\x20though\x20this\x20is\
+    \x20not\x20technically\x20guaranteed\x20by\x20the\n\x20protobuf\x20wire\
+    \x20format.\x20\x20This\x20theoretically\x20could\x20allow\x20a\x20plugi\
+    n\x20to\x20stream\n\x20in\x20the\x20FileDescriptorProtos\x20and\x20handl\
+    e\x20them\x20one\x20by\x20one\x20rather\x20than\x20read\n\x20the\x20enti\
+    re\x20set\x20into\x20memory\x20at\x20once.\x20\x20However,\x20as\x20of\
+    \x20this\x20writing,\x20this\n\x20is\x20not\x20similarly\x20optimized\
+    \x20on\x20protoc's\x20end\x20--\x20it\x20will\x20store\x20all\x20fields\
+    \x20in\n\x20memory\x20at\x20once\x20before\x20sending\x20them\x20to\x20t\
+    he\x20plugin.\n\n\x20Type\x20names\x20of\x20fields\x20and\x20extensions\
+    \x20in\x20the\x20FileDescriptorProto\x20are\x20always\n\x20fully\x20qual\
+    ified.\n\n\x0c\n\x05\x04\x01\x02\x02\x04\x12\x03Z\x02\n\n\x0c\n\x05\x04\
+    \x01\x02\x02\x06\x12\x03Z\x0b\x1e\n\x0c\n\x05\x04\x01\x02\x02\x01\x12\
+    \x03Z\x1f)\n\x0c\n\x05\x04\x01\x02\x02\x03\x12\x03Z,.\n7\n\x04\x04\x01\
+    \x02\x03\x12\x03]\x02(\x1a*\x20The\x20version\x20number\x20of\x20protoco\
+    l\x20compiler.\n\n\x0c\n\x05\x04\x01\x02\x03\x04\x12\x03]\x02\n\n\x0c\n\
+    \x05\x04\x01\x02\x03\x06\x12\x03]\x0b\x12\n\x0c\n\x05\x04\x01\x02\x03\
+    \x01\x12\x03]\x13#\n\x0c\n\x05\x04\x01\x02\x03\x03\x12\x03]&'\nL\n\x02\
+    \x04\x02\x12\x05b\0\xb6\x01\x01\x1a?\x20The\x20plugin\x20writes\x20an\
+    \x20encoded\x20CodeGeneratorResponse\x20to\x20stdout.\n\n\n\n\x03\x04\
+    \x02\x01\x12\x03b\x08\x1d\n\xed\x03\n\x04\x04\x02\x02\0\x12\x03k\x02\x1c\
+    \x1a\xdf\x03\x20Error\x20message.\x20\x20If\x20non-empty,\x20code\x20gen\
+    eration\x20failed.\x20\x20The\x20plugin\x20process\n\x20should\x20exit\
+    \x20with\x20status\x20code\x20zero\x20even\x20if\x20it\x20reports\x20an\
+    \x20error\x20in\x20this\x20way.\n\n\x20This\x20should\x20be\x20used\x20t\
+    o\x20indicate\x20errors\x20in\x20.proto\x20files\x20which\x20prevent\x20\
+    the\n\x20code\x20generator\x20from\x20generating\x20correct\x20code.\x20\
+    \x20Errors\x20which\x20indicate\x20a\n\x20problem\x20in\x20protoc\x20its\
+    elf\x20--\x20such\x20as\x20the\x20input\x20CodeGeneratorRequest\x20being\
+    \n\x20unparseable\x20--\x20should\x20be\x20reported\x20by\x20writing\x20\
+    a\x20message\x20to\x20stderr\x20and\n\x20exiting\x20with\x20a\x20non-zer\
+    o\x20status\x20code.\n\n\x0c\n\x05\x04\x02\x02\0\x04\x12\x03k\x02\n\n\
+    \x0c\n\x05\x04\x02\x02\0\x05\x12\x03k\x0b\x11\n\x0c\n\x05\x04\x02\x02\0\
+    \x01\x12\x03k\x12\x17\n\x0c\n\x05\x04\x02\x02\0\x03\x12\x03k\x1a\x1b\n\
+    \x89\x01\n\x04\x04\x02\x02\x01\x12\x03o\x02)\x1a|\x20A\x20bitmask\x20of\
+    \x20supported\x20features\x20that\x20the\x20code\x20generator\x20support\
+    s.\n\x20This\x20is\x20a\x20bitwise\x20\"or\"\x20of\x20values\x20from\x20\
+    the\x20Feature\x20enum.\n\n\x0c\n\x05\x04\x02\x02\x01\x04\x12\x03o\x02\n\
+    \n\x0c\n\x05\x04\x02\x02\x01\x05\x12\x03o\x0b\x11\n\x0c\n\x05\x04\x02\
+    \x02\x01\x01\x12\x03o\x12$\n\x0c\n\x05\x04\x02\x02\x01\x03\x12\x03o'(\n+\
+    \n\x04\x04\x02\x04\0\x12\x04r\x02u\x03\x1a\x1d\x20Sync\x20with\x20code_g\
+    enerator.h.\n\n\x0c\n\x05\x04\x02\x04\0\x01\x12\x03r\x07\x0e\n\r\n\x06\
+    \x04\x02\x04\0\x02\0\x12\x03s\x04\x15\n\x0e\n\x07\x04\x02\x04\0\x02\0\
+    \x01\x12\x03s\x04\x10\n\x0e\n\x07\x04\x02\x04\0\x02\0\x02\x12\x03s\x13\
+    \x14\n\r\n\x06\x04\x02\x04\0\x02\x01\x12\x03t\x04\x20\n\x0e\n\x07\x04\
+    \x02\x04\0\x02\x01\x01\x12\x03t\x04\x1b\n\x0e\n\x07\x04\x02\x04\0\x02\
+    \x01\x02\x12\x03t\x1e\x1f\n4\n\x04\x04\x02\x03\0\x12\x05x\x02\xb4\x01\
+    \x03\x1a%\x20Represents\x20a\x20single\x20generated\x20file.\n\n\x0c\n\
+    \x05\x04\x02\x03\0\x01\x12\x03x\n\x0e\n\xae\x05\n\x06\x04\x02\x03\0\x02\
+    \0\x12\x04\x84\x01\x04\x1d\x1a\x9d\x05\x20The\x20file\x20name,\x20relati\
+    ve\x20to\x20the\x20output\x20directory.\x20\x20The\x20name\x20must\x20no\
+    t\n\x20contain\x20\".\"\x20or\x20\"..\"\x20components\x20and\x20must\x20\
+    be\x20relative,\x20not\x20be\x20absolute\x20(so,\n\x20the\x20file\x20can\
+    not\x20lie\x20outside\x20the\x20output\x20directory).\x20\x20\"/\"\x20mu\
+    st\x20be\x20used\x20as\n\x20the\x20path\x20separator,\x20not\x20\"\\\".\
+    \n\n\x20If\x20the\x20name\x20is\x20omitted,\x20the\x20content\x20will\
+    \x20be\x20appended\x20to\x20the\x20previous\n\x20file.\x20\x20This\x20al\
+    lows\x20the\x20generator\x20to\x20break\x20large\x20files\x20into\x20sma\
+    ll\x20chunks,\n\x20and\x20allows\x20the\x20generated\x20text\x20to\x20be\
+    \x20streamed\x20back\x20to\x20protoc\x20so\x20that\x20large\n\x20files\
+    \x20need\x20not\x20reside\x20completely\x20in\x20memory\x20at\x20one\x20\
+    time.\x20\x20Note\x20that\x20as\x20of\n\x20this\x20writing\x20protoc\x20\
+    does\x20not\x20optimize\x20for\x20this\x20--\x20it\x20will\x20read\x20th\
+    e\x20entire\n\x20CodeGeneratorResponse\x20before\x20writing\x20files\x20\
+    to\x20disk.\n\n\x0f\n\x07\x04\x02\x03\0\x02\0\x04\x12\x04\x84\x01\x04\
+    \x0c\n\x0f\n\x07\x04\x02\x03\0\x02\0\x05\x12\x04\x84\x01\r\x13\n\x0f\n\
+    \x07\x04\x02\x03\0\x02\0\x01\x12\x04\x84\x01\x14\x18\n\x0f\n\x07\x04\x02\
+    \x03\0\x02\0\x03\x12\x04\x84\x01\x1b\x1c\n\xae\x10\n\x06\x04\x02\x03\0\
+    \x02\x01\x12\x04\xab\x01\x04(\x1a\x9d\x10\x20If\x20non-empty,\x20indicat\
+    es\x20that\x20the\x20named\x20file\x20should\x20already\x20exist,\x20and\
+    \x20the\n\x20content\x20here\x20is\x20to\x20be\x20inserted\x20into\x20th\
+    at\x20file\x20at\x20a\x20defined\x20insertion\n\x20point.\x20\x20This\
+    \x20feature\x20allows\x20a\x20code\x20generator\x20to\x20extend\x20the\
+    \x20output\n\x20produced\x20by\x20another\x20code\x20generator.\x20\x20T\
+    he\x20original\x20generator\x20may\x20provide\n\x20insertion\x20points\
+    \x20by\x20placing\x20special\x20annotations\x20in\x20the\x20file\x20that\
+    \x20look\n\x20like:\n\x20\x20\x20@@protoc_insertion_point(NAME)\n\x20The\
+    \x20annotation\x20can\x20have\x20arbitrary\x20text\x20before\x20and\x20a\
+    fter\x20it\x20on\x20the\x20line,\n\x20which\x20allows\x20it\x20to\x20be\
+    \x20placed\x20in\x20a\x20comment.\x20\x20NAME\x20should\x20be\x20replace\
+    d\x20with\n\x20an\x20identifier\x20naming\x20the\x20point\x20--\x20this\
+    \x20is\x20what\x20other\x20generators\x20will\x20use\n\x20as\x20the\x20i\
+    nsertion_point.\x20\x20Code\x20inserted\x20at\x20this\x20point\x20will\
+    \x20be\x20placed\n\x20immediately\x20above\x20the\x20line\x20containing\
+    \x20the\x20insertion\x20point\x20(thus\x20multiple\n\x20insertions\x20to\
+    \x20the\x20same\x20point\x20will\x20come\x20out\x20in\x20the\x20order\
+    \x20they\x20were\x20added).\n\x20The\x20double-@\x20is\x20intended\x20to\
+    \x20make\x20it\x20unlikely\x20that\x20the\x20generated\x20code\n\x20coul\
+    d\x20contain\x20things\x20that\x20look\x20like\x20insertion\x20points\
+    \x20by\x20accident.\n\n\x20For\x20example,\x20the\x20C++\x20code\x20gene\
+    rator\x20places\x20the\x20following\x20line\x20in\x20the\n\x20.pb.h\x20f\
+    iles\x20that\x20it\x20generates:\n\x20\x20\x20//\x20@@protoc_insertion_p\
+    oint(namespace_scope)\n\x20This\x20line\x20appears\x20within\x20the\x20s\
+    cope\x20of\x20the\x20file's\x20package\x20namespace,\x20but\n\x20outside\
+    \x20of\x20any\x20particular\x20class.\x20\x20Another\x20plugin\x20can\
+    \x20then\x20specify\x20the\n\x20insertion_point\x20\"namespace_scope\"\
+    \x20to\x20generate\x20additional\x20classes\x20or\n\x20other\x20declarat\
+    ions\x20that\x20should\x20be\x20placed\x20in\x20this\x20scope.\n\n\x20No\
+    te\x20that\x20if\x20the\x20line\x20containing\x20the\x20insertion\x20poi\
+    nt\x20begins\x20with\n\x20whitespace,\x20the\x20same\x20whitespace\x20wi\
+    ll\x20be\x20added\x20to\x20every\x20line\x20of\x20the\n\x20inserted\x20t\
+    ext.\x20\x20This\x20is\x20useful\x20for\x20languages\x20like\x20Python,\
+    \x20where\n\x20indentation\x20matters.\x20\x20In\x20these\x20languages,\
+    \x20the\x20insertion\x20point\x20comment\n\x20should\x20be\x20indented\
+    \x20the\x20same\x20amount\x20as\x20any\x20inserted\x20code\x20will\x20ne\
+    ed\x20to\x20be\n\x20in\x20order\x20to\x20work\x20correctly\x20in\x20that\
+    \x20context.\n\n\x20The\x20code\x20generator\x20that\x20generates\x20the\
+    \x20initial\x20file\x20and\x20the\x20one\x20which\n\x20inserts\x20into\
+    \x20it\x20must\x20both\x20run\x20as\x20part\x20of\x20a\x20single\x20invo\
+    cation\x20of\x20protoc.\n\x20Code\x20generators\x20are\x20executed\x20in\
+    \x20the\x20order\x20in\x20which\x20they\x20appear\x20on\x20the\n\x20comm\
+    and\x20line.\n\n\x20If\x20|insertion_point|\x20is\x20present,\x20|name|\
+    \x20must\x20also\x20be\x20present.\n\n\x0f\n\x07\x04\x02\x03\0\x02\x01\
+    \x04\x12\x04\xab\x01\x04\x0c\n\x0f\n\x07\x04\x02\x03\0\x02\x01\x05\x12\
+    \x04\xab\x01\r\x13\n\x0f\n\x07\x04\x02\x03\0\x02\x01\x01\x12\x04\xab\x01\
+    \x14#\n\x0f\n\x07\x04\x02\x03\0\x02\x01\x03\x12\x04\xab\x01&'\n$\n\x06\
+    \x04\x02\x03\0\x02\x02\x12\x04\xae\x01\x04!\x1a\x14\x20The\x20file\x20co\
+    ntents.\n\n\x0f\n\x07\x04\x02\x03\0\x02\x02\x04\x12\x04\xae\x01\x04\x0c\
+    \n\x0f\n\x07\x04\x02\x03\0\x02\x02\x05\x12\x04\xae\x01\r\x13\n\x0f\n\x07\
+    \x04\x02\x03\0\x02\x02\x01\x12\x04\xae\x01\x14\x1b\n\x0f\n\x07\x04\x02\
+    \x03\0\x02\x02\x03\x12\x04\xae\x01\x1e\x20\n\xe1\x01\n\x06\x04\x02\x03\0\
+    \x02\x03\x12\x04\xb3\x01\x048\x1a\xd0\x01\x20Information\x20describing\
+    \x20the\x20file\x20content\x20being\x20inserted.\x20If\x20an\x20insertio\
+    n\n\x20point\x20is\x20used,\x20this\x20information\x20will\x20be\x20appr\
+    opriately\x20offset\x20and\x20inserted\n\x20into\x20the\x20code\x20gener\
+    ation\x20metadata\x20for\x20the\x20generated\x20files.\n\n\x0f\n\x07\x04\
+    \x02\x03\0\x02\x03\x04\x12\x04\xb3\x01\x04\x0c\n\x0f\n\x07\x04\x02\x03\0\
+    \x02\x03\x06\x12\x04\xb3\x01\r\x1e\n\x0f\n\x07\x04\x02\x03\0\x02\x03\x01\
+    \x12\x04\xb3\x01\x1f2\n\x0f\n\x07\x04\x02\x03\0\x02\x03\x03\x12\x04\xb3\
+    \x0157\n\x0c\n\x04\x04\x02\x02\x02\x12\x04\xb5\x01\x02\x1a\n\r\n\x05\x04\
+    \x02\x02\x02\x04\x12\x04\xb5\x01\x02\n\n\r\n\x05\x04\x02\x02\x02\x06\x12\
+    \x04\xb5\x01\x0b\x0f\n\r\n\x05\x04\x02\x02\x02\x01\x12\x04\xb5\x01\x10\
+    \x14\n\r\n\x05\x04\x02\x02\x02\x03\x12\x04\xb5\x01\x17\x19\
 ";
 
 static file_descriptor_proto_lazy: crate::rt::LazyV2<crate::descriptor::FileDescriptorProto> = crate::rt::LazyV2::INIT;