protoc 2.6.1.1 → 2.6.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/ext/protoc/Makefile.in +10 -13
- data/ext/protoc/extconf.rb +0 -1
- data/ext/protoc/protobuf/CHANGES.txt +593 -0
- data/ext/protoc/protobuf/CONTRIBUTORS.txt +93 -0
- data/ext/protoc/protobuf/INSTALL.txt +237 -0
- data/ext/protoc/protobuf/LICENSE +33 -0
- data/ext/protoc/protobuf/Makefile.am +267 -0
- data/ext/protoc/protobuf/README.md +167 -0
- data/ext/protoc/protobuf/autogen.sh +41 -0
- data/ext/protoc/protobuf/benchmarks/ProtoBench.java +203 -0
- data/ext/protoc/protobuf/benchmarks/google_message1.dat +0 -0
- data/ext/protoc/protobuf/benchmarks/google_message2.dat +0 -0
- data/ext/protoc/protobuf/benchmarks/google_size.proto +136 -0
- data/ext/protoc/protobuf/benchmarks/google_speed.proto +136 -0
- data/ext/protoc/protobuf/benchmarks/readme.txt +50 -0
- data/ext/protoc/protobuf/configure.ac +159 -0
- data/ext/protoc/protobuf/editors/README.txt +5 -0
- data/ext/protoc/protobuf/editors/proto.vim +105 -0
- data/ext/protoc/protobuf/editors/protobuf-mode.el +220 -0
- data/ext/protoc/protobuf/examples/AddPerson.java +95 -0
- data/ext/protoc/protobuf/examples/ListPeople.java +50 -0
- data/ext/protoc/protobuf/examples/Makefile +58 -0
- data/ext/protoc/protobuf/examples/README.txt +29 -0
- data/ext/protoc/protobuf/examples/add_person.cc +95 -0
- data/ext/protoc/protobuf/examples/add_person.py +58 -0
- data/ext/protoc/protobuf/examples/addressbook.proto +30 -0
- data/ext/protoc/protobuf/examples/list_people.cc +68 -0
- data/ext/protoc/protobuf/examples/list_people.py +38 -0
- data/ext/protoc/protobuf/generate_descriptor_proto.sh +33 -0
- data/ext/protoc/protobuf/java/README.txt +96 -0
- data/ext/protoc/protobuf/java/pom.xml +217 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/AbstractMessage.java +466 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/AbstractMessageLite.java +355 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/AbstractParser.java +253 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/BlockingRpcChannel.java +51 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/BlockingService.java +64 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/BoundedByteString.java +163 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ByteString.java +1022 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/CodedInputStream.java +1311 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/CodedOutputStream.java +1297 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Descriptors.java +2238 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/DynamicMessage.java +622 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Extension.java +96 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ExtensionRegistry.java +392 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ExtensionRegistryLite.java +185 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/FieldSet.java +907 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/GeneratedMessage.java +2213 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/GeneratedMessageLite.java +949 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Internal.java +391 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/InvalidProtocolBufferException.java +122 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LazyField.java +154 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LazyFieldLite.java +176 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LazyStringArrayList.java +367 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LazyStringList.java +163 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LiteralByteString.java +362 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Message.java +244 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/MessageLite.java +320 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/MessageLiteOrBuilder.java +60 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/MessageOrBuilder.java +143 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/MessageReflection.java +931 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Parser.java +261 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ProtocolMessageEnum.java +58 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ProtocolStringList.java +48 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RepeatedFieldBuilder.java +696 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RopeByteString.java +957 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RpcCallback.java +47 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RpcChannel.java +71 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RpcController.java +118 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RpcUtil.java +134 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Service.java +117 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ServiceException.java +52 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/SingleFieldBuilder.java +241 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/SmallSortedMap.java +618 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/TextFormat.java +1984 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/UninitializedMessageException.java +99 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/UnknownFieldSet.java +995 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/UnmodifiableLazyStringList.java +205 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Utf8.java +349 -0
- data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/WireFormat.java +163 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/AbstractMessageTest.java +527 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/BoundedByteStringTest.java +68 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/ByteStringTest.java +759 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/CheckUtf8Test.java +141 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/CodedInputStreamTest.java +769 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/CodedOutputStreamTest.java +401 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/DeprecatedFieldTest.java +80 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/DescriptorsTest.java +735 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/DynamicMessageTest.java +326 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/ForceFieldBuildersPreRun.java +48 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/GeneratedMessageTest.java +1515 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/IsValidUtf8Test.java +180 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/IsValidUtf8TestUtil.java +421 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyFieldLiteTest.java +134 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyFieldTest.java +121 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyMessageLiteTest.java +319 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyStringArrayListTest.java +174 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyStringEndToEndTest.java +143 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LiteEqualsAndHashTest.java +85 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LiteTest.java +148 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LiteralByteStringTest.java +396 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/MessageTest.java +353 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/NestedBuildersTest.java +185 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/ParserTest.java +381 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/RepeatedFieldBuilderTest.java +190 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/RopeByteStringSubstringTest.java +97 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/RopeByteStringTest.java +115 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/ServiceTest.java +320 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/SingleFieldBuilderTest.java +155 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/SmallSortedMapTest.java +420 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/TestBadIdentifiers.java +96 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/TestUtil.java +4124 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/TextFormatTest.java +994 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/UnknownFieldSetTest.java +653 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/UnmodifiableLazyStringListTest.java +227 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/WireFormatTest.java +606 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/lazy_fields_lite.proto +61 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/lite_equals_and_hash.proto +55 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/multiple_files_test.proto +77 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/nested_builders_test.proto +53 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/nested_extension.proto +46 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/nested_extension_lite.proto +48 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/non_nested_extension.proto +49 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/non_nested_extension_lite.proto +50 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/outer_class_name_test.proto +38 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/outer_class_name_test2.proto +42 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/outer_class_name_test3.proto +43 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_bad_identifiers.proto +157 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_check_utf8.proto +50 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_check_utf8_size.proto +51 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_custom_options.proto +43 -0
- data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_extra_interfaces.proto +60 -0
- data/ext/protoc/protobuf/m4/ac_system_extensions.m4 +37 -0
- data/ext/protoc/protobuf/m4/acx_check_suncc.m4 +75 -0
- data/ext/protoc/protobuf/m4/acx_pthread.m4 +397 -0
- data/ext/protoc/protobuf/m4/stl_hash.m4 +72 -0
- data/ext/protoc/protobuf/more_tests/Makefile +41 -0
- data/ext/protoc/protobuf/post_process_dist.sh +60 -0
- data/ext/protoc/protobuf/protobuf-lite.pc.in +13 -0
- data/ext/protoc/protobuf/protobuf.pc.in +14 -0
- data/ext/protoc/protobuf/python/README.txt +105 -0
- data/ext/protoc/protobuf/python/ez_setup.py +284 -0
- data/ext/protoc/protobuf/python/google/__init__.py +1 -0
- data/ext/protoc/protobuf/python/google/protobuf/__init__.py +0 -0
- data/ext/protoc/protobuf/python/google/protobuf/descriptor.py +849 -0
- data/ext/protoc/protobuf/python/google/protobuf/descriptor_database.py +137 -0
- data/ext/protoc/protobuf/python/google/protobuf/descriptor_pool.py +643 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/__init__.py +0 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/api_implementation.cc +139 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/api_implementation.py +89 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/api_implementation_default_test.py +63 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/containers.py +269 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/cpp_message.py +663 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/decoder.py +831 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_database_test.py +63 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_pool_test.py +564 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_pool_test1.proto +94 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_pool_test2.proto +70 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_python_test.py +54 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_test.py +669 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/encoder.py +788 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/enum_type_wrapper.py +89 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/factory_test1.proto +57 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/factory_test2.proto +92 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/generator_test.py +343 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/message_factory_python_test.py +54 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/message_factory_test.py +131 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/message_listener.py +78 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/message_python_test.py +54 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/message_test.py +681 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/missing_enum_values.proto +50 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/more_extensions.proto +58 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/more_extensions_dynamic.proto +49 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/more_messages.proto +51 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/python_message.py +1251 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/reflection_test.py +2934 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/service_reflection_test.py +136 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/symbol_database_test.py +120 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/test_bad_identifiers.proto +52 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/test_util.py +662 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/text_encoding_test.py +68 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/text_format_test.py +743 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/type_checkers.py +328 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/unknown_fields_test.py +231 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/wire_format.py +268 -0
- data/ext/protoc/protobuf/python/google/protobuf/internal/wire_format_test.py +253 -0
- data/ext/protoc/protobuf/python/google/protobuf/message.py +284 -0
- data/ext/protoc/protobuf/python/google/protobuf/message_factory.py +155 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/README +6 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/__init__.py +0 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/cpp_message.py +61 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/descriptor.cc +357 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/descriptor.h +96 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/descriptor_cpp2_test.py +58 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/extension_dict.cc +338 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/extension_dict.h +123 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/message.cc +2561 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/message.h +305 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/message_factory_cpp2_test.py +56 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/proto2_api_test.proto +38 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/python.proto +66 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/python_protobuf.h +57 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/reflection_cpp2_generated_test.py +94 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/repeated_composite_container.cc +763 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/repeated_composite_container.h +172 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/repeated_scalar_container.cc +825 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/repeated_scalar_container.h +112 -0
- data/ext/protoc/protobuf/python/google/protobuf/pyext/scoped_pyobject_ptr.h +95 -0
- data/ext/protoc/protobuf/python/google/protobuf/reflection.py +205 -0
- data/ext/protoc/protobuf/python/google/protobuf/service.py +226 -0
- data/ext/protoc/protobuf/python/google/protobuf/service_reflection.py +284 -0
- data/ext/protoc/protobuf/python/google/protobuf/symbol_database.py +185 -0
- data/ext/protoc/protobuf/python/google/protobuf/text_encoding.py +110 -0
- data/ext/protoc/protobuf/python/google/protobuf/text_format.py +873 -0
- data/ext/protoc/protobuf/python/mox.py +1401 -0
- data/ext/protoc/protobuf/python/setup.py +201 -0
- data/ext/protoc/protobuf/python/stubout.py +140 -0
- data/ext/protoc/protobuf/src/Makefile.am +418 -0
- data/ext/protoc/protobuf/src/google/protobuf/SEBS +240 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/code_generator.cc +84 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/code_generator.h +145 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/command_line_interface.cc +1603 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/command_line_interface.h +378 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/command_line_interface_unittest.cc +1654 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_bootstrap_unittest.cc +158 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_enum.cc +288 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_enum.h +103 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_enum_field.cc +431 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_enum_field.h +122 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_extension.cc +210 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_extension.h +86 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_field.cc +166 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_field.h +185 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_file.cc +665 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_file.h +99 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_generator.cc +125 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_generator.h +72 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_helpers.cc +494 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_helpers.h +206 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_message.cc +2645 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_message.h +175 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_message_field.cc +375 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_message_field.h +121 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_options.h +58 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_plugin_unittest.cc +123 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_primitive_field.cc +451 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_primitive_field.h +123 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_service.cc +334 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_service.h +118 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_string_field.cc +642 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_string_field.h +127 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_test_bad_identifiers.proto +132 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_unittest.cc +2074 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_unittest.h +51 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/importer.cc +480 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/importer.h +317 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/importer_unittest.cc +617 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_context.cc +195 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_context.h +95 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_doc_comment.cc +233 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_doc_comment.h +69 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_doc_comment_unittest.cc +67 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_enum.cc +333 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_enum.h +99 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_enum_field.cc +778 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_enum_field.h +158 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_extension.cc +207 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_extension.h +109 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_field.cc +213 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_field.h +162 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_file.cc +534 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_file.h +115 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_generator.cc +158 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_generator.h +72 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_generator_factory.cc +77 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_generator_factory.h +101 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_helpers.cc +737 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_helpers.h +322 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_lazy_message_field.cc +826 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_lazy_message_field.h +121 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_message.cc +1666 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_message.h +140 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_message_field.cc +1343 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_message_field.h +173 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_name_resolver.cc +266 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_name_resolver.h +124 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_plugin_unittest.cc +124 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_primitive_field.cc +877 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_primitive_field.h +160 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_service.cc +473 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_service.h +135 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_shared_code_generator.cc +201 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_shared_code_generator.h +90 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_string_field.cc +1056 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_string_field.h +160 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/main.cc +61 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/mock_code_generator.cc +240 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/mock_code_generator.h +117 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/package_info.h +64 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/parser.cc +1750 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/parser.h +522 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/parser_unittest.cc +2612 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.cc +163 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.h +72 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.pb.cc +1148 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.pb.h +897 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.proto +147 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/python/python_generator.cc +1262 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/python/python_generator.h +166 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/python/python_plugin_unittest.cc +118 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/subprocess.cc +463 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/subprocess.h +108 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/test_plugin.cc +51 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/zip_output_unittest.sh +91 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/zip_writer.cc +218 -0
- data/ext/protoc/protobuf/src/google/protobuf/compiler/zip_writer.h +93 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor.cc +5420 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor.h +1691 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor.pb.cc +9135 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor.pb.h +6761 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor.proto +687 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor_database.cc +543 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor_database.h +369 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor_database_unittest.cc +748 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor_pb2_test.py +54 -0
- data/ext/protoc/protobuf/src/google/protobuf/descriptor_unittest.cc +5501 -0
- data/ext/protoc/protobuf/src/google/protobuf/dynamic_message.cc +764 -0
- data/ext/protoc/protobuf/src/google/protobuf/dynamic_message.h +148 -0
- data/ext/protoc/protobuf/src/google/protobuf/dynamic_message_unittest.cc +230 -0
- data/ext/protoc/protobuf/src/google/protobuf/extension_set.cc +1663 -0
- data/ext/protoc/protobuf/src/google/protobuf/extension_set.h +1234 -0
- data/ext/protoc/protobuf/src/google/protobuf/extension_set_heavy.cc +734 -0
- data/ext/protoc/protobuf/src/google/protobuf/extension_set_unittest.cc +1095 -0
- data/ext/protoc/protobuf/src/google/protobuf/generated_enum_reflection.h +91 -0
- data/ext/protoc/protobuf/src/google/protobuf/generated_message_reflection.cc +1683 -0
- data/ext/protoc/protobuf/src/google/protobuf/generated_message_reflection.h +504 -0
- data/ext/protoc/protobuf/src/google/protobuf/generated_message_reflection_unittest.cc +795 -0
- data/ext/protoc/protobuf/src/google/protobuf/generated_message_util.cc +65 -0
- data/ext/protoc/protobuf/src/google/protobuf/generated_message_util.h +113 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/coded_stream.cc +914 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/coded_stream.h +1220 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/coded_stream_inl.h +69 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/coded_stream_unittest.cc +1378 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/gzip_stream.cc +326 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/gzip_stream.h +209 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/gzip_stream_unittest.sh +44 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/package_info.h +54 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/printer.cc +198 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/printer.h +136 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/printer_unittest.cc +285 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/strtod.cc +113 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/strtod.h +50 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/tokenizer.cc +1127 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/tokenizer.h +402 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/tokenizer_unittest.cc +999 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream.cc +57 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream.h +248 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_impl.cc +473 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_impl.h +358 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_impl_lite.cc +405 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_impl_lite.h +354 -0
- data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_unittest.cc +965 -0
- data/ext/protoc/protobuf/src/google/protobuf/lite_unittest.cc +350 -0
- data/ext/protoc/protobuf/src/google/protobuf/message.cc +358 -0
- data/ext/protoc/protobuf/src/google/protobuf/message.h +866 -0
- data/ext/protoc/protobuf/src/google/protobuf/message_lite.cc +335 -0
- data/ext/protoc/protobuf/src/google/protobuf/message_lite.h +247 -0
- data/ext/protoc/protobuf/src/google/protobuf/message_unittest.cc +427 -0
- data/ext/protoc/protobuf/src/google/protobuf/package_info.h +64 -0
- data/ext/protoc/protobuf/src/google/protobuf/reflection_ops.cc +269 -0
- data/ext/protoc/protobuf/src/google/protobuf/reflection_ops.h +81 -0
- data/ext/protoc/protobuf/src/google/protobuf/reflection_ops_unittest.cc +475 -0
- data/ext/protoc/protobuf/src/google/protobuf/repeated_field.cc +87 -0
- data/ext/protoc/protobuf/src/google/protobuf/repeated_field.h +1603 -0
- data/ext/protoc/protobuf/src/google/protobuf/repeated_field_reflection_unittest.cc +195 -0
- data/ext/protoc/protobuf/src/google/protobuf/repeated_field_unittest.cc +1442 -0
- data/ext/protoc/protobuf/src/google/protobuf/service.cc +46 -0
- data/ext/protoc/protobuf/src/google/protobuf/service.h +291 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops.h +227 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_arm64_gcc.h +325 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_arm_gcc.h +151 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_arm_qnx.h +146 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_atomicword_compat.h +122 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_generic_gcc.h +137 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_macosx.h +225 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_mips_gcc.h +313 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_pnacl.h +73 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_solaris.h +188 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_tsan.h +219 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_x86_gcc.cc +137 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_x86_gcc.h +293 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_x86_msvc.cc +112 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_x86_msvc.h +150 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/common.cc +395 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/common.h +1226 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/common_unittest.cc +357 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/hash.h +232 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/map_util.h +771 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/once.cc +99 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/once.h +166 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/once_unittest.cc +253 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/platform_macros.h +103 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/shared_ptr.h +470 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/stl_util.h +121 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/stringprintf.cc +175 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/stringprintf.h +76 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/stringprintf_unittest.cc +152 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/structurally_valid.cc +536 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/structurally_valid_unittest.cc +40 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/strutil.cc +1279 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/strutil.h +562 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/strutil_unittest.cc +73 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/substitute.cc +134 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/substitute.h +170 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/template_util.h +138 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/template_util_unittest.cc +130 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/type_traits.h +336 -0
- data/ext/protoc/protobuf/src/google/protobuf/stubs/type_traits_unittest.cc +628 -0
- data/ext/protoc/protobuf/src/google/protobuf/test_util.cc +3345 -0
- data/ext/protoc/protobuf/src/google/protobuf/test_util.h +215 -0
- data/ext/protoc/protobuf/src/google/protobuf/test_util_lite.cc +1585 -0
- data/ext/protoc/protobuf/src/google/protobuf/test_util_lite.h +101 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/bad_utf8_string +1 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/golden_message +0 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/golden_message_oneof_implemented +0 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/golden_packed_fields_message +0 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_data.txt +134 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_data_oneof_implemented.txt +129 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_data_pointy.txt +134 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_data_pointy_oneof.txt +129 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_extensions_data.txt +134 -0
- data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_extensions_data_pointy.txt +134 -0
- data/ext/protoc/protobuf/src/google/protobuf/testing/file.cc +194 -0
- data/ext/protoc/protobuf/src/google/protobuf/testing/file.h +97 -0
- data/ext/protoc/protobuf/src/google/protobuf/testing/googletest.cc +255 -0
- data/ext/protoc/protobuf/src/google/protobuf/testing/googletest.h +102 -0
- data/ext/protoc/protobuf/src/google/protobuf/testing/zcgunzip.cc +73 -0
- data/ext/protoc/protobuf/src/google/protobuf/testing/zcgzip.cc +79 -0
- data/ext/protoc/protobuf/src/google/protobuf/text_format.cc +1746 -0
- data/ext/protoc/protobuf/src/google/protobuf/text_format.h +473 -0
- data/ext/protoc/protobuf/src/google/protobuf/text_format_unittest.cc +1479 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest.proto +861 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_custom_options.proto +393 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_embed_optimize_for.proto +50 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_empty.proto +37 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_enormous_descriptor.proto +1046 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_import.proto +64 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_import_lite.proto +51 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_import_public.proto +40 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_import_public_lite.proto +42 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_lite.proto +384 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_lite_imports_nonlite.proto +43 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_mset.proto +83 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_no_generic_services.proto +53 -0
- data/ext/protoc/protobuf/src/google/protobuf/unittest_optimize_for.proto +66 -0
- data/ext/protoc/protobuf/src/google/protobuf/unknown_field_set.cc +265 -0
- data/ext/protoc/protobuf/src/google/protobuf/unknown_field_set.h +318 -0
- data/ext/protoc/protobuf/src/google/protobuf/unknown_field_set_unittest.cc +599 -0
- data/ext/protoc/protobuf/src/google/protobuf/wire_format.cc +1101 -0
- data/ext/protoc/protobuf/src/google/protobuf/wire_format.h +336 -0
- data/ext/protoc/protobuf/src/google/protobuf/wire_format_lite.cc +471 -0
- data/ext/protoc/protobuf/src/google/protobuf/wire_format_lite.h +661 -0
- data/ext/protoc/protobuf/src/google/protobuf/wire_format_lite_inl.h +860 -0
- data/ext/protoc/protobuf/src/google/protobuf/wire_format_unittest.cc +1120 -0
- data/ext/protoc/protobuf/src/solaris/libstdc++.la +51 -0
- data/ext/protoc/protobuf/vsprojects/config.h +29 -0
- data/ext/protoc/protobuf/vsprojects/convert2008to2005.sh +20 -0
- data/ext/protoc/protobuf/vsprojects/extract_includes.bat +50 -0
- data/ext/protoc/protobuf/vsprojects/libprotobuf-lite.vcproj +302 -0
- data/ext/protoc/protobuf/vsprojects/libprotobuf.vcproj +470 -0
- data/ext/protoc/protobuf/vsprojects/libprotoc.vcproj +466 -0
- data/ext/protoc/protobuf/vsprojects/lite-test.vcproj +305 -0
- data/ext/protoc/protobuf/vsprojects/protobuf.sln +92 -0
- data/ext/protoc/protobuf/vsprojects/protoc.vcproj +192 -0
- data/ext/protoc/protobuf/vsprojects/readme.txt +114 -0
- data/ext/protoc/protobuf/vsprojects/test_plugin.vcproj +209 -0
- data/ext/protoc/protobuf/vsprojects/tests.vcproj +681 -0
- data/lib/protoc/version.rb +1 -1
- metadata +480 -3
|
@@ -0,0 +1,663 @@
|
|
|
1
|
+
# Protocol Buffers - Google's data interchange format
|
|
2
|
+
# Copyright 2008 Google Inc. All rights reserved.
|
|
3
|
+
# https://developers.google.com/protocol-buffers/
|
|
4
|
+
#
|
|
5
|
+
# Redistribution and use in source and binary forms, with or without
|
|
6
|
+
# modification, are permitted provided that the following conditions are
|
|
7
|
+
# met:
|
|
8
|
+
#
|
|
9
|
+
# * Redistributions of source code must retain the above copyright
|
|
10
|
+
# notice, this list of conditions and the following disclaimer.
|
|
11
|
+
# * Redistributions in binary form must reproduce the above
|
|
12
|
+
# copyright notice, this list of conditions and the following disclaimer
|
|
13
|
+
# in the documentation and/or other materials provided with the
|
|
14
|
+
# distribution.
|
|
15
|
+
# * Neither the name of Google Inc. nor the names of its
|
|
16
|
+
# contributors may be used to endorse or promote products derived from
|
|
17
|
+
# this software without specific prior written permission.
|
|
18
|
+
#
|
|
19
|
+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
20
|
+
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
21
|
+
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
22
|
+
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
23
|
+
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
24
|
+
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
25
|
+
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
26
|
+
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
27
|
+
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
28
|
+
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
29
|
+
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
30
|
+
|
|
31
|
+
"""Contains helper functions used to create protocol message classes from
|
|
32
|
+
Descriptor objects at runtime backed by the protocol buffer C++ API.
|
|
33
|
+
"""
|
|
34
|
+
|
|
35
|
+
__author__ = 'petar@google.com (Petar Petrov)'
|
|
36
|
+
|
|
37
|
+
import copy_reg
|
|
38
|
+
import operator
|
|
39
|
+
from google.protobuf.internal import _net_proto2___python
|
|
40
|
+
from google.protobuf.internal import enum_type_wrapper
|
|
41
|
+
from google.protobuf import message
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
_LABEL_REPEATED = _net_proto2___python.LABEL_REPEATED
|
|
45
|
+
_LABEL_OPTIONAL = _net_proto2___python.LABEL_OPTIONAL
|
|
46
|
+
_CPPTYPE_MESSAGE = _net_proto2___python.CPPTYPE_MESSAGE
|
|
47
|
+
_TYPE_MESSAGE = _net_proto2___python.TYPE_MESSAGE
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
def GetDescriptorPool():
|
|
51
|
+
"""Creates a new DescriptorPool C++ object."""
|
|
52
|
+
return _net_proto2___python.NewCDescriptorPool()
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
_pool = GetDescriptorPool()
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
def GetFieldDescriptor(full_field_name):
|
|
59
|
+
"""Searches for a field descriptor given a full field name."""
|
|
60
|
+
return _pool.FindFieldByName(full_field_name)
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
def BuildFile(content):
|
|
64
|
+
"""Registers a new proto file in the underlying C++ descriptor pool."""
|
|
65
|
+
_net_proto2___python.BuildFile(content)
|
|
66
|
+
|
|
67
|
+
|
|
68
|
+
def GetExtensionDescriptor(full_extension_name):
|
|
69
|
+
"""Searches for extension descriptor given a full field name."""
|
|
70
|
+
return _pool.FindExtensionByName(full_extension_name)
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
def NewCMessage(full_message_name):
|
|
74
|
+
"""Creates a new C++ protocol message by its name."""
|
|
75
|
+
return _net_proto2___python.NewCMessage(full_message_name)
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
def ScalarProperty(cdescriptor):
|
|
79
|
+
"""Returns a scalar property for the given descriptor."""
|
|
80
|
+
|
|
81
|
+
def Getter(self):
|
|
82
|
+
return self._cmsg.GetScalar(cdescriptor)
|
|
83
|
+
|
|
84
|
+
def Setter(self, value):
|
|
85
|
+
self._cmsg.SetScalar(cdescriptor, value)
|
|
86
|
+
|
|
87
|
+
return property(Getter, Setter)
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
def CompositeProperty(cdescriptor, message_type):
|
|
91
|
+
"""Returns a Python property the given composite field."""
|
|
92
|
+
|
|
93
|
+
def Getter(self):
|
|
94
|
+
sub_message = self._composite_fields.get(cdescriptor.name, None)
|
|
95
|
+
if sub_message is None:
|
|
96
|
+
cmessage = self._cmsg.NewSubMessage(cdescriptor)
|
|
97
|
+
sub_message = message_type._concrete_class(__cmessage=cmessage)
|
|
98
|
+
self._composite_fields[cdescriptor.name] = sub_message
|
|
99
|
+
return sub_message
|
|
100
|
+
|
|
101
|
+
return property(Getter)
|
|
102
|
+
|
|
103
|
+
|
|
104
|
+
class RepeatedScalarContainer(object):
|
|
105
|
+
"""Container for repeated scalar fields."""
|
|
106
|
+
|
|
107
|
+
__slots__ = ['_message', '_cfield_descriptor', '_cmsg']
|
|
108
|
+
|
|
109
|
+
def __init__(self, msg, cfield_descriptor):
|
|
110
|
+
self._message = msg
|
|
111
|
+
self._cmsg = msg._cmsg
|
|
112
|
+
self._cfield_descriptor = cfield_descriptor
|
|
113
|
+
|
|
114
|
+
def append(self, value):
|
|
115
|
+
self._cmsg.AddRepeatedScalar(
|
|
116
|
+
self._cfield_descriptor, value)
|
|
117
|
+
|
|
118
|
+
def extend(self, sequence):
|
|
119
|
+
for element in sequence:
|
|
120
|
+
self.append(element)
|
|
121
|
+
|
|
122
|
+
def insert(self, key, value):
|
|
123
|
+
values = self[slice(None, None, None)]
|
|
124
|
+
values.insert(key, value)
|
|
125
|
+
self._cmsg.AssignRepeatedScalar(self._cfield_descriptor, values)
|
|
126
|
+
|
|
127
|
+
def remove(self, value):
|
|
128
|
+
values = self[slice(None, None, None)]
|
|
129
|
+
values.remove(value)
|
|
130
|
+
self._cmsg.AssignRepeatedScalar(self._cfield_descriptor, values)
|
|
131
|
+
|
|
132
|
+
def __setitem__(self, key, value):
|
|
133
|
+
values = self[slice(None, None, None)]
|
|
134
|
+
values[key] = value
|
|
135
|
+
self._cmsg.AssignRepeatedScalar(self._cfield_descriptor, values)
|
|
136
|
+
|
|
137
|
+
def __getitem__(self, key):
|
|
138
|
+
return self._cmsg.GetRepeatedScalar(self._cfield_descriptor, key)
|
|
139
|
+
|
|
140
|
+
def __delitem__(self, key):
|
|
141
|
+
self._cmsg.DeleteRepeatedField(self._cfield_descriptor, key)
|
|
142
|
+
|
|
143
|
+
def __len__(self):
|
|
144
|
+
return len(self[slice(None, None, None)])
|
|
145
|
+
|
|
146
|
+
def __eq__(self, other):
|
|
147
|
+
if self is other:
|
|
148
|
+
return True
|
|
149
|
+
if not operator.isSequenceType(other):
|
|
150
|
+
raise TypeError(
|
|
151
|
+
'Can only compare repeated scalar fields against sequences.')
|
|
152
|
+
# We are presumably comparing against some other sequence type.
|
|
153
|
+
return other == self[slice(None, None, None)]
|
|
154
|
+
|
|
155
|
+
def __ne__(self, other):
|
|
156
|
+
return not self == other
|
|
157
|
+
|
|
158
|
+
def __hash__(self):
|
|
159
|
+
raise TypeError('unhashable object')
|
|
160
|
+
|
|
161
|
+
def sort(self, *args, **kwargs):
|
|
162
|
+
# Maintain compatibility with the previous interface.
|
|
163
|
+
if 'sort_function' in kwargs:
|
|
164
|
+
kwargs['cmp'] = kwargs.pop('sort_function')
|
|
165
|
+
self._cmsg.AssignRepeatedScalar(self._cfield_descriptor,
|
|
166
|
+
sorted(self, *args, **kwargs))
|
|
167
|
+
|
|
168
|
+
|
|
169
|
+
def RepeatedScalarProperty(cdescriptor):
|
|
170
|
+
"""Returns a Python property the given repeated scalar field."""
|
|
171
|
+
|
|
172
|
+
def Getter(self):
|
|
173
|
+
container = self._composite_fields.get(cdescriptor.name, None)
|
|
174
|
+
if container is None:
|
|
175
|
+
container = RepeatedScalarContainer(self, cdescriptor)
|
|
176
|
+
self._composite_fields[cdescriptor.name] = container
|
|
177
|
+
return container
|
|
178
|
+
|
|
179
|
+
def Setter(self, new_value):
|
|
180
|
+
raise AttributeError('Assignment not allowed to repeated field '
|
|
181
|
+
'"%s" in protocol message object.' % cdescriptor.name)
|
|
182
|
+
|
|
183
|
+
doc = 'Magic attribute generated for "%s" proto field.' % cdescriptor.name
|
|
184
|
+
return property(Getter, Setter, doc=doc)
|
|
185
|
+
|
|
186
|
+
|
|
187
|
+
class RepeatedCompositeContainer(object):
|
|
188
|
+
"""Container for repeated composite fields."""
|
|
189
|
+
|
|
190
|
+
__slots__ = ['_message', '_subclass', '_cfield_descriptor', '_cmsg']
|
|
191
|
+
|
|
192
|
+
def __init__(self, msg, cfield_descriptor, subclass):
|
|
193
|
+
self._message = msg
|
|
194
|
+
self._cmsg = msg._cmsg
|
|
195
|
+
self._subclass = subclass
|
|
196
|
+
self._cfield_descriptor = cfield_descriptor
|
|
197
|
+
|
|
198
|
+
def add(self, **kwargs):
|
|
199
|
+
cmessage = self._cmsg.AddMessage(self._cfield_descriptor)
|
|
200
|
+
return self._subclass(__cmessage=cmessage, __owner=self._message, **kwargs)
|
|
201
|
+
|
|
202
|
+
def extend(self, elem_seq):
|
|
203
|
+
"""Extends by appending the given sequence of elements of the same type
|
|
204
|
+
as this one, copying each individual message.
|
|
205
|
+
"""
|
|
206
|
+
for message in elem_seq:
|
|
207
|
+
self.add().MergeFrom(message)
|
|
208
|
+
|
|
209
|
+
def remove(self, value):
|
|
210
|
+
# TODO(protocol-devel): This is inefficient as it needs to generate a
|
|
211
|
+
# message pointer for each message only to do index(). Move this to a C++
|
|
212
|
+
# extension function.
|
|
213
|
+
self.__delitem__(self[slice(None, None, None)].index(value))
|
|
214
|
+
|
|
215
|
+
def MergeFrom(self, other):
|
|
216
|
+
for message in other[:]:
|
|
217
|
+
self.add().MergeFrom(message)
|
|
218
|
+
|
|
219
|
+
def __getitem__(self, key):
|
|
220
|
+
cmessages = self._cmsg.GetRepeatedMessage(
|
|
221
|
+
self._cfield_descriptor, key)
|
|
222
|
+
subclass = self._subclass
|
|
223
|
+
if not isinstance(cmessages, list):
|
|
224
|
+
return subclass(__cmessage=cmessages, __owner=self._message)
|
|
225
|
+
|
|
226
|
+
return [subclass(__cmessage=m, __owner=self._message) for m in cmessages]
|
|
227
|
+
|
|
228
|
+
def __delitem__(self, key):
|
|
229
|
+
self._cmsg.DeleteRepeatedField(
|
|
230
|
+
self._cfield_descriptor, key)
|
|
231
|
+
|
|
232
|
+
def __len__(self):
|
|
233
|
+
return self._cmsg.FieldLength(self._cfield_descriptor)
|
|
234
|
+
|
|
235
|
+
def __eq__(self, other):
|
|
236
|
+
"""Compares the current instance with another one."""
|
|
237
|
+
if self is other:
|
|
238
|
+
return True
|
|
239
|
+
if not isinstance(other, self.__class__):
|
|
240
|
+
raise TypeError('Can only compare repeated composite fields against '
|
|
241
|
+
'other repeated composite fields.')
|
|
242
|
+
messages = self[slice(None, None, None)]
|
|
243
|
+
other_messages = other[slice(None, None, None)]
|
|
244
|
+
return messages == other_messages
|
|
245
|
+
|
|
246
|
+
def __hash__(self):
|
|
247
|
+
raise TypeError('unhashable object')
|
|
248
|
+
|
|
249
|
+
def sort(self, cmp=None, key=None, reverse=False, **kwargs):
|
|
250
|
+
# Maintain compatibility with the old interface.
|
|
251
|
+
if cmp is None and 'sort_function' in kwargs:
|
|
252
|
+
cmp = kwargs.pop('sort_function')
|
|
253
|
+
|
|
254
|
+
# The cmp function, if provided, is passed the results of the key function,
|
|
255
|
+
# so we only need to wrap one of them.
|
|
256
|
+
if key is None:
|
|
257
|
+
index_key = self.__getitem__
|
|
258
|
+
else:
|
|
259
|
+
index_key = lambda i: key(self[i])
|
|
260
|
+
|
|
261
|
+
# Sort the list of current indexes by the underlying object.
|
|
262
|
+
indexes = range(len(self))
|
|
263
|
+
indexes.sort(cmp=cmp, key=index_key, reverse=reverse)
|
|
264
|
+
|
|
265
|
+
# Apply the transposition.
|
|
266
|
+
for dest, src in enumerate(indexes):
|
|
267
|
+
if dest == src:
|
|
268
|
+
continue
|
|
269
|
+
self._cmsg.SwapRepeatedFieldElements(self._cfield_descriptor, dest, src)
|
|
270
|
+
# Don't swap the same value twice.
|
|
271
|
+
indexes[src] = src
|
|
272
|
+
|
|
273
|
+
|
|
274
|
+
def RepeatedCompositeProperty(cdescriptor, message_type):
|
|
275
|
+
"""Returns a Python property for the given repeated composite field."""
|
|
276
|
+
|
|
277
|
+
def Getter(self):
|
|
278
|
+
container = self._composite_fields.get(cdescriptor.name, None)
|
|
279
|
+
if container is None:
|
|
280
|
+
container = RepeatedCompositeContainer(
|
|
281
|
+
self, cdescriptor, message_type._concrete_class)
|
|
282
|
+
self._composite_fields[cdescriptor.name] = container
|
|
283
|
+
return container
|
|
284
|
+
|
|
285
|
+
def Setter(self, new_value):
|
|
286
|
+
raise AttributeError('Assignment not allowed to repeated field '
|
|
287
|
+
'"%s" in protocol message object.' % cdescriptor.name)
|
|
288
|
+
|
|
289
|
+
doc = 'Magic attribute generated for "%s" proto field.' % cdescriptor.name
|
|
290
|
+
return property(Getter, Setter, doc=doc)
|
|
291
|
+
|
|
292
|
+
|
|
293
|
+
class ExtensionDict(object):
|
|
294
|
+
"""Extension dictionary added to each protocol message."""
|
|
295
|
+
|
|
296
|
+
def __init__(self, msg):
|
|
297
|
+
self._message = msg
|
|
298
|
+
self._cmsg = msg._cmsg
|
|
299
|
+
self._values = {}
|
|
300
|
+
|
|
301
|
+
def __setitem__(self, extension, value):
|
|
302
|
+
from google.protobuf import descriptor
|
|
303
|
+
if not isinstance(extension, descriptor.FieldDescriptor):
|
|
304
|
+
raise KeyError('Bad extension %r.' % (extension,))
|
|
305
|
+
cdescriptor = extension._cdescriptor
|
|
306
|
+
if (cdescriptor.label != _LABEL_OPTIONAL or
|
|
307
|
+
cdescriptor.cpp_type == _CPPTYPE_MESSAGE):
|
|
308
|
+
raise TypeError('Extension %r is repeated and/or a composite type.' % (
|
|
309
|
+
extension.full_name,))
|
|
310
|
+
self._cmsg.SetScalar(cdescriptor, value)
|
|
311
|
+
self._values[extension] = value
|
|
312
|
+
|
|
313
|
+
def __getitem__(self, extension):
|
|
314
|
+
from google.protobuf import descriptor
|
|
315
|
+
if not isinstance(extension, descriptor.FieldDescriptor):
|
|
316
|
+
raise KeyError('Bad extension %r.' % (extension,))
|
|
317
|
+
|
|
318
|
+
cdescriptor = extension._cdescriptor
|
|
319
|
+
if (cdescriptor.label != _LABEL_REPEATED and
|
|
320
|
+
cdescriptor.cpp_type != _CPPTYPE_MESSAGE):
|
|
321
|
+
return self._cmsg.GetScalar(cdescriptor)
|
|
322
|
+
|
|
323
|
+
ext = self._values.get(extension, None)
|
|
324
|
+
if ext is not None:
|
|
325
|
+
return ext
|
|
326
|
+
|
|
327
|
+
ext = self._CreateNewHandle(extension)
|
|
328
|
+
self._values[extension] = ext
|
|
329
|
+
return ext
|
|
330
|
+
|
|
331
|
+
def ClearExtension(self, extension):
|
|
332
|
+
from google.protobuf import descriptor
|
|
333
|
+
if not isinstance(extension, descriptor.FieldDescriptor):
|
|
334
|
+
raise KeyError('Bad extension %r.' % (extension,))
|
|
335
|
+
self._cmsg.ClearFieldByDescriptor(extension._cdescriptor)
|
|
336
|
+
if extension in self._values:
|
|
337
|
+
del self._values[extension]
|
|
338
|
+
|
|
339
|
+
def HasExtension(self, extension):
|
|
340
|
+
from google.protobuf import descriptor
|
|
341
|
+
if not isinstance(extension, descriptor.FieldDescriptor):
|
|
342
|
+
raise KeyError('Bad extension %r.' % (extension,))
|
|
343
|
+
return self._cmsg.HasFieldByDescriptor(extension._cdescriptor)
|
|
344
|
+
|
|
345
|
+
def _FindExtensionByName(self, name):
|
|
346
|
+
"""Tries to find a known extension with the specified name.
|
|
347
|
+
|
|
348
|
+
Args:
|
|
349
|
+
name: Extension full name.
|
|
350
|
+
|
|
351
|
+
Returns:
|
|
352
|
+
Extension field descriptor.
|
|
353
|
+
"""
|
|
354
|
+
return self._message._extensions_by_name.get(name, None)
|
|
355
|
+
|
|
356
|
+
def _CreateNewHandle(self, extension):
|
|
357
|
+
cdescriptor = extension._cdescriptor
|
|
358
|
+
if (cdescriptor.label != _LABEL_REPEATED and
|
|
359
|
+
cdescriptor.cpp_type == _CPPTYPE_MESSAGE):
|
|
360
|
+
cmessage = self._cmsg.NewSubMessage(cdescriptor)
|
|
361
|
+
return extension.message_type._concrete_class(__cmessage=cmessage)
|
|
362
|
+
|
|
363
|
+
if cdescriptor.label == _LABEL_REPEATED:
|
|
364
|
+
if cdescriptor.cpp_type == _CPPTYPE_MESSAGE:
|
|
365
|
+
return RepeatedCompositeContainer(
|
|
366
|
+
self._message, cdescriptor, extension.message_type._concrete_class)
|
|
367
|
+
else:
|
|
368
|
+
return RepeatedScalarContainer(self._message, cdescriptor)
|
|
369
|
+
# This shouldn't happen!
|
|
370
|
+
assert False
|
|
371
|
+
return None
|
|
372
|
+
|
|
373
|
+
|
|
374
|
+
def NewMessage(bases, message_descriptor, dictionary):
|
|
375
|
+
"""Creates a new protocol message *class*."""
|
|
376
|
+
_AddClassAttributesForNestedExtensions(message_descriptor, dictionary)
|
|
377
|
+
_AddEnumValues(message_descriptor, dictionary)
|
|
378
|
+
_AddDescriptors(message_descriptor, dictionary)
|
|
379
|
+
return bases
|
|
380
|
+
|
|
381
|
+
|
|
382
|
+
def InitMessage(message_descriptor, cls):
|
|
383
|
+
"""Constructs a new message instance (called before instance's __init__)."""
|
|
384
|
+
cls._extensions_by_name = {}
|
|
385
|
+
_AddInitMethod(message_descriptor, cls)
|
|
386
|
+
_AddMessageMethods(message_descriptor, cls)
|
|
387
|
+
_AddPropertiesForExtensions(message_descriptor, cls)
|
|
388
|
+
copy_reg.pickle(cls, lambda obj: (cls, (), obj.__getstate__()))
|
|
389
|
+
|
|
390
|
+
|
|
391
|
+
def _AddDescriptors(message_descriptor, dictionary):
|
|
392
|
+
"""Sets up a new protocol message class dictionary.
|
|
393
|
+
|
|
394
|
+
Args:
|
|
395
|
+
message_descriptor: A Descriptor instance describing this message type.
|
|
396
|
+
dictionary: Class dictionary to which we'll add a '__slots__' entry.
|
|
397
|
+
"""
|
|
398
|
+
dictionary['__descriptors'] = {}
|
|
399
|
+
for field in message_descriptor.fields:
|
|
400
|
+
dictionary['__descriptors'][field.name] = GetFieldDescriptor(
|
|
401
|
+
field.full_name)
|
|
402
|
+
|
|
403
|
+
dictionary['__slots__'] = list(dictionary['__descriptors'].iterkeys()) + [
|
|
404
|
+
'_cmsg', '_owner', '_composite_fields', 'Extensions', '_HACK_REFCOUNTS']
|
|
405
|
+
|
|
406
|
+
|
|
407
|
+
def _AddEnumValues(message_descriptor, dictionary):
|
|
408
|
+
"""Sets class-level attributes for all enum fields defined in this message.
|
|
409
|
+
|
|
410
|
+
Args:
|
|
411
|
+
message_descriptor: Descriptor object for this message type.
|
|
412
|
+
dictionary: Class dictionary that should be populated.
|
|
413
|
+
"""
|
|
414
|
+
for enum_type in message_descriptor.enum_types:
|
|
415
|
+
dictionary[enum_type.name] = enum_type_wrapper.EnumTypeWrapper(enum_type)
|
|
416
|
+
for enum_value in enum_type.values:
|
|
417
|
+
dictionary[enum_value.name] = enum_value.number
|
|
418
|
+
|
|
419
|
+
|
|
420
|
+
def _AddClassAttributesForNestedExtensions(message_descriptor, dictionary):
|
|
421
|
+
"""Adds class attributes for the nested extensions."""
|
|
422
|
+
extension_dict = message_descriptor.extensions_by_name
|
|
423
|
+
for extension_name, extension_field in extension_dict.iteritems():
|
|
424
|
+
assert extension_name not in dictionary
|
|
425
|
+
dictionary[extension_name] = extension_field
|
|
426
|
+
|
|
427
|
+
|
|
428
|
+
def _AddInitMethod(message_descriptor, cls):
|
|
429
|
+
"""Adds an __init__ method to cls."""
|
|
430
|
+
|
|
431
|
+
# Create and attach message field properties to the message class.
|
|
432
|
+
# This can be done just once per message class, since property setters and
|
|
433
|
+
# getters are passed the message instance.
|
|
434
|
+
# This makes message instantiation extremely fast, and at the same time it
|
|
435
|
+
# doesn't require the creation of property objects for each message instance,
|
|
436
|
+
# which saves a lot of memory.
|
|
437
|
+
for field in message_descriptor.fields:
|
|
438
|
+
field_cdescriptor = cls.__descriptors[field.name]
|
|
439
|
+
if field.label == _LABEL_REPEATED:
|
|
440
|
+
if field.cpp_type == _CPPTYPE_MESSAGE:
|
|
441
|
+
value = RepeatedCompositeProperty(field_cdescriptor, field.message_type)
|
|
442
|
+
else:
|
|
443
|
+
value = RepeatedScalarProperty(field_cdescriptor)
|
|
444
|
+
elif field.cpp_type == _CPPTYPE_MESSAGE:
|
|
445
|
+
value = CompositeProperty(field_cdescriptor, field.message_type)
|
|
446
|
+
else:
|
|
447
|
+
value = ScalarProperty(field_cdescriptor)
|
|
448
|
+
setattr(cls, field.name, value)
|
|
449
|
+
|
|
450
|
+
# Attach a constant with the field number.
|
|
451
|
+
constant_name = field.name.upper() + '_FIELD_NUMBER'
|
|
452
|
+
setattr(cls, constant_name, field.number)
|
|
453
|
+
|
|
454
|
+
def Init(self, **kwargs):
|
|
455
|
+
"""Message constructor."""
|
|
456
|
+
cmessage = kwargs.pop('__cmessage', None)
|
|
457
|
+
if cmessage:
|
|
458
|
+
self._cmsg = cmessage
|
|
459
|
+
else:
|
|
460
|
+
self._cmsg = NewCMessage(message_descriptor.full_name)
|
|
461
|
+
|
|
462
|
+
# Keep a reference to the owner, as the owner keeps a reference to the
|
|
463
|
+
# underlying protocol buffer message.
|
|
464
|
+
owner = kwargs.pop('__owner', None)
|
|
465
|
+
if owner:
|
|
466
|
+
self._owner = owner
|
|
467
|
+
|
|
468
|
+
if message_descriptor.is_extendable:
|
|
469
|
+
self.Extensions = ExtensionDict(self)
|
|
470
|
+
else:
|
|
471
|
+
# Reference counting in the C++ code is broken and depends on
|
|
472
|
+
# the Extensions reference to keep this object alive during unit
|
|
473
|
+
# tests (see b/4856052). Remove this once b/4945904 is fixed.
|
|
474
|
+
self._HACK_REFCOUNTS = self
|
|
475
|
+
self._composite_fields = {}
|
|
476
|
+
|
|
477
|
+
for field_name, field_value in kwargs.iteritems():
|
|
478
|
+
field_cdescriptor = self.__descriptors.get(field_name, None)
|
|
479
|
+
if not field_cdescriptor:
|
|
480
|
+
raise ValueError('Protocol message has no "%s" field.' % field_name)
|
|
481
|
+
if field_cdescriptor.label == _LABEL_REPEATED:
|
|
482
|
+
if field_cdescriptor.cpp_type == _CPPTYPE_MESSAGE:
|
|
483
|
+
field_name = getattr(self, field_name)
|
|
484
|
+
for val in field_value:
|
|
485
|
+
field_name.add().MergeFrom(val)
|
|
486
|
+
else:
|
|
487
|
+
getattr(self, field_name).extend(field_value)
|
|
488
|
+
elif field_cdescriptor.cpp_type == _CPPTYPE_MESSAGE:
|
|
489
|
+
getattr(self, field_name).MergeFrom(field_value)
|
|
490
|
+
else:
|
|
491
|
+
setattr(self, field_name, field_value)
|
|
492
|
+
|
|
493
|
+
Init.__module__ = None
|
|
494
|
+
Init.__doc__ = None
|
|
495
|
+
cls.__init__ = Init
|
|
496
|
+
|
|
497
|
+
|
|
498
|
+
def _IsMessageSetExtension(field):
|
|
499
|
+
"""Checks if a field is a message set extension."""
|
|
500
|
+
return (field.is_extension and
|
|
501
|
+
field.containing_type.has_options and
|
|
502
|
+
field.containing_type.GetOptions().message_set_wire_format and
|
|
503
|
+
field.type == _TYPE_MESSAGE and
|
|
504
|
+
field.message_type == field.extension_scope and
|
|
505
|
+
field.label == _LABEL_OPTIONAL)
|
|
506
|
+
|
|
507
|
+
|
|
508
|
+
def _AddMessageMethods(message_descriptor, cls):
|
|
509
|
+
"""Adds the methods to a protocol message class."""
|
|
510
|
+
if message_descriptor.is_extendable:
|
|
511
|
+
|
|
512
|
+
def ClearExtension(self, extension):
|
|
513
|
+
self.Extensions.ClearExtension(extension)
|
|
514
|
+
|
|
515
|
+
def HasExtension(self, extension):
|
|
516
|
+
return self.Extensions.HasExtension(extension)
|
|
517
|
+
|
|
518
|
+
def HasField(self, field_name):
|
|
519
|
+
return self._cmsg.HasField(field_name)
|
|
520
|
+
|
|
521
|
+
def ClearField(self, field_name):
|
|
522
|
+
child_cmessage = None
|
|
523
|
+
if field_name in self._composite_fields:
|
|
524
|
+
child_field = self._composite_fields[field_name]
|
|
525
|
+
del self._composite_fields[field_name]
|
|
526
|
+
|
|
527
|
+
child_cdescriptor = self.__descriptors[field_name]
|
|
528
|
+
# TODO(anuraag): Support clearing repeated message fields as well.
|
|
529
|
+
if (child_cdescriptor.label != _LABEL_REPEATED and
|
|
530
|
+
child_cdescriptor.cpp_type == _CPPTYPE_MESSAGE):
|
|
531
|
+
child_field._owner = None
|
|
532
|
+
child_cmessage = child_field._cmsg
|
|
533
|
+
|
|
534
|
+
if child_cmessage is not None:
|
|
535
|
+
self._cmsg.ClearField(field_name, child_cmessage)
|
|
536
|
+
else:
|
|
537
|
+
self._cmsg.ClearField(field_name)
|
|
538
|
+
|
|
539
|
+
def Clear(self):
|
|
540
|
+
cmessages_to_release = []
|
|
541
|
+
for field_name, child_field in self._composite_fields.iteritems():
|
|
542
|
+
child_cdescriptor = self.__descriptors[field_name]
|
|
543
|
+
# TODO(anuraag): Support clearing repeated message fields as well.
|
|
544
|
+
if (child_cdescriptor.label != _LABEL_REPEATED and
|
|
545
|
+
child_cdescriptor.cpp_type == _CPPTYPE_MESSAGE):
|
|
546
|
+
child_field._owner = None
|
|
547
|
+
cmessages_to_release.append((child_cdescriptor, child_field._cmsg))
|
|
548
|
+
self._composite_fields.clear()
|
|
549
|
+
self._cmsg.Clear(cmessages_to_release)
|
|
550
|
+
|
|
551
|
+
def IsInitialized(self, errors=None):
|
|
552
|
+
if self._cmsg.IsInitialized():
|
|
553
|
+
return True
|
|
554
|
+
if errors is not None:
|
|
555
|
+
errors.extend(self.FindInitializationErrors());
|
|
556
|
+
return False
|
|
557
|
+
|
|
558
|
+
def SerializeToString(self):
|
|
559
|
+
if not self.IsInitialized():
|
|
560
|
+
raise message.EncodeError(
|
|
561
|
+
'Message %s is missing required fields: %s' % (
|
|
562
|
+
self._cmsg.full_name, ','.join(self.FindInitializationErrors())))
|
|
563
|
+
return self._cmsg.SerializeToString()
|
|
564
|
+
|
|
565
|
+
def SerializePartialToString(self):
|
|
566
|
+
return self._cmsg.SerializePartialToString()
|
|
567
|
+
|
|
568
|
+
def ParseFromString(self, serialized):
|
|
569
|
+
self.Clear()
|
|
570
|
+
self.MergeFromString(serialized)
|
|
571
|
+
|
|
572
|
+
def MergeFromString(self, serialized):
|
|
573
|
+
byte_size = self._cmsg.MergeFromString(serialized)
|
|
574
|
+
if byte_size < 0:
|
|
575
|
+
raise message.DecodeError('Unable to merge from string.')
|
|
576
|
+
return byte_size
|
|
577
|
+
|
|
578
|
+
def MergeFrom(self, msg):
|
|
579
|
+
if not isinstance(msg, cls):
|
|
580
|
+
raise TypeError(
|
|
581
|
+
"Parameter to MergeFrom() must be instance of same class: "
|
|
582
|
+
"expected %s got %s." % (cls.__name__, type(msg).__name__))
|
|
583
|
+
self._cmsg.MergeFrom(msg._cmsg)
|
|
584
|
+
|
|
585
|
+
def CopyFrom(self, msg):
|
|
586
|
+
self._cmsg.CopyFrom(msg._cmsg)
|
|
587
|
+
|
|
588
|
+
def ByteSize(self):
|
|
589
|
+
return self._cmsg.ByteSize()
|
|
590
|
+
|
|
591
|
+
def SetInParent(self):
|
|
592
|
+
return self._cmsg.SetInParent()
|
|
593
|
+
|
|
594
|
+
def ListFields(self):
|
|
595
|
+
all_fields = []
|
|
596
|
+
field_list = self._cmsg.ListFields()
|
|
597
|
+
fields_by_name = cls.DESCRIPTOR.fields_by_name
|
|
598
|
+
for is_extension, field_name in field_list:
|
|
599
|
+
if is_extension:
|
|
600
|
+
extension = cls._extensions_by_name[field_name]
|
|
601
|
+
all_fields.append((extension, self.Extensions[extension]))
|
|
602
|
+
else:
|
|
603
|
+
field_descriptor = fields_by_name[field_name]
|
|
604
|
+
all_fields.append(
|
|
605
|
+
(field_descriptor, getattr(self, field_name)))
|
|
606
|
+
all_fields.sort(key=lambda item: item[0].number)
|
|
607
|
+
return all_fields
|
|
608
|
+
|
|
609
|
+
def FindInitializationErrors(self):
|
|
610
|
+
return self._cmsg.FindInitializationErrors()
|
|
611
|
+
|
|
612
|
+
def __str__(self):
|
|
613
|
+
return str(self._cmsg)
|
|
614
|
+
|
|
615
|
+
def __eq__(self, other):
|
|
616
|
+
if self is other:
|
|
617
|
+
return True
|
|
618
|
+
if not isinstance(other, self.__class__):
|
|
619
|
+
return False
|
|
620
|
+
return self.ListFields() == other.ListFields()
|
|
621
|
+
|
|
622
|
+
def __ne__(self, other):
|
|
623
|
+
return not self == other
|
|
624
|
+
|
|
625
|
+
def __hash__(self):
|
|
626
|
+
raise TypeError('unhashable object')
|
|
627
|
+
|
|
628
|
+
def __unicode__(self):
|
|
629
|
+
# Lazy import to prevent circular import when text_format imports this file.
|
|
630
|
+
from google.protobuf import text_format
|
|
631
|
+
return text_format.MessageToString(self, as_utf8=True).decode('utf-8')
|
|
632
|
+
|
|
633
|
+
# Attach the local methods to the message class.
|
|
634
|
+
for key, value in locals().copy().iteritems():
|
|
635
|
+
if key not in ('key', 'value', '__builtins__', '__name__', '__doc__'):
|
|
636
|
+
setattr(cls, key, value)
|
|
637
|
+
|
|
638
|
+
# Static methods:
|
|
639
|
+
|
|
640
|
+
def RegisterExtension(extension_handle):
|
|
641
|
+
extension_handle.containing_type = cls.DESCRIPTOR
|
|
642
|
+
cls._extensions_by_name[extension_handle.full_name] = extension_handle
|
|
643
|
+
|
|
644
|
+
if _IsMessageSetExtension(extension_handle):
|
|
645
|
+
# MessageSet extension. Also register under type name.
|
|
646
|
+
cls._extensions_by_name[
|
|
647
|
+
extension_handle.message_type.full_name] = extension_handle
|
|
648
|
+
cls.RegisterExtension = staticmethod(RegisterExtension)
|
|
649
|
+
|
|
650
|
+
def FromString(string):
|
|
651
|
+
msg = cls()
|
|
652
|
+
msg.MergeFromString(string)
|
|
653
|
+
return msg
|
|
654
|
+
cls.FromString = staticmethod(FromString)
|
|
655
|
+
|
|
656
|
+
|
|
657
|
+
|
|
658
|
+
def _AddPropertiesForExtensions(message_descriptor, cls):
|
|
659
|
+
"""Adds properties for all fields in this protocol message type."""
|
|
660
|
+
extension_dict = message_descriptor.extensions_by_name
|
|
661
|
+
for extension_name, extension_field in extension_dict.iteritems():
|
|
662
|
+
constant_name = extension_name.upper() + '_FIELD_NUMBER'
|
|
663
|
+
setattr(cls, constant_name, extension_field.number)
|