protoc 2.6.1.1 → 2.6.1.2

Sign up to get free protection for your applications and to get access to all the features.
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)