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,220 @@
|
|
|
1
|
+
;;; protobuf-mode.el --- major mode for editing protocol buffers.
|
|
2
|
+
|
|
3
|
+
;; Author: Alexandre Vassalotti <alexandre@peadrop.com>
|
|
4
|
+
;; Created: 23-Apr-2009
|
|
5
|
+
;; Version: 0.3
|
|
6
|
+
;; Keywords: google protobuf languages
|
|
7
|
+
|
|
8
|
+
;; Redistribution and use in source and binary forms, with or without
|
|
9
|
+
;; modification, are permitted provided that the following conditions are
|
|
10
|
+
;; met:
|
|
11
|
+
;;
|
|
12
|
+
;; * Redistributions of source code must retain the above copyright
|
|
13
|
+
;; notice, this list of conditions and the following disclaimer.
|
|
14
|
+
;; * Redistributions in binary form must reproduce the above
|
|
15
|
+
;; copyright notice, this list of conditions and the following disclaimer
|
|
16
|
+
;; in the documentation and/or other materials provided with the
|
|
17
|
+
;; distribution.
|
|
18
|
+
;; * Neither the name of Google Inc. nor the names of its
|
|
19
|
+
;; contributors may be used to endorse or promote products derived from
|
|
20
|
+
;; this software without specific prior written permission.
|
|
21
|
+
;;
|
|
22
|
+
;; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
23
|
+
;; "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
24
|
+
;; LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
25
|
+
;; A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
26
|
+
;; OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
27
|
+
;; SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
28
|
+
;; LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
29
|
+
;; DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
30
|
+
;; THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
31
|
+
;; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
32
|
+
;; OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
33
|
+
|
|
34
|
+
;;; Commentary:
|
|
35
|
+
|
|
36
|
+
;; Installation:
|
|
37
|
+
;; - Put `protobuf-mode.el' in your Emacs load-path.
|
|
38
|
+
;; - Add this line to your .emacs file:
|
|
39
|
+
;; (require 'protobuf-mode)
|
|
40
|
+
;;
|
|
41
|
+
;; You can customize this mode just like any mode derived from CC Mode. If
|
|
42
|
+
;; you want to add customizations specific to protobuf-mode, you can use the
|
|
43
|
+
;; `protobuf-mode-hook'. For example, the following would make protocol-mode
|
|
44
|
+
;; use 2-space indentation:
|
|
45
|
+
;;
|
|
46
|
+
;; (defconst my-protobuf-style
|
|
47
|
+
;; '((c-basic-offset . 2)
|
|
48
|
+
;; (indent-tabs-mode . nil)))
|
|
49
|
+
;;
|
|
50
|
+
;; (add-hook 'protobuf-mode-hook
|
|
51
|
+
;; (lambda () (c-add-style "my-style" my-protobuf-style t)))
|
|
52
|
+
;;
|
|
53
|
+
;; Refer to the documentation of CC Mode for more information about
|
|
54
|
+
;; customization details and how to use this mode.
|
|
55
|
+
;;
|
|
56
|
+
;; TODO:
|
|
57
|
+
;; - Make highlighting for enum values work properly.
|
|
58
|
+
;; - Fix the parser to recognize extensions as identifiers and not
|
|
59
|
+
;; as casts.
|
|
60
|
+
;; - Improve the parsing of option assignment lists. For example:
|
|
61
|
+
;; optional int32 foo = 1 [(my_field_option) = 4.5];
|
|
62
|
+
;; - Add support for fully-qualified identifiers (e.g., with a leading ".").
|
|
63
|
+
|
|
64
|
+
;;; Code:
|
|
65
|
+
|
|
66
|
+
(require 'cc-mode)
|
|
67
|
+
|
|
68
|
+
(eval-when-compile
|
|
69
|
+
(require 'cc-langs)
|
|
70
|
+
(require 'cc-fonts))
|
|
71
|
+
|
|
72
|
+
;; This mode does not inherit properties from other modes. So, we do not use
|
|
73
|
+
;; the usual `c-add-language' function.
|
|
74
|
+
(eval-and-compile
|
|
75
|
+
(put 'protobuf-mode 'c-mode-prefix "protobuf-"))
|
|
76
|
+
|
|
77
|
+
;; The following code uses of the `c-lang-defconst' macro define syntactic
|
|
78
|
+
;; features of protocol buffer language. Refer to the documentation in the
|
|
79
|
+
;; cc-langs.el file for information about the meaning of the -kwds variables.
|
|
80
|
+
|
|
81
|
+
(c-lang-defconst c-primitive-type-kwds
|
|
82
|
+
protobuf '("double" "float" "int32" "int64" "uint32" "uint64" "sint32"
|
|
83
|
+
"sint64" "fixed32" "fixed64" "sfixed32" "sfixed64" "bool"
|
|
84
|
+
"string" "bytes" "group"))
|
|
85
|
+
|
|
86
|
+
(c-lang-defconst c-modifier-kwds
|
|
87
|
+
protobuf '("required" "optional" "repeated"))
|
|
88
|
+
|
|
89
|
+
(c-lang-defconst c-class-decl-kwds
|
|
90
|
+
protobuf '("message" "enum" "service"))
|
|
91
|
+
|
|
92
|
+
(c-lang-defconst c-constant-kwds
|
|
93
|
+
protobuf '("true" "false"))
|
|
94
|
+
|
|
95
|
+
(c-lang-defconst c-other-decl-kwds
|
|
96
|
+
protobuf '("package" "import"))
|
|
97
|
+
|
|
98
|
+
(c-lang-defconst c-other-kwds
|
|
99
|
+
protobuf '("default" "max"))
|
|
100
|
+
|
|
101
|
+
(c-lang-defconst c-identifier-ops
|
|
102
|
+
;; Handle extended identifiers like google.protobuf.MessageOptions
|
|
103
|
+
protobuf '((left-assoc ".")))
|
|
104
|
+
|
|
105
|
+
;; The following keywords do not fit well in keyword classes defined by
|
|
106
|
+
;; cc-mode. So, we approximate as best we can.
|
|
107
|
+
|
|
108
|
+
(c-lang-defconst c-type-list-kwds
|
|
109
|
+
protobuf '("extensions" "to"))
|
|
110
|
+
|
|
111
|
+
(c-lang-defconst c-typeless-decl-kwds
|
|
112
|
+
protobuf '("extend" "rpc" "option" "returns"))
|
|
113
|
+
|
|
114
|
+
|
|
115
|
+
;; Here we remove default syntax for loops, if-statements and other C
|
|
116
|
+
;; syntactic features that are not supported by the protocol buffer language.
|
|
117
|
+
|
|
118
|
+
(c-lang-defconst c-brace-list-decl-kwds
|
|
119
|
+
;; Remove syntax for C-style enumerations.
|
|
120
|
+
protobuf nil)
|
|
121
|
+
|
|
122
|
+
(c-lang-defconst c-block-stmt-1-kwds
|
|
123
|
+
;; Remove syntax for "do" and "else" keywords.
|
|
124
|
+
protobuf nil)
|
|
125
|
+
|
|
126
|
+
(c-lang-defconst c-block-stmt-2-kwds
|
|
127
|
+
;; Remove syntax for "for", "if", "switch" and "while" keywords.
|
|
128
|
+
protobuf nil)
|
|
129
|
+
|
|
130
|
+
(c-lang-defconst c-simple-stmt-kwds
|
|
131
|
+
;; Remove syntax for "break", "continue", "goto" and "return" keywords.
|
|
132
|
+
protobuf nil)
|
|
133
|
+
|
|
134
|
+
(c-lang-defconst c-paren-stmt-kwds
|
|
135
|
+
;; Remove special case for the "(;;)" in for-loops.
|
|
136
|
+
protobuf nil)
|
|
137
|
+
|
|
138
|
+
(c-lang-defconst c-label-kwds
|
|
139
|
+
;; Remove case label syntax for the "case" and "default" keywords.
|
|
140
|
+
protobuf nil)
|
|
141
|
+
|
|
142
|
+
(c-lang-defconst c-before-label-kwds
|
|
143
|
+
;; Remove special case for the label in a goto statement.
|
|
144
|
+
protobuf nil)
|
|
145
|
+
|
|
146
|
+
(c-lang-defconst c-cpp-matchers
|
|
147
|
+
;; Disable all the C preprocessor syntax.
|
|
148
|
+
protobuf nil)
|
|
149
|
+
|
|
150
|
+
(c-lang-defconst c-decl-prefix-re
|
|
151
|
+
;; Same as for C, except it does not match "(". This is needed for disabling
|
|
152
|
+
;; the syntax for casts.
|
|
153
|
+
protobuf "\\([\{\};,]+\\)")
|
|
154
|
+
|
|
155
|
+
|
|
156
|
+
;; Add support for variable levels of syntax highlighting.
|
|
157
|
+
|
|
158
|
+
(defconst protobuf-font-lock-keywords-1 (c-lang-const c-matchers-1 protobuf)
|
|
159
|
+
"Minimal highlighting for protobuf-mode.")
|
|
160
|
+
|
|
161
|
+
(defconst protobuf-font-lock-keywords-2 (c-lang-const c-matchers-2 protobuf)
|
|
162
|
+
"Fast normal highlighting for protobuf-mode.")
|
|
163
|
+
|
|
164
|
+
(defconst protobuf-font-lock-keywords-3 (c-lang-const c-matchers-3 protobuf)
|
|
165
|
+
"Accurate normal highlighting for protobuf-mode.")
|
|
166
|
+
|
|
167
|
+
(defvar protobuf-font-lock-keywords protobuf-font-lock-keywords-3
|
|
168
|
+
"Default expressions to highlight in protobuf-mode.")
|
|
169
|
+
|
|
170
|
+
;; Our syntax table is auto-generated from the keyword classes we defined
|
|
171
|
+
;; previously with the `c-lang-const' macro.
|
|
172
|
+
(defvar protobuf-mode-syntax-table nil
|
|
173
|
+
"Syntax table used in protobuf-mode buffers.")
|
|
174
|
+
(or protobuf-mode-syntax-table
|
|
175
|
+
(setq protobuf-mode-syntax-table
|
|
176
|
+
(funcall (c-lang-const c-make-mode-syntax-table protobuf))))
|
|
177
|
+
|
|
178
|
+
(defvar protobuf-mode-abbrev-table nil
|
|
179
|
+
"Abbreviation table used in protobuf-mode buffers.")
|
|
180
|
+
|
|
181
|
+
(defvar protobuf-mode-map nil
|
|
182
|
+
"Keymap used in protobuf-mode buffers.")
|
|
183
|
+
(or protobuf-mode-map
|
|
184
|
+
(setq protobuf-mode-map (c-make-inherited-keymap)))
|
|
185
|
+
|
|
186
|
+
(easy-menu-define protobuf-menu protobuf-mode-map
|
|
187
|
+
"Protocol Buffers Mode Commands"
|
|
188
|
+
(cons "Protocol Buffers" (c-lang-const c-mode-menu protobuf)))
|
|
189
|
+
|
|
190
|
+
;;;###autoload (add-to-list 'auto-mode-alist '("\\.proto\\'" . protobuf-mode))
|
|
191
|
+
|
|
192
|
+
;;;###autoload
|
|
193
|
+
(defun protobuf-mode ()
|
|
194
|
+
"Major mode for editing Protocol Buffers description language.
|
|
195
|
+
|
|
196
|
+
The hook `c-mode-common-hook' is run with no argument at mode
|
|
197
|
+
initialization, then `protobuf-mode-hook'.
|
|
198
|
+
|
|
199
|
+
Key bindings:
|
|
200
|
+
\\{protobuf-mode-map}"
|
|
201
|
+
(interactive)
|
|
202
|
+
(kill-all-local-variables)
|
|
203
|
+
(set-syntax-table protobuf-mode-syntax-table)
|
|
204
|
+
(setq major-mode 'protobuf-mode
|
|
205
|
+
mode-name "Protocol-Buffers"
|
|
206
|
+
local-abbrev-table protobuf-mode-abbrev-table
|
|
207
|
+
abbrev-mode t)
|
|
208
|
+
(use-local-map protobuf-mode-map)
|
|
209
|
+
(c-initialize-cc-mode t)
|
|
210
|
+
(if (fboundp 'c-make-emacs-variables-local)
|
|
211
|
+
(c-make-emacs-variables-local))
|
|
212
|
+
(c-init-language-vars protobuf-mode)
|
|
213
|
+
(c-common-init 'protobuf-mode)
|
|
214
|
+
(easy-menu-add protobuf-menu)
|
|
215
|
+
(c-run-mode-hooks 'c-mode-common-hook 'protobuf-mode-hook)
|
|
216
|
+
(c-update-modeline))
|
|
217
|
+
|
|
218
|
+
(provide 'protobuf-mode)
|
|
219
|
+
|
|
220
|
+
;;; protobuf-mode.el ends here
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
// See README.txt for information and build instructions.
|
|
2
|
+
|
|
3
|
+
import com.example.tutorial.AddressBookProtos.AddressBook;
|
|
4
|
+
import com.example.tutorial.AddressBookProtos.Person;
|
|
5
|
+
import java.io.BufferedReader;
|
|
6
|
+
import java.io.FileInputStream;
|
|
7
|
+
import java.io.FileNotFoundException;
|
|
8
|
+
import java.io.FileOutputStream;
|
|
9
|
+
import java.io.InputStreamReader;
|
|
10
|
+
import java.io.IOException;
|
|
11
|
+
import java.io.PrintStream;
|
|
12
|
+
|
|
13
|
+
class AddPerson {
|
|
14
|
+
// This function fills in a Person message based on user input.
|
|
15
|
+
static Person PromptForAddress(BufferedReader stdin,
|
|
16
|
+
PrintStream stdout) throws IOException {
|
|
17
|
+
Person.Builder person = Person.newBuilder();
|
|
18
|
+
|
|
19
|
+
stdout.print("Enter person ID: ");
|
|
20
|
+
person.setId(Integer.valueOf(stdin.readLine()));
|
|
21
|
+
|
|
22
|
+
stdout.print("Enter name: ");
|
|
23
|
+
person.setName(stdin.readLine());
|
|
24
|
+
|
|
25
|
+
stdout.print("Enter email address (blank for none): ");
|
|
26
|
+
String email = stdin.readLine();
|
|
27
|
+
if (email.length() > 0) {
|
|
28
|
+
person.setEmail(email);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
while (true) {
|
|
32
|
+
stdout.print("Enter a phone number (or leave blank to finish): ");
|
|
33
|
+
String number = stdin.readLine();
|
|
34
|
+
if (number.length() == 0) {
|
|
35
|
+
break;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
Person.PhoneNumber.Builder phoneNumber =
|
|
39
|
+
Person.PhoneNumber.newBuilder().setNumber(number);
|
|
40
|
+
|
|
41
|
+
stdout.print("Is this a mobile, home, or work phone? ");
|
|
42
|
+
String type = stdin.readLine();
|
|
43
|
+
if (type.equals("mobile")) {
|
|
44
|
+
phoneNumber.setType(Person.PhoneType.MOBILE);
|
|
45
|
+
} else if (type.equals("home")) {
|
|
46
|
+
phoneNumber.setType(Person.PhoneType.HOME);
|
|
47
|
+
} else if (type.equals("work")) {
|
|
48
|
+
phoneNumber.setType(Person.PhoneType.WORK);
|
|
49
|
+
} else {
|
|
50
|
+
stdout.println("Unknown phone type. Using default.");
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
person.addPhone(phoneNumber);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return person.build();
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
// Main function: Reads the entire address book from a file,
|
|
60
|
+
// adds one person based on user input, then writes it back out to the same
|
|
61
|
+
// file.
|
|
62
|
+
public static void main(String[] args) throws Exception {
|
|
63
|
+
if (args.length != 1) {
|
|
64
|
+
System.err.println("Usage: AddPerson ADDRESS_BOOK_FILE");
|
|
65
|
+
System.exit(-1);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
AddressBook.Builder addressBook = AddressBook.newBuilder();
|
|
69
|
+
|
|
70
|
+
// Read the existing address book.
|
|
71
|
+
try {
|
|
72
|
+
FileInputStream input = new FileInputStream(args[0]);
|
|
73
|
+
try {
|
|
74
|
+
addressBook.mergeFrom(input);
|
|
75
|
+
} finally {
|
|
76
|
+
try { input.close(); } catch (Throwable ignore) {}
|
|
77
|
+
}
|
|
78
|
+
} catch (FileNotFoundException e) {
|
|
79
|
+
System.out.println(args[0] + ": File not found. Creating a new file.");
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
// Add an address.
|
|
83
|
+
addressBook.addPerson(
|
|
84
|
+
PromptForAddress(new BufferedReader(new InputStreamReader(System.in)),
|
|
85
|
+
System.out));
|
|
86
|
+
|
|
87
|
+
// Write the new address book back to disk.
|
|
88
|
+
FileOutputStream output = new FileOutputStream(args[0]);
|
|
89
|
+
try {
|
|
90
|
+
addressBook.build().writeTo(output);
|
|
91
|
+
} finally {
|
|
92
|
+
output.close();
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
// See README.txt for information and build instructions.
|
|
2
|
+
|
|
3
|
+
import com.example.tutorial.AddressBookProtos.AddressBook;
|
|
4
|
+
import com.example.tutorial.AddressBookProtos.Person;
|
|
5
|
+
import java.io.FileInputStream;
|
|
6
|
+
import java.io.IOException;
|
|
7
|
+
import java.io.PrintStream;
|
|
8
|
+
|
|
9
|
+
class ListPeople {
|
|
10
|
+
// Iterates though all people in the AddressBook and prints info about them.
|
|
11
|
+
static void Print(AddressBook addressBook) {
|
|
12
|
+
for (Person person: addressBook.getPersonList()) {
|
|
13
|
+
System.out.println("Person ID: " + person.getId());
|
|
14
|
+
System.out.println(" Name: " + person.getName());
|
|
15
|
+
if (person.hasEmail()) {
|
|
16
|
+
System.out.println(" E-mail address: " + person.getEmail());
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
for (Person.PhoneNumber phoneNumber : person.getPhoneList()) {
|
|
20
|
+
switch (phoneNumber.getType()) {
|
|
21
|
+
case MOBILE:
|
|
22
|
+
System.out.print(" Mobile phone #: ");
|
|
23
|
+
break;
|
|
24
|
+
case HOME:
|
|
25
|
+
System.out.print(" Home phone #: ");
|
|
26
|
+
break;
|
|
27
|
+
case WORK:
|
|
28
|
+
System.out.print(" Work phone #: ");
|
|
29
|
+
break;
|
|
30
|
+
}
|
|
31
|
+
System.out.println(phoneNumber.getNumber());
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// Main function: Reads the entire address book from a file and prints all
|
|
37
|
+
// the information inside.
|
|
38
|
+
public static void main(String[] args) throws Exception {
|
|
39
|
+
if (args.length != 1) {
|
|
40
|
+
System.err.println("Usage: ListPeople ADDRESS_BOOK_FILE");
|
|
41
|
+
System.exit(-1);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
// Read the existing address book.
|
|
45
|
+
AddressBook addressBook =
|
|
46
|
+
AddressBook.parseFrom(new FileInputStream(args[0]));
|
|
47
|
+
|
|
48
|
+
Print(addressBook);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
# See README.txt.
|
|
2
|
+
|
|
3
|
+
.PHONY: all cpp java python clean
|
|
4
|
+
|
|
5
|
+
all: cpp java python
|
|
6
|
+
|
|
7
|
+
cpp: add_person_cpp list_people_cpp
|
|
8
|
+
java: add_person_java list_people_java
|
|
9
|
+
python: add_person_python list_people_python
|
|
10
|
+
|
|
11
|
+
clean:
|
|
12
|
+
rm -f add_person_cpp list_people_cpp add_person_java list_people_java add_person_python list_people_python
|
|
13
|
+
rm -f javac_middleman AddPerson*.class ListPeople*.class com/example/tutorial/*.class
|
|
14
|
+
rm -f protoc_middleman addressbook.pb.cc addressbook.pb.h addressbook_pb2.py com/example/tutorial/AddressBookProtos.java
|
|
15
|
+
rm -f *.pyc
|
|
16
|
+
rmdir com/example/tutorial 2>/dev/null || true
|
|
17
|
+
rmdir com/example 2>/dev/null || true
|
|
18
|
+
rmdir com 2>/dev/null || true
|
|
19
|
+
|
|
20
|
+
protoc_middleman: addressbook.proto
|
|
21
|
+
protoc --cpp_out=. --java_out=. --python_out=. addressbook.proto
|
|
22
|
+
@touch protoc_middleman
|
|
23
|
+
|
|
24
|
+
add_person_cpp: add_person.cc protoc_middleman
|
|
25
|
+
pkg-config --cflags protobuf # fails if protobuf is not installed
|
|
26
|
+
c++ add_person.cc addressbook.pb.cc -o add_person_cpp `pkg-config --cflags --libs protobuf`
|
|
27
|
+
|
|
28
|
+
list_people_cpp: list_people.cc protoc_middleman
|
|
29
|
+
pkg-config --cflags protobuf # fails if protobuf is not installed
|
|
30
|
+
c++ list_people.cc addressbook.pb.cc -o list_people_cpp `pkg-config --cflags --libs protobuf`
|
|
31
|
+
|
|
32
|
+
javac_middleman: AddPerson.java ListPeople.java protoc_middleman
|
|
33
|
+
javac AddPerson.java ListPeople.java com/example/tutorial/AddressBookProtos.java
|
|
34
|
+
@touch javac_middleman
|
|
35
|
+
|
|
36
|
+
add_person_java: javac_middleman
|
|
37
|
+
@echo "Writing shortcut script add_person_java..."
|
|
38
|
+
@echo '#! /bin/sh' > add_person_java
|
|
39
|
+
@echo 'java -classpath .:$$CLASSPATH AddPerson "$$@"' >> add_person_java
|
|
40
|
+
@chmod +x add_person_java
|
|
41
|
+
|
|
42
|
+
list_people_java: javac_middleman
|
|
43
|
+
@echo "Writing shortcut script list_people_java..."
|
|
44
|
+
@echo '#! /bin/sh' > list_people_java
|
|
45
|
+
@echo 'java -classpath .:$$CLASSPATH ListPeople "$$@"' >> list_people_java
|
|
46
|
+
@chmod +x list_people_java
|
|
47
|
+
|
|
48
|
+
add_person_python: add_person.py protoc_middleman
|
|
49
|
+
@echo "Writing shortcut script add_person_python..."
|
|
50
|
+
@echo '#! /bin/sh' > add_person_python
|
|
51
|
+
@echo './add_person.py "$$@"' >> add_person_python
|
|
52
|
+
@chmod +x add_person_python
|
|
53
|
+
|
|
54
|
+
list_people_python: list_people.py protoc_middleman
|
|
55
|
+
@echo "Writing shortcut script list_people_python..."
|
|
56
|
+
@echo '#! /bin/sh' > list_people_python
|
|
57
|
+
@echo './list_people.py "$$@"' >> list_people_python
|
|
58
|
+
@chmod +x list_people_python
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
This directory contains example code that uses Protocol Buffers to manage an
|
|
2
|
+
address book. Two programs are provided, each with three different
|
|
3
|
+
implementations, one written in each of C++, Java, and Python. The add_person
|
|
4
|
+
example adds a new person to an address book, prompting the user to input
|
|
5
|
+
the person's information. The list_people example lists people already in the
|
|
6
|
+
address book. The examples use the exact same format in all three languages,
|
|
7
|
+
so you can, for example, use add_person_java to create an address book and then
|
|
8
|
+
use list_people_python to read it.
|
|
9
|
+
|
|
10
|
+
You must install the protobuf package before you can build these.
|
|
11
|
+
|
|
12
|
+
To build all the examples (on a unix-like system), simply run "make". This
|
|
13
|
+
creates the following executable files in the current directory:
|
|
14
|
+
add_person_cpp list_people_cpp
|
|
15
|
+
add_person_java list_people_java
|
|
16
|
+
add_person_python list_people_python
|
|
17
|
+
|
|
18
|
+
If you only want to compile examples in one language, use "make cpp"*,
|
|
19
|
+
"make java", or "make python".
|
|
20
|
+
|
|
21
|
+
All of these programs simply take an address book file as their parameter.
|
|
22
|
+
The add_person programs will create the file if it doesn't already exist.
|
|
23
|
+
|
|
24
|
+
These examples are part of the Protocol Buffers tutorial, located at:
|
|
25
|
+
https://developers.google.com/protocol-buffers/docs/tutorials
|
|
26
|
+
|
|
27
|
+
* Note that on some platforms you may have to edit the Makefile and remove
|
|
28
|
+
"-lpthread" from the linker commands (perhaps replacing it with something else).
|
|
29
|
+
We didn't do this automatically because we wanted to keep the example simple.
|