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.
Files changed (479) hide show
  1. checksums.yaml +4 -4
  2. data/ext/protoc/Makefile.in +10 -13
  3. data/ext/protoc/extconf.rb +0 -1
  4. data/ext/protoc/protobuf/CHANGES.txt +593 -0
  5. data/ext/protoc/protobuf/CONTRIBUTORS.txt +93 -0
  6. data/ext/protoc/protobuf/INSTALL.txt +237 -0
  7. data/ext/protoc/protobuf/LICENSE +33 -0
  8. data/ext/protoc/protobuf/Makefile.am +267 -0
  9. data/ext/protoc/protobuf/README.md +167 -0
  10. data/ext/protoc/protobuf/autogen.sh +41 -0
  11. data/ext/protoc/protobuf/benchmarks/ProtoBench.java +203 -0
  12. data/ext/protoc/protobuf/benchmarks/google_message1.dat +0 -0
  13. data/ext/protoc/protobuf/benchmarks/google_message2.dat +0 -0
  14. data/ext/protoc/protobuf/benchmarks/google_size.proto +136 -0
  15. data/ext/protoc/protobuf/benchmarks/google_speed.proto +136 -0
  16. data/ext/protoc/protobuf/benchmarks/readme.txt +50 -0
  17. data/ext/protoc/protobuf/configure.ac +159 -0
  18. data/ext/protoc/protobuf/editors/README.txt +5 -0
  19. data/ext/protoc/protobuf/editors/proto.vim +105 -0
  20. data/ext/protoc/protobuf/editors/protobuf-mode.el +220 -0
  21. data/ext/protoc/protobuf/examples/AddPerson.java +95 -0
  22. data/ext/protoc/protobuf/examples/ListPeople.java +50 -0
  23. data/ext/protoc/protobuf/examples/Makefile +58 -0
  24. data/ext/protoc/protobuf/examples/README.txt +29 -0
  25. data/ext/protoc/protobuf/examples/add_person.cc +95 -0
  26. data/ext/protoc/protobuf/examples/add_person.py +58 -0
  27. data/ext/protoc/protobuf/examples/addressbook.proto +30 -0
  28. data/ext/protoc/protobuf/examples/list_people.cc +68 -0
  29. data/ext/protoc/protobuf/examples/list_people.py +38 -0
  30. data/ext/protoc/protobuf/generate_descriptor_proto.sh +33 -0
  31. data/ext/protoc/protobuf/java/README.txt +96 -0
  32. data/ext/protoc/protobuf/java/pom.xml +217 -0
  33. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/AbstractMessage.java +466 -0
  34. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/AbstractMessageLite.java +355 -0
  35. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/AbstractParser.java +253 -0
  36. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/BlockingRpcChannel.java +51 -0
  37. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/BlockingService.java +64 -0
  38. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/BoundedByteString.java +163 -0
  39. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ByteString.java +1022 -0
  40. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/CodedInputStream.java +1311 -0
  41. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/CodedOutputStream.java +1297 -0
  42. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Descriptors.java +2238 -0
  43. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/DynamicMessage.java +622 -0
  44. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Extension.java +96 -0
  45. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ExtensionRegistry.java +392 -0
  46. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ExtensionRegistryLite.java +185 -0
  47. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/FieldSet.java +907 -0
  48. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/GeneratedMessage.java +2213 -0
  49. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/GeneratedMessageLite.java +949 -0
  50. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Internal.java +391 -0
  51. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/InvalidProtocolBufferException.java +122 -0
  52. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LazyField.java +154 -0
  53. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LazyFieldLite.java +176 -0
  54. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LazyStringArrayList.java +367 -0
  55. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LazyStringList.java +163 -0
  56. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/LiteralByteString.java +362 -0
  57. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Message.java +244 -0
  58. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/MessageLite.java +320 -0
  59. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/MessageLiteOrBuilder.java +60 -0
  60. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/MessageOrBuilder.java +143 -0
  61. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/MessageReflection.java +931 -0
  62. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Parser.java +261 -0
  63. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ProtocolMessageEnum.java +58 -0
  64. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ProtocolStringList.java +48 -0
  65. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RepeatedFieldBuilder.java +696 -0
  66. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RopeByteString.java +957 -0
  67. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RpcCallback.java +47 -0
  68. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RpcChannel.java +71 -0
  69. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RpcController.java +118 -0
  70. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/RpcUtil.java +134 -0
  71. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Service.java +117 -0
  72. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/ServiceException.java +52 -0
  73. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/SingleFieldBuilder.java +241 -0
  74. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/SmallSortedMap.java +618 -0
  75. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/TextFormat.java +1984 -0
  76. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/UninitializedMessageException.java +99 -0
  77. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/UnknownFieldSet.java +995 -0
  78. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/UnmodifiableLazyStringList.java +205 -0
  79. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/Utf8.java +349 -0
  80. data/ext/protoc/protobuf/java/src/main/java/com/google/protobuf/WireFormat.java +163 -0
  81. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/AbstractMessageTest.java +527 -0
  82. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/BoundedByteStringTest.java +68 -0
  83. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/ByteStringTest.java +759 -0
  84. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/CheckUtf8Test.java +141 -0
  85. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/CodedInputStreamTest.java +769 -0
  86. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/CodedOutputStreamTest.java +401 -0
  87. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/DeprecatedFieldTest.java +80 -0
  88. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/DescriptorsTest.java +735 -0
  89. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/DynamicMessageTest.java +326 -0
  90. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/ForceFieldBuildersPreRun.java +48 -0
  91. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/GeneratedMessageTest.java +1515 -0
  92. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/IsValidUtf8Test.java +180 -0
  93. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/IsValidUtf8TestUtil.java +421 -0
  94. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyFieldLiteTest.java +134 -0
  95. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyFieldTest.java +121 -0
  96. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyMessageLiteTest.java +319 -0
  97. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyStringArrayListTest.java +174 -0
  98. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LazyStringEndToEndTest.java +143 -0
  99. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LiteEqualsAndHashTest.java +85 -0
  100. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LiteTest.java +148 -0
  101. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/LiteralByteStringTest.java +396 -0
  102. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/MessageTest.java +353 -0
  103. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/NestedBuildersTest.java +185 -0
  104. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/ParserTest.java +381 -0
  105. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/RepeatedFieldBuilderTest.java +190 -0
  106. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/RopeByteStringSubstringTest.java +97 -0
  107. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/RopeByteStringTest.java +115 -0
  108. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/ServiceTest.java +320 -0
  109. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/SingleFieldBuilderTest.java +155 -0
  110. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/SmallSortedMapTest.java +420 -0
  111. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/TestBadIdentifiers.java +96 -0
  112. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/TestUtil.java +4124 -0
  113. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/TextFormatTest.java +994 -0
  114. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/UnknownFieldSetTest.java +653 -0
  115. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/UnmodifiableLazyStringListTest.java +227 -0
  116. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/WireFormatTest.java +606 -0
  117. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/lazy_fields_lite.proto +61 -0
  118. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/lite_equals_and_hash.proto +55 -0
  119. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/multiple_files_test.proto +77 -0
  120. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/nested_builders_test.proto +53 -0
  121. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/nested_extension.proto +46 -0
  122. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/nested_extension_lite.proto +48 -0
  123. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/non_nested_extension.proto +49 -0
  124. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/non_nested_extension_lite.proto +50 -0
  125. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/outer_class_name_test.proto +38 -0
  126. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/outer_class_name_test2.proto +42 -0
  127. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/outer_class_name_test3.proto +43 -0
  128. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_bad_identifiers.proto +157 -0
  129. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_check_utf8.proto +50 -0
  130. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_check_utf8_size.proto +51 -0
  131. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_custom_options.proto +43 -0
  132. data/ext/protoc/protobuf/java/src/test/java/com/google/protobuf/test_extra_interfaces.proto +60 -0
  133. data/ext/protoc/protobuf/m4/ac_system_extensions.m4 +37 -0
  134. data/ext/protoc/protobuf/m4/acx_check_suncc.m4 +75 -0
  135. data/ext/protoc/protobuf/m4/acx_pthread.m4 +397 -0
  136. data/ext/protoc/protobuf/m4/stl_hash.m4 +72 -0
  137. data/ext/protoc/protobuf/more_tests/Makefile +41 -0
  138. data/ext/protoc/protobuf/post_process_dist.sh +60 -0
  139. data/ext/protoc/protobuf/protobuf-lite.pc.in +13 -0
  140. data/ext/protoc/protobuf/protobuf.pc.in +14 -0
  141. data/ext/protoc/protobuf/python/README.txt +105 -0
  142. data/ext/protoc/protobuf/python/ez_setup.py +284 -0
  143. data/ext/protoc/protobuf/python/google/__init__.py +1 -0
  144. data/ext/protoc/protobuf/python/google/protobuf/__init__.py +0 -0
  145. data/ext/protoc/protobuf/python/google/protobuf/descriptor.py +849 -0
  146. data/ext/protoc/protobuf/python/google/protobuf/descriptor_database.py +137 -0
  147. data/ext/protoc/protobuf/python/google/protobuf/descriptor_pool.py +643 -0
  148. data/ext/protoc/protobuf/python/google/protobuf/internal/__init__.py +0 -0
  149. data/ext/protoc/protobuf/python/google/protobuf/internal/api_implementation.cc +139 -0
  150. data/ext/protoc/protobuf/python/google/protobuf/internal/api_implementation.py +89 -0
  151. data/ext/protoc/protobuf/python/google/protobuf/internal/api_implementation_default_test.py +63 -0
  152. data/ext/protoc/protobuf/python/google/protobuf/internal/containers.py +269 -0
  153. data/ext/protoc/protobuf/python/google/protobuf/internal/cpp_message.py +663 -0
  154. data/ext/protoc/protobuf/python/google/protobuf/internal/decoder.py +831 -0
  155. data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_database_test.py +63 -0
  156. data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_pool_test.py +564 -0
  157. data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_pool_test1.proto +94 -0
  158. data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_pool_test2.proto +70 -0
  159. data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_python_test.py +54 -0
  160. data/ext/protoc/protobuf/python/google/protobuf/internal/descriptor_test.py +669 -0
  161. data/ext/protoc/protobuf/python/google/protobuf/internal/encoder.py +788 -0
  162. data/ext/protoc/protobuf/python/google/protobuf/internal/enum_type_wrapper.py +89 -0
  163. data/ext/protoc/protobuf/python/google/protobuf/internal/factory_test1.proto +57 -0
  164. data/ext/protoc/protobuf/python/google/protobuf/internal/factory_test2.proto +92 -0
  165. data/ext/protoc/protobuf/python/google/protobuf/internal/generator_test.py +343 -0
  166. data/ext/protoc/protobuf/python/google/protobuf/internal/message_factory_python_test.py +54 -0
  167. data/ext/protoc/protobuf/python/google/protobuf/internal/message_factory_test.py +131 -0
  168. data/ext/protoc/protobuf/python/google/protobuf/internal/message_listener.py +78 -0
  169. data/ext/protoc/protobuf/python/google/protobuf/internal/message_python_test.py +54 -0
  170. data/ext/protoc/protobuf/python/google/protobuf/internal/message_test.py +681 -0
  171. data/ext/protoc/protobuf/python/google/protobuf/internal/missing_enum_values.proto +50 -0
  172. data/ext/protoc/protobuf/python/google/protobuf/internal/more_extensions.proto +58 -0
  173. data/ext/protoc/protobuf/python/google/protobuf/internal/more_extensions_dynamic.proto +49 -0
  174. data/ext/protoc/protobuf/python/google/protobuf/internal/more_messages.proto +51 -0
  175. data/ext/protoc/protobuf/python/google/protobuf/internal/python_message.py +1251 -0
  176. data/ext/protoc/protobuf/python/google/protobuf/internal/reflection_test.py +2934 -0
  177. data/ext/protoc/protobuf/python/google/protobuf/internal/service_reflection_test.py +136 -0
  178. data/ext/protoc/protobuf/python/google/protobuf/internal/symbol_database_test.py +120 -0
  179. data/ext/protoc/protobuf/python/google/protobuf/internal/test_bad_identifiers.proto +52 -0
  180. data/ext/protoc/protobuf/python/google/protobuf/internal/test_util.py +662 -0
  181. data/ext/protoc/protobuf/python/google/protobuf/internal/text_encoding_test.py +68 -0
  182. data/ext/protoc/protobuf/python/google/protobuf/internal/text_format_test.py +743 -0
  183. data/ext/protoc/protobuf/python/google/protobuf/internal/type_checkers.py +328 -0
  184. data/ext/protoc/protobuf/python/google/protobuf/internal/unknown_fields_test.py +231 -0
  185. data/ext/protoc/protobuf/python/google/protobuf/internal/wire_format.py +268 -0
  186. data/ext/protoc/protobuf/python/google/protobuf/internal/wire_format_test.py +253 -0
  187. data/ext/protoc/protobuf/python/google/protobuf/message.py +284 -0
  188. data/ext/protoc/protobuf/python/google/protobuf/message_factory.py +155 -0
  189. data/ext/protoc/protobuf/python/google/protobuf/pyext/README +6 -0
  190. data/ext/protoc/protobuf/python/google/protobuf/pyext/__init__.py +0 -0
  191. data/ext/protoc/protobuf/python/google/protobuf/pyext/cpp_message.py +61 -0
  192. data/ext/protoc/protobuf/python/google/protobuf/pyext/descriptor.cc +357 -0
  193. data/ext/protoc/protobuf/python/google/protobuf/pyext/descriptor.h +96 -0
  194. data/ext/protoc/protobuf/python/google/protobuf/pyext/descriptor_cpp2_test.py +58 -0
  195. data/ext/protoc/protobuf/python/google/protobuf/pyext/extension_dict.cc +338 -0
  196. data/ext/protoc/protobuf/python/google/protobuf/pyext/extension_dict.h +123 -0
  197. data/ext/protoc/protobuf/python/google/protobuf/pyext/message.cc +2561 -0
  198. data/ext/protoc/protobuf/python/google/protobuf/pyext/message.h +305 -0
  199. data/ext/protoc/protobuf/python/google/protobuf/pyext/message_factory_cpp2_test.py +56 -0
  200. data/ext/protoc/protobuf/python/google/protobuf/pyext/proto2_api_test.proto +38 -0
  201. data/ext/protoc/protobuf/python/google/protobuf/pyext/python.proto +66 -0
  202. data/ext/protoc/protobuf/python/google/protobuf/pyext/python_protobuf.h +57 -0
  203. data/ext/protoc/protobuf/python/google/protobuf/pyext/reflection_cpp2_generated_test.py +94 -0
  204. data/ext/protoc/protobuf/python/google/protobuf/pyext/repeated_composite_container.cc +763 -0
  205. data/ext/protoc/protobuf/python/google/protobuf/pyext/repeated_composite_container.h +172 -0
  206. data/ext/protoc/protobuf/python/google/protobuf/pyext/repeated_scalar_container.cc +825 -0
  207. data/ext/protoc/protobuf/python/google/protobuf/pyext/repeated_scalar_container.h +112 -0
  208. data/ext/protoc/protobuf/python/google/protobuf/pyext/scoped_pyobject_ptr.h +95 -0
  209. data/ext/protoc/protobuf/python/google/protobuf/reflection.py +205 -0
  210. data/ext/protoc/protobuf/python/google/protobuf/service.py +226 -0
  211. data/ext/protoc/protobuf/python/google/protobuf/service_reflection.py +284 -0
  212. data/ext/protoc/protobuf/python/google/protobuf/symbol_database.py +185 -0
  213. data/ext/protoc/protobuf/python/google/protobuf/text_encoding.py +110 -0
  214. data/ext/protoc/protobuf/python/google/protobuf/text_format.py +873 -0
  215. data/ext/protoc/protobuf/python/mox.py +1401 -0
  216. data/ext/protoc/protobuf/python/setup.py +201 -0
  217. data/ext/protoc/protobuf/python/stubout.py +140 -0
  218. data/ext/protoc/protobuf/src/Makefile.am +418 -0
  219. data/ext/protoc/protobuf/src/google/protobuf/SEBS +240 -0
  220. data/ext/protoc/protobuf/src/google/protobuf/compiler/code_generator.cc +84 -0
  221. data/ext/protoc/protobuf/src/google/protobuf/compiler/code_generator.h +145 -0
  222. data/ext/protoc/protobuf/src/google/protobuf/compiler/command_line_interface.cc +1603 -0
  223. data/ext/protoc/protobuf/src/google/protobuf/compiler/command_line_interface.h +378 -0
  224. data/ext/protoc/protobuf/src/google/protobuf/compiler/command_line_interface_unittest.cc +1654 -0
  225. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_bootstrap_unittest.cc +158 -0
  226. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_enum.cc +288 -0
  227. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_enum.h +103 -0
  228. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_enum_field.cc +431 -0
  229. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_enum_field.h +122 -0
  230. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_extension.cc +210 -0
  231. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_extension.h +86 -0
  232. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_field.cc +166 -0
  233. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_field.h +185 -0
  234. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_file.cc +665 -0
  235. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_file.h +99 -0
  236. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_generator.cc +125 -0
  237. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_generator.h +72 -0
  238. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_helpers.cc +494 -0
  239. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_helpers.h +206 -0
  240. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_message.cc +2645 -0
  241. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_message.h +175 -0
  242. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_message_field.cc +375 -0
  243. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_message_field.h +121 -0
  244. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_options.h +58 -0
  245. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_plugin_unittest.cc +123 -0
  246. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_primitive_field.cc +451 -0
  247. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_primitive_field.h +123 -0
  248. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_service.cc +334 -0
  249. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_service.h +118 -0
  250. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_string_field.cc +642 -0
  251. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_string_field.h +127 -0
  252. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_test_bad_identifiers.proto +132 -0
  253. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_unittest.cc +2074 -0
  254. data/ext/protoc/protobuf/src/google/protobuf/compiler/cpp/cpp_unittest.h +51 -0
  255. data/ext/protoc/protobuf/src/google/protobuf/compiler/importer.cc +480 -0
  256. data/ext/protoc/protobuf/src/google/protobuf/compiler/importer.h +317 -0
  257. data/ext/protoc/protobuf/src/google/protobuf/compiler/importer_unittest.cc +617 -0
  258. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_context.cc +195 -0
  259. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_context.h +95 -0
  260. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_doc_comment.cc +233 -0
  261. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_doc_comment.h +69 -0
  262. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_doc_comment_unittest.cc +67 -0
  263. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_enum.cc +333 -0
  264. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_enum.h +99 -0
  265. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_enum_field.cc +778 -0
  266. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_enum_field.h +158 -0
  267. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_extension.cc +207 -0
  268. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_extension.h +109 -0
  269. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_field.cc +213 -0
  270. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_field.h +162 -0
  271. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_file.cc +534 -0
  272. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_file.h +115 -0
  273. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_generator.cc +158 -0
  274. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_generator.h +72 -0
  275. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_generator_factory.cc +77 -0
  276. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_generator_factory.h +101 -0
  277. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_helpers.cc +737 -0
  278. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_helpers.h +322 -0
  279. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_lazy_message_field.cc +826 -0
  280. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_lazy_message_field.h +121 -0
  281. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_message.cc +1666 -0
  282. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_message.h +140 -0
  283. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_message_field.cc +1343 -0
  284. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_message_field.h +173 -0
  285. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_name_resolver.cc +266 -0
  286. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_name_resolver.h +124 -0
  287. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_plugin_unittest.cc +124 -0
  288. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_primitive_field.cc +877 -0
  289. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_primitive_field.h +160 -0
  290. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_service.cc +473 -0
  291. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_service.h +135 -0
  292. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_shared_code_generator.cc +201 -0
  293. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_shared_code_generator.h +90 -0
  294. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_string_field.cc +1056 -0
  295. data/ext/protoc/protobuf/src/google/protobuf/compiler/java/java_string_field.h +160 -0
  296. data/ext/protoc/protobuf/src/google/protobuf/compiler/main.cc +61 -0
  297. data/ext/protoc/protobuf/src/google/protobuf/compiler/mock_code_generator.cc +240 -0
  298. data/ext/protoc/protobuf/src/google/protobuf/compiler/mock_code_generator.h +117 -0
  299. data/ext/protoc/protobuf/src/google/protobuf/compiler/package_info.h +64 -0
  300. data/ext/protoc/protobuf/src/google/protobuf/compiler/parser.cc +1750 -0
  301. data/ext/protoc/protobuf/src/google/protobuf/compiler/parser.h +522 -0
  302. data/ext/protoc/protobuf/src/google/protobuf/compiler/parser_unittest.cc +2612 -0
  303. data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.cc +163 -0
  304. data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.h +72 -0
  305. data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.pb.cc +1148 -0
  306. data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.pb.h +897 -0
  307. data/ext/protoc/protobuf/src/google/protobuf/compiler/plugin.proto +147 -0
  308. data/ext/protoc/protobuf/src/google/protobuf/compiler/python/python_generator.cc +1262 -0
  309. data/ext/protoc/protobuf/src/google/protobuf/compiler/python/python_generator.h +166 -0
  310. data/ext/protoc/protobuf/src/google/protobuf/compiler/python/python_plugin_unittest.cc +118 -0
  311. data/ext/protoc/protobuf/src/google/protobuf/compiler/subprocess.cc +463 -0
  312. data/ext/protoc/protobuf/src/google/protobuf/compiler/subprocess.h +108 -0
  313. data/ext/protoc/protobuf/src/google/protobuf/compiler/test_plugin.cc +51 -0
  314. data/ext/protoc/protobuf/src/google/protobuf/compiler/zip_output_unittest.sh +91 -0
  315. data/ext/protoc/protobuf/src/google/protobuf/compiler/zip_writer.cc +218 -0
  316. data/ext/protoc/protobuf/src/google/protobuf/compiler/zip_writer.h +93 -0
  317. data/ext/protoc/protobuf/src/google/protobuf/descriptor.cc +5420 -0
  318. data/ext/protoc/protobuf/src/google/protobuf/descriptor.h +1691 -0
  319. data/ext/protoc/protobuf/src/google/protobuf/descriptor.pb.cc +9135 -0
  320. data/ext/protoc/protobuf/src/google/protobuf/descriptor.pb.h +6761 -0
  321. data/ext/protoc/protobuf/src/google/protobuf/descriptor.proto +687 -0
  322. data/ext/protoc/protobuf/src/google/protobuf/descriptor_database.cc +543 -0
  323. data/ext/protoc/protobuf/src/google/protobuf/descriptor_database.h +369 -0
  324. data/ext/protoc/protobuf/src/google/protobuf/descriptor_database_unittest.cc +748 -0
  325. data/ext/protoc/protobuf/src/google/protobuf/descriptor_pb2_test.py +54 -0
  326. data/ext/protoc/protobuf/src/google/protobuf/descriptor_unittest.cc +5501 -0
  327. data/ext/protoc/protobuf/src/google/protobuf/dynamic_message.cc +764 -0
  328. data/ext/protoc/protobuf/src/google/protobuf/dynamic_message.h +148 -0
  329. data/ext/protoc/protobuf/src/google/protobuf/dynamic_message_unittest.cc +230 -0
  330. data/ext/protoc/protobuf/src/google/protobuf/extension_set.cc +1663 -0
  331. data/ext/protoc/protobuf/src/google/protobuf/extension_set.h +1234 -0
  332. data/ext/protoc/protobuf/src/google/protobuf/extension_set_heavy.cc +734 -0
  333. data/ext/protoc/protobuf/src/google/protobuf/extension_set_unittest.cc +1095 -0
  334. data/ext/protoc/protobuf/src/google/protobuf/generated_enum_reflection.h +91 -0
  335. data/ext/protoc/protobuf/src/google/protobuf/generated_message_reflection.cc +1683 -0
  336. data/ext/protoc/protobuf/src/google/protobuf/generated_message_reflection.h +504 -0
  337. data/ext/protoc/protobuf/src/google/protobuf/generated_message_reflection_unittest.cc +795 -0
  338. data/ext/protoc/protobuf/src/google/protobuf/generated_message_util.cc +65 -0
  339. data/ext/protoc/protobuf/src/google/protobuf/generated_message_util.h +113 -0
  340. data/ext/protoc/protobuf/src/google/protobuf/io/coded_stream.cc +914 -0
  341. data/ext/protoc/protobuf/src/google/protobuf/io/coded_stream.h +1220 -0
  342. data/ext/protoc/protobuf/src/google/protobuf/io/coded_stream_inl.h +69 -0
  343. data/ext/protoc/protobuf/src/google/protobuf/io/coded_stream_unittest.cc +1378 -0
  344. data/ext/protoc/protobuf/src/google/protobuf/io/gzip_stream.cc +326 -0
  345. data/ext/protoc/protobuf/src/google/protobuf/io/gzip_stream.h +209 -0
  346. data/ext/protoc/protobuf/src/google/protobuf/io/gzip_stream_unittest.sh +44 -0
  347. data/ext/protoc/protobuf/src/google/protobuf/io/package_info.h +54 -0
  348. data/ext/protoc/protobuf/src/google/protobuf/io/printer.cc +198 -0
  349. data/ext/protoc/protobuf/src/google/protobuf/io/printer.h +136 -0
  350. data/ext/protoc/protobuf/src/google/protobuf/io/printer_unittest.cc +285 -0
  351. data/ext/protoc/protobuf/src/google/protobuf/io/strtod.cc +113 -0
  352. data/ext/protoc/protobuf/src/google/protobuf/io/strtod.h +50 -0
  353. data/ext/protoc/protobuf/src/google/protobuf/io/tokenizer.cc +1127 -0
  354. data/ext/protoc/protobuf/src/google/protobuf/io/tokenizer.h +402 -0
  355. data/ext/protoc/protobuf/src/google/protobuf/io/tokenizer_unittest.cc +999 -0
  356. data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream.cc +57 -0
  357. data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream.h +248 -0
  358. data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_impl.cc +473 -0
  359. data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_impl.h +358 -0
  360. data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_impl_lite.cc +405 -0
  361. data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_impl_lite.h +354 -0
  362. data/ext/protoc/protobuf/src/google/protobuf/io/zero_copy_stream_unittest.cc +965 -0
  363. data/ext/protoc/protobuf/src/google/protobuf/lite_unittest.cc +350 -0
  364. data/ext/protoc/protobuf/src/google/protobuf/message.cc +358 -0
  365. data/ext/protoc/protobuf/src/google/protobuf/message.h +866 -0
  366. data/ext/protoc/protobuf/src/google/protobuf/message_lite.cc +335 -0
  367. data/ext/protoc/protobuf/src/google/protobuf/message_lite.h +247 -0
  368. data/ext/protoc/protobuf/src/google/protobuf/message_unittest.cc +427 -0
  369. data/ext/protoc/protobuf/src/google/protobuf/package_info.h +64 -0
  370. data/ext/protoc/protobuf/src/google/protobuf/reflection_ops.cc +269 -0
  371. data/ext/protoc/protobuf/src/google/protobuf/reflection_ops.h +81 -0
  372. data/ext/protoc/protobuf/src/google/protobuf/reflection_ops_unittest.cc +475 -0
  373. data/ext/protoc/protobuf/src/google/protobuf/repeated_field.cc +87 -0
  374. data/ext/protoc/protobuf/src/google/protobuf/repeated_field.h +1603 -0
  375. data/ext/protoc/protobuf/src/google/protobuf/repeated_field_reflection_unittest.cc +195 -0
  376. data/ext/protoc/protobuf/src/google/protobuf/repeated_field_unittest.cc +1442 -0
  377. data/ext/protoc/protobuf/src/google/protobuf/service.cc +46 -0
  378. data/ext/protoc/protobuf/src/google/protobuf/service.h +291 -0
  379. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops.h +227 -0
  380. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_arm64_gcc.h +325 -0
  381. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_arm_gcc.h +151 -0
  382. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_arm_qnx.h +146 -0
  383. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_atomicword_compat.h +122 -0
  384. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_generic_gcc.h +137 -0
  385. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_macosx.h +225 -0
  386. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_mips_gcc.h +313 -0
  387. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_pnacl.h +73 -0
  388. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_solaris.h +188 -0
  389. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_tsan.h +219 -0
  390. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_x86_gcc.cc +137 -0
  391. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_x86_gcc.h +293 -0
  392. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_x86_msvc.cc +112 -0
  393. data/ext/protoc/protobuf/src/google/protobuf/stubs/atomicops_internals_x86_msvc.h +150 -0
  394. data/ext/protoc/protobuf/src/google/protobuf/stubs/common.cc +395 -0
  395. data/ext/protoc/protobuf/src/google/protobuf/stubs/common.h +1226 -0
  396. data/ext/protoc/protobuf/src/google/protobuf/stubs/common_unittest.cc +357 -0
  397. data/ext/protoc/protobuf/src/google/protobuf/stubs/hash.h +232 -0
  398. data/ext/protoc/protobuf/src/google/protobuf/stubs/map_util.h +771 -0
  399. data/ext/protoc/protobuf/src/google/protobuf/stubs/once.cc +99 -0
  400. data/ext/protoc/protobuf/src/google/protobuf/stubs/once.h +166 -0
  401. data/ext/protoc/protobuf/src/google/protobuf/stubs/once_unittest.cc +253 -0
  402. data/ext/protoc/protobuf/src/google/protobuf/stubs/platform_macros.h +103 -0
  403. data/ext/protoc/protobuf/src/google/protobuf/stubs/shared_ptr.h +470 -0
  404. data/ext/protoc/protobuf/src/google/protobuf/stubs/stl_util.h +121 -0
  405. data/ext/protoc/protobuf/src/google/protobuf/stubs/stringprintf.cc +175 -0
  406. data/ext/protoc/protobuf/src/google/protobuf/stubs/stringprintf.h +76 -0
  407. data/ext/protoc/protobuf/src/google/protobuf/stubs/stringprintf_unittest.cc +152 -0
  408. data/ext/protoc/protobuf/src/google/protobuf/stubs/structurally_valid.cc +536 -0
  409. data/ext/protoc/protobuf/src/google/protobuf/stubs/structurally_valid_unittest.cc +40 -0
  410. data/ext/protoc/protobuf/src/google/protobuf/stubs/strutil.cc +1279 -0
  411. data/ext/protoc/protobuf/src/google/protobuf/stubs/strutil.h +562 -0
  412. data/ext/protoc/protobuf/src/google/protobuf/stubs/strutil_unittest.cc +73 -0
  413. data/ext/protoc/protobuf/src/google/protobuf/stubs/substitute.cc +134 -0
  414. data/ext/protoc/protobuf/src/google/protobuf/stubs/substitute.h +170 -0
  415. data/ext/protoc/protobuf/src/google/protobuf/stubs/template_util.h +138 -0
  416. data/ext/protoc/protobuf/src/google/protobuf/stubs/template_util_unittest.cc +130 -0
  417. data/ext/protoc/protobuf/src/google/protobuf/stubs/type_traits.h +336 -0
  418. data/ext/protoc/protobuf/src/google/protobuf/stubs/type_traits_unittest.cc +628 -0
  419. data/ext/protoc/protobuf/src/google/protobuf/test_util.cc +3345 -0
  420. data/ext/protoc/protobuf/src/google/protobuf/test_util.h +215 -0
  421. data/ext/protoc/protobuf/src/google/protobuf/test_util_lite.cc +1585 -0
  422. data/ext/protoc/protobuf/src/google/protobuf/test_util_lite.h +101 -0
  423. data/ext/protoc/protobuf/src/google/protobuf/testdata/bad_utf8_string +1 -0
  424. data/ext/protoc/protobuf/src/google/protobuf/testdata/golden_message +0 -0
  425. data/ext/protoc/protobuf/src/google/protobuf/testdata/golden_message_oneof_implemented +0 -0
  426. data/ext/protoc/protobuf/src/google/protobuf/testdata/golden_packed_fields_message +0 -0
  427. data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_data.txt +134 -0
  428. data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_data_oneof_implemented.txt +129 -0
  429. data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_data_pointy.txt +134 -0
  430. data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_data_pointy_oneof.txt +129 -0
  431. data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_extensions_data.txt +134 -0
  432. data/ext/protoc/protobuf/src/google/protobuf/testdata/text_format_unittest_extensions_data_pointy.txt +134 -0
  433. data/ext/protoc/protobuf/src/google/protobuf/testing/file.cc +194 -0
  434. data/ext/protoc/protobuf/src/google/protobuf/testing/file.h +97 -0
  435. data/ext/protoc/protobuf/src/google/protobuf/testing/googletest.cc +255 -0
  436. data/ext/protoc/protobuf/src/google/protobuf/testing/googletest.h +102 -0
  437. data/ext/protoc/protobuf/src/google/protobuf/testing/zcgunzip.cc +73 -0
  438. data/ext/protoc/protobuf/src/google/protobuf/testing/zcgzip.cc +79 -0
  439. data/ext/protoc/protobuf/src/google/protobuf/text_format.cc +1746 -0
  440. data/ext/protoc/protobuf/src/google/protobuf/text_format.h +473 -0
  441. data/ext/protoc/protobuf/src/google/protobuf/text_format_unittest.cc +1479 -0
  442. data/ext/protoc/protobuf/src/google/protobuf/unittest.proto +861 -0
  443. data/ext/protoc/protobuf/src/google/protobuf/unittest_custom_options.proto +393 -0
  444. data/ext/protoc/protobuf/src/google/protobuf/unittest_embed_optimize_for.proto +50 -0
  445. data/ext/protoc/protobuf/src/google/protobuf/unittest_empty.proto +37 -0
  446. data/ext/protoc/protobuf/src/google/protobuf/unittest_enormous_descriptor.proto +1046 -0
  447. data/ext/protoc/protobuf/src/google/protobuf/unittest_import.proto +64 -0
  448. data/ext/protoc/protobuf/src/google/protobuf/unittest_import_lite.proto +51 -0
  449. data/ext/protoc/protobuf/src/google/protobuf/unittest_import_public.proto +40 -0
  450. data/ext/protoc/protobuf/src/google/protobuf/unittest_import_public_lite.proto +42 -0
  451. data/ext/protoc/protobuf/src/google/protobuf/unittest_lite.proto +384 -0
  452. data/ext/protoc/protobuf/src/google/protobuf/unittest_lite_imports_nonlite.proto +43 -0
  453. data/ext/protoc/protobuf/src/google/protobuf/unittest_mset.proto +83 -0
  454. data/ext/protoc/protobuf/src/google/protobuf/unittest_no_generic_services.proto +53 -0
  455. data/ext/protoc/protobuf/src/google/protobuf/unittest_optimize_for.proto +66 -0
  456. data/ext/protoc/protobuf/src/google/protobuf/unknown_field_set.cc +265 -0
  457. data/ext/protoc/protobuf/src/google/protobuf/unknown_field_set.h +318 -0
  458. data/ext/protoc/protobuf/src/google/protobuf/unknown_field_set_unittest.cc +599 -0
  459. data/ext/protoc/protobuf/src/google/protobuf/wire_format.cc +1101 -0
  460. data/ext/protoc/protobuf/src/google/protobuf/wire_format.h +336 -0
  461. data/ext/protoc/protobuf/src/google/protobuf/wire_format_lite.cc +471 -0
  462. data/ext/protoc/protobuf/src/google/protobuf/wire_format_lite.h +661 -0
  463. data/ext/protoc/protobuf/src/google/protobuf/wire_format_lite_inl.h +860 -0
  464. data/ext/protoc/protobuf/src/google/protobuf/wire_format_unittest.cc +1120 -0
  465. data/ext/protoc/protobuf/src/solaris/libstdc++.la +51 -0
  466. data/ext/protoc/protobuf/vsprojects/config.h +29 -0
  467. data/ext/protoc/protobuf/vsprojects/convert2008to2005.sh +20 -0
  468. data/ext/protoc/protobuf/vsprojects/extract_includes.bat +50 -0
  469. data/ext/protoc/protobuf/vsprojects/libprotobuf-lite.vcproj +302 -0
  470. data/ext/protoc/protobuf/vsprojects/libprotobuf.vcproj +470 -0
  471. data/ext/protoc/protobuf/vsprojects/libprotoc.vcproj +466 -0
  472. data/ext/protoc/protobuf/vsprojects/lite-test.vcproj +305 -0
  473. data/ext/protoc/protobuf/vsprojects/protobuf.sln +92 -0
  474. data/ext/protoc/protobuf/vsprojects/protoc.vcproj +192 -0
  475. data/ext/protoc/protobuf/vsprojects/readme.txt +114 -0
  476. data/ext/protoc/protobuf/vsprojects/test_plugin.vcproj +209 -0
  477. data/ext/protoc/protobuf/vsprojects/tests.vcproj +681 -0
  478. data/lib/protoc/version.rb +1 -1
  479. 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)