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,163 @@
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
+ package com.google.protobuf;
32
+
33
+ /**
34
+ * This class is used internally by the Protocol Buffer library and generated
35
+ * message implementations. It is public only because those generated messages
36
+ * do not reside in the {@code protobuf} package. Others should not use this
37
+ * class directly.
38
+ *
39
+ * This class contains constants and helper functions useful for dealing with
40
+ * the Protocol Buffer wire format.
41
+ *
42
+ * @author kenton@google.com Kenton Varda
43
+ */
44
+ public final class WireFormat {
45
+ // Do not allow instantiation.
46
+ private WireFormat() {}
47
+
48
+ public static final int WIRETYPE_VARINT = 0;
49
+ public static final int WIRETYPE_FIXED64 = 1;
50
+ public static final int WIRETYPE_LENGTH_DELIMITED = 2;
51
+ public static final int WIRETYPE_START_GROUP = 3;
52
+ public static final int WIRETYPE_END_GROUP = 4;
53
+ public static final int WIRETYPE_FIXED32 = 5;
54
+
55
+ static final int TAG_TYPE_BITS = 3;
56
+ static final int TAG_TYPE_MASK = (1 << TAG_TYPE_BITS) - 1;
57
+
58
+ /** Given a tag value, determines the wire type (the lower 3 bits). */
59
+ static int getTagWireType(final int tag) {
60
+ return tag & TAG_TYPE_MASK;
61
+ }
62
+
63
+ /** Given a tag value, determines the field number (the upper 29 bits). */
64
+ public static int getTagFieldNumber(final int tag) {
65
+ return tag >>> TAG_TYPE_BITS;
66
+ }
67
+
68
+ /** Makes a tag value given a field number and wire type. */
69
+ static int makeTag(final int fieldNumber, final int wireType) {
70
+ return (fieldNumber << TAG_TYPE_BITS) | wireType;
71
+ }
72
+
73
+ /**
74
+ * Lite equivalent to {@link Descriptors.FieldDescriptor.JavaType}. This is
75
+ * only here to support the lite runtime and should not be used by users.
76
+ */
77
+ public enum JavaType {
78
+ INT(0),
79
+ LONG(0L),
80
+ FLOAT(0F),
81
+ DOUBLE(0D),
82
+ BOOLEAN(false),
83
+ STRING(""),
84
+ BYTE_STRING(ByteString.EMPTY),
85
+ ENUM(null),
86
+ MESSAGE(null);
87
+
88
+ JavaType(final Object defaultDefault) {
89
+ this.defaultDefault = defaultDefault;
90
+ }
91
+
92
+ /**
93
+ * The default default value for fields of this type, if it's a primitive
94
+ * type.
95
+ */
96
+ Object getDefaultDefault() {
97
+ return defaultDefault;
98
+ }
99
+
100
+ private final Object defaultDefault;
101
+ }
102
+
103
+ /**
104
+ * Lite equivalent to {@link Descriptors.FieldDescriptor.Type}. This is
105
+ * only here to support the lite runtime and should not be used by users.
106
+ */
107
+ public enum FieldType {
108
+ DOUBLE (JavaType.DOUBLE , WIRETYPE_FIXED64 ),
109
+ FLOAT (JavaType.FLOAT , WIRETYPE_FIXED32 ),
110
+ INT64 (JavaType.LONG , WIRETYPE_VARINT ),
111
+ UINT64 (JavaType.LONG , WIRETYPE_VARINT ),
112
+ INT32 (JavaType.INT , WIRETYPE_VARINT ),
113
+ FIXED64 (JavaType.LONG , WIRETYPE_FIXED64 ),
114
+ FIXED32 (JavaType.INT , WIRETYPE_FIXED32 ),
115
+ BOOL (JavaType.BOOLEAN , WIRETYPE_VARINT ),
116
+ STRING (JavaType.STRING , WIRETYPE_LENGTH_DELIMITED) {
117
+ public boolean isPackable() { return false; }
118
+ },
119
+ GROUP (JavaType.MESSAGE , WIRETYPE_START_GROUP ) {
120
+ public boolean isPackable() { return false; }
121
+ },
122
+ MESSAGE (JavaType.MESSAGE , WIRETYPE_LENGTH_DELIMITED) {
123
+ public boolean isPackable() { return false; }
124
+ },
125
+ BYTES (JavaType.BYTE_STRING, WIRETYPE_LENGTH_DELIMITED) {
126
+ public boolean isPackable() { return false; }
127
+ },
128
+ UINT32 (JavaType.INT , WIRETYPE_VARINT ),
129
+ ENUM (JavaType.ENUM , WIRETYPE_VARINT ),
130
+ SFIXED32(JavaType.INT , WIRETYPE_FIXED32 ),
131
+ SFIXED64(JavaType.LONG , WIRETYPE_FIXED64 ),
132
+ SINT32 (JavaType.INT , WIRETYPE_VARINT ),
133
+ SINT64 (JavaType.LONG , WIRETYPE_VARINT );
134
+
135
+ FieldType(final JavaType javaType, final int wireType) {
136
+ this.javaType = javaType;
137
+ this.wireType = wireType;
138
+ }
139
+
140
+ private final JavaType javaType;
141
+ private final int wireType;
142
+
143
+ public JavaType getJavaType() { return javaType; }
144
+ public int getWireType() { return wireType; }
145
+
146
+ public boolean isPackable() { return true; }
147
+ }
148
+
149
+ // Field numbers for fields in MessageSet wire format.
150
+ static final int MESSAGE_SET_ITEM = 1;
151
+ static final int MESSAGE_SET_TYPE_ID = 2;
152
+ static final int MESSAGE_SET_MESSAGE = 3;
153
+
154
+ // Tag numbers.
155
+ static final int MESSAGE_SET_ITEM_TAG =
156
+ makeTag(MESSAGE_SET_ITEM, WIRETYPE_START_GROUP);
157
+ static final int MESSAGE_SET_ITEM_END_TAG =
158
+ makeTag(MESSAGE_SET_ITEM, WIRETYPE_END_GROUP);
159
+ static final int MESSAGE_SET_TYPE_ID_TAG =
160
+ makeTag(MESSAGE_SET_TYPE_ID, WIRETYPE_VARINT);
161
+ static final int MESSAGE_SET_MESSAGE_TAG =
162
+ makeTag(MESSAGE_SET_MESSAGE, WIRETYPE_LENGTH_DELIMITED);
163
+ }
@@ -0,0 +1,527 @@
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
+ package com.google.protobuf;
32
+
33
+ import com.google.protobuf.Descriptors.FieldDescriptor;
34
+ import protobuf_unittest.UnittestOptimizeFor.TestOptimizedForSize;
35
+ import protobuf_unittest.UnittestProto;
36
+ import protobuf_unittest.UnittestProto.ForeignMessage;
37
+ import protobuf_unittest.UnittestProto.TestAllExtensions;
38
+ import protobuf_unittest.UnittestProto.TestAllTypes;
39
+ import protobuf_unittest.UnittestProto.TestPackedTypes;
40
+ import protobuf_unittest.UnittestProto.TestRequired;
41
+ import protobuf_unittest.UnittestProto.TestRequiredForeign;
42
+ import protobuf_unittest.UnittestProto.TestUnpackedTypes;
43
+
44
+ import junit.framework.TestCase;
45
+
46
+ import java.util.Map;
47
+
48
+ /**
49
+ * Unit test for {@link AbstractMessage}.
50
+ *
51
+ * @author kenton@google.com Kenton Varda
52
+ */
53
+ public class AbstractMessageTest extends TestCase {
54
+ /**
55
+ * Extends AbstractMessage and wraps some other message object. The methods
56
+ * of the Message interface which aren't explicitly implemented by
57
+ * AbstractMessage are forwarded to the wrapped object. This allows us to
58
+ * test that AbstractMessage's implementations work even if the wrapped
59
+ * object does not use them.
60
+ */
61
+ private static class AbstractMessageWrapper extends AbstractMessage {
62
+ private final Message wrappedMessage;
63
+
64
+ public AbstractMessageWrapper(Message wrappedMessage) {
65
+ this.wrappedMessage = wrappedMessage;
66
+ }
67
+
68
+ public Descriptors.Descriptor getDescriptorForType() {
69
+ return wrappedMessage.getDescriptorForType();
70
+ }
71
+ public AbstractMessageWrapper getDefaultInstanceForType() {
72
+ return new AbstractMessageWrapper(
73
+ wrappedMessage.getDefaultInstanceForType());
74
+ }
75
+ public Map<Descriptors.FieldDescriptor, Object> getAllFields() {
76
+ return wrappedMessage.getAllFields();
77
+ }
78
+ public boolean hasField(Descriptors.FieldDescriptor field) {
79
+ return wrappedMessage.hasField(field);
80
+ }
81
+ public Object getField(Descriptors.FieldDescriptor field) {
82
+ return wrappedMessage.getField(field);
83
+ }
84
+ public int getRepeatedFieldCount(Descriptors.FieldDescriptor field) {
85
+ return wrappedMessage.getRepeatedFieldCount(field);
86
+ }
87
+ public Object getRepeatedField(
88
+ Descriptors.FieldDescriptor field, int index) {
89
+ return wrappedMessage.getRepeatedField(field, index);
90
+ }
91
+ public UnknownFieldSet getUnknownFields() {
92
+ return wrappedMessage.getUnknownFields();
93
+ }
94
+ public Builder newBuilderForType() {
95
+ return new Builder(wrappedMessage.newBuilderForType());
96
+ }
97
+ public Builder toBuilder() {
98
+ return new Builder(wrappedMessage.toBuilder());
99
+ }
100
+
101
+ static class Builder extends AbstractMessage.Builder<Builder> {
102
+ private final Message.Builder wrappedBuilder;
103
+
104
+ public Builder(Message.Builder wrappedBuilder) {
105
+ this.wrappedBuilder = wrappedBuilder;
106
+ }
107
+
108
+ public AbstractMessageWrapper build() {
109
+ return new AbstractMessageWrapper(wrappedBuilder.build());
110
+ }
111
+ public AbstractMessageWrapper buildPartial() {
112
+ return new AbstractMessageWrapper(wrappedBuilder.buildPartial());
113
+ }
114
+ public Builder clone() {
115
+ return new Builder(wrappedBuilder.clone());
116
+ }
117
+ public boolean isInitialized() {
118
+ return clone().buildPartial().isInitialized();
119
+ }
120
+ public Descriptors.Descriptor getDescriptorForType() {
121
+ return wrappedBuilder.getDescriptorForType();
122
+ }
123
+ public AbstractMessageWrapper getDefaultInstanceForType() {
124
+ return new AbstractMessageWrapper(
125
+ wrappedBuilder.getDefaultInstanceForType());
126
+ }
127
+ public Map<Descriptors.FieldDescriptor, Object> getAllFields() {
128
+ return wrappedBuilder.getAllFields();
129
+ }
130
+ public Builder newBuilderForField(Descriptors.FieldDescriptor field) {
131
+ return new Builder(wrappedBuilder.newBuilderForField(field));
132
+ }
133
+ public boolean hasField(Descriptors.FieldDescriptor field) {
134
+ return wrappedBuilder.hasField(field);
135
+ }
136
+ public Object getField(Descriptors.FieldDescriptor field) {
137
+ return wrappedBuilder.getField(field);
138
+ }
139
+ public Builder setField(Descriptors.FieldDescriptor field, Object value) {
140
+ wrappedBuilder.setField(field, value);
141
+ return this;
142
+ }
143
+ public Builder clearField(Descriptors.FieldDescriptor field) {
144
+ wrappedBuilder.clearField(field);
145
+ return this;
146
+ }
147
+ public int getRepeatedFieldCount(Descriptors.FieldDescriptor field) {
148
+ return wrappedBuilder.getRepeatedFieldCount(field);
149
+ }
150
+ public Object getRepeatedField(
151
+ Descriptors.FieldDescriptor field, int index) {
152
+ return wrappedBuilder.getRepeatedField(field, index);
153
+ }
154
+ public Builder setRepeatedField(Descriptors.FieldDescriptor field,
155
+ int index, Object value) {
156
+ wrappedBuilder.setRepeatedField(field, index, value);
157
+ return this;
158
+ }
159
+ public Builder addRepeatedField(
160
+ Descriptors.FieldDescriptor field, Object value) {
161
+ wrappedBuilder.addRepeatedField(field, value);
162
+ return this;
163
+ }
164
+ public UnknownFieldSet getUnknownFields() {
165
+ return wrappedBuilder.getUnknownFields();
166
+ }
167
+ public Builder setUnknownFields(UnknownFieldSet unknownFields) {
168
+ wrappedBuilder.setUnknownFields(unknownFields);
169
+ return this;
170
+ }
171
+ @Override
172
+ public Message.Builder getFieldBuilder(FieldDescriptor field) {
173
+ return wrappedBuilder.getFieldBuilder(field);
174
+ }
175
+ }
176
+ public Parser<? extends Message> getParserForType() {
177
+ return wrappedMessage.getParserForType();
178
+ }
179
+ }
180
+
181
+ // =================================================================
182
+
183
+ TestUtil.ReflectionTester reflectionTester =
184
+ new TestUtil.ReflectionTester(TestAllTypes.getDescriptor(), null);
185
+
186
+ TestUtil.ReflectionTester extensionsReflectionTester =
187
+ new TestUtil.ReflectionTester(TestAllExtensions.getDescriptor(),
188
+ TestUtil.getExtensionRegistry());
189
+
190
+ public void testClear() throws Exception {
191
+ AbstractMessageWrapper message =
192
+ new AbstractMessageWrapper.Builder(
193
+ TestAllTypes.newBuilder(TestUtil.getAllSet()))
194
+ .clear().build();
195
+ TestUtil.assertClear((TestAllTypes) message.wrappedMessage);
196
+ }
197
+
198
+ public void testCopy() throws Exception {
199
+ AbstractMessageWrapper message =
200
+ new AbstractMessageWrapper.Builder(TestAllTypes.newBuilder())
201
+ .mergeFrom(TestUtil.getAllSet()).build();
202
+ TestUtil.assertAllFieldsSet((TestAllTypes) message.wrappedMessage);
203
+ }
204
+
205
+ public void testSerializedSize() throws Exception {
206
+ TestAllTypes message = TestUtil.getAllSet();
207
+ Message abstractMessage = new AbstractMessageWrapper(TestUtil.getAllSet());
208
+
209
+ assertEquals(message.getSerializedSize(),
210
+ abstractMessage.getSerializedSize());
211
+ }
212
+
213
+ public void testSerialization() throws Exception {
214
+ Message abstractMessage = new AbstractMessageWrapper(TestUtil.getAllSet());
215
+
216
+ TestUtil.assertAllFieldsSet(
217
+ TestAllTypes.parseFrom(abstractMessage.toByteString()));
218
+
219
+ assertEquals(TestUtil.getAllSet().toByteString(),
220
+ abstractMessage.toByteString());
221
+ }
222
+
223
+ public void testParsing() throws Exception {
224
+ AbstractMessageWrapper.Builder builder =
225
+ new AbstractMessageWrapper.Builder(TestAllTypes.newBuilder());
226
+ AbstractMessageWrapper message =
227
+ builder.mergeFrom(TestUtil.getAllSet().toByteString()).build();
228
+ TestUtil.assertAllFieldsSet((TestAllTypes) message.wrappedMessage);
229
+ }
230
+
231
+ public void testParsingUninitialized() throws Exception {
232
+ TestRequiredForeign.Builder builder = TestRequiredForeign.newBuilder();
233
+ builder.getOptionalMessageBuilder().setDummy2(10);
234
+ ByteString bytes = builder.buildPartial().toByteString();
235
+ Message.Builder abstractMessageBuilder =
236
+ new AbstractMessageWrapper.Builder(TestRequiredForeign.newBuilder());
237
+ // mergeFrom() should not throw initialization error.
238
+ abstractMessageBuilder.mergeFrom(bytes).buildPartial();
239
+ try {
240
+ abstractMessageBuilder.mergeFrom(bytes).build();
241
+ fail();
242
+ } catch (UninitializedMessageException ex) {
243
+ // pass
244
+ }
245
+
246
+ // test DynamicMessage directly.
247
+ Message.Builder dynamicMessageBuilder = DynamicMessage.newBuilder(
248
+ TestRequiredForeign.getDescriptor());
249
+ // mergeFrom() should not throw initialization error.
250
+ dynamicMessageBuilder.mergeFrom(bytes).buildPartial();
251
+ try {
252
+ dynamicMessageBuilder.mergeFrom(bytes).build();
253
+ fail();
254
+ } catch (UninitializedMessageException ex) {
255
+ // pass
256
+ }
257
+ }
258
+
259
+ public void testPackedSerialization() throws Exception {
260
+ Message abstractMessage =
261
+ new AbstractMessageWrapper(TestUtil.getPackedSet());
262
+
263
+ TestUtil.assertPackedFieldsSet(
264
+ TestPackedTypes.parseFrom(abstractMessage.toByteString()));
265
+
266
+ assertEquals(TestUtil.getPackedSet().toByteString(),
267
+ abstractMessage.toByteString());
268
+ }
269
+
270
+ public void testPackedParsing() throws Exception {
271
+ AbstractMessageWrapper.Builder builder =
272
+ new AbstractMessageWrapper.Builder(TestPackedTypes.newBuilder());
273
+ AbstractMessageWrapper message =
274
+ builder.mergeFrom(TestUtil.getPackedSet().toByteString()).build();
275
+ TestUtil.assertPackedFieldsSet((TestPackedTypes) message.wrappedMessage);
276
+ }
277
+
278
+ public void testUnpackedSerialization() throws Exception {
279
+ Message abstractMessage =
280
+ new AbstractMessageWrapper(TestUtil.getUnpackedSet());
281
+
282
+ TestUtil.assertUnpackedFieldsSet(
283
+ TestUnpackedTypes.parseFrom(abstractMessage.toByteString()));
284
+
285
+ assertEquals(TestUtil.getUnpackedSet().toByteString(),
286
+ abstractMessage.toByteString());
287
+ }
288
+
289
+ public void testParsePackedToUnpacked() throws Exception {
290
+ AbstractMessageWrapper.Builder builder =
291
+ new AbstractMessageWrapper.Builder(TestUnpackedTypes.newBuilder());
292
+ AbstractMessageWrapper message =
293
+ builder.mergeFrom(TestUtil.getPackedSet().toByteString()).build();
294
+ TestUtil.assertUnpackedFieldsSet(
295
+ (TestUnpackedTypes) message.wrappedMessage);
296
+ }
297
+
298
+ public void testParseUnpackedToPacked() throws Exception {
299
+ AbstractMessageWrapper.Builder builder =
300
+ new AbstractMessageWrapper.Builder(TestPackedTypes.newBuilder());
301
+ AbstractMessageWrapper message =
302
+ builder.mergeFrom(TestUtil.getUnpackedSet().toByteString()).build();
303
+ TestUtil.assertPackedFieldsSet((TestPackedTypes) message.wrappedMessage);
304
+ }
305
+
306
+ public void testUnpackedParsing() throws Exception {
307
+ AbstractMessageWrapper.Builder builder =
308
+ new AbstractMessageWrapper.Builder(TestUnpackedTypes.newBuilder());
309
+ AbstractMessageWrapper message =
310
+ builder.mergeFrom(TestUtil.getUnpackedSet().toByteString()).build();
311
+ TestUtil.assertUnpackedFieldsSet(
312
+ (TestUnpackedTypes) message.wrappedMessage);
313
+ }
314
+
315
+ public void testOptimizedForSize() throws Exception {
316
+ // We're mostly only checking that this class was compiled successfully.
317
+ TestOptimizedForSize message =
318
+ TestOptimizedForSize.newBuilder().setI(1).build();
319
+ message = TestOptimizedForSize.parseFrom(message.toByteString());
320
+ assertEquals(2, message.getSerializedSize());
321
+ }
322
+
323
+ // -----------------------------------------------------------------
324
+ // Tests for isInitialized().
325
+
326
+ private static final TestRequired TEST_REQUIRED_UNINITIALIZED =
327
+ TestRequired.getDefaultInstance();
328
+ private static final TestRequired TEST_REQUIRED_INITIALIZED =
329
+ TestRequired.newBuilder().setA(1).setB(2).setC(3).build();
330
+
331
+ public void testIsInitialized() throws Exception {
332
+ TestRequired.Builder builder = TestRequired.newBuilder();
333
+ AbstractMessageWrapper.Builder abstractBuilder =
334
+ new AbstractMessageWrapper.Builder(builder);
335
+
336
+ assertFalse(abstractBuilder.isInitialized());
337
+ assertEquals("a, b, c", abstractBuilder.getInitializationErrorString());
338
+ builder.setA(1);
339
+ assertFalse(abstractBuilder.isInitialized());
340
+ assertEquals("b, c", abstractBuilder.getInitializationErrorString());
341
+ builder.setB(1);
342
+ assertFalse(abstractBuilder.isInitialized());
343
+ assertEquals("c", abstractBuilder.getInitializationErrorString());
344
+ builder.setC(1);
345
+ assertTrue(abstractBuilder.isInitialized());
346
+ assertEquals("", abstractBuilder.getInitializationErrorString());
347
+ }
348
+
349
+ public void testForeignIsInitialized() throws Exception {
350
+ TestRequiredForeign.Builder builder = TestRequiredForeign.newBuilder();
351
+ AbstractMessageWrapper.Builder abstractBuilder =
352
+ new AbstractMessageWrapper.Builder(builder);
353
+
354
+ assertTrue(abstractBuilder.isInitialized());
355
+ assertEquals("", abstractBuilder.getInitializationErrorString());
356
+
357
+ builder.setOptionalMessage(TEST_REQUIRED_UNINITIALIZED);
358
+ assertFalse(abstractBuilder.isInitialized());
359
+ assertEquals(
360
+ "optional_message.a, optional_message.b, optional_message.c",
361
+ abstractBuilder.getInitializationErrorString());
362
+
363
+ builder.setOptionalMessage(TEST_REQUIRED_INITIALIZED);
364
+ assertTrue(abstractBuilder.isInitialized());
365
+ assertEquals("", abstractBuilder.getInitializationErrorString());
366
+
367
+ builder.addRepeatedMessage(TEST_REQUIRED_UNINITIALIZED);
368
+ assertFalse(abstractBuilder.isInitialized());
369
+ assertEquals(
370
+ "repeated_message[0].a, repeated_message[0].b, repeated_message[0].c",
371
+ abstractBuilder.getInitializationErrorString());
372
+
373
+ builder.setRepeatedMessage(0, TEST_REQUIRED_INITIALIZED);
374
+ assertTrue(abstractBuilder.isInitialized());
375
+ assertEquals("", abstractBuilder.getInitializationErrorString());
376
+ }
377
+
378
+ // -----------------------------------------------------------------
379
+ // Tests for mergeFrom
380
+
381
+ static final TestAllTypes MERGE_SOURCE =
382
+ TestAllTypes.newBuilder()
383
+ .setOptionalInt32(1)
384
+ .setOptionalString("foo")
385
+ .setOptionalForeignMessage(ForeignMessage.getDefaultInstance())
386
+ .addRepeatedString("bar")
387
+ .build();
388
+
389
+ static final TestAllTypes MERGE_DEST =
390
+ TestAllTypes.newBuilder()
391
+ .setOptionalInt64(2)
392
+ .setOptionalString("baz")
393
+ .setOptionalForeignMessage(ForeignMessage.newBuilder().setC(3).build())
394
+ .addRepeatedString("qux")
395
+ .build();
396
+
397
+ static final String MERGE_RESULT_TEXT =
398
+ "optional_int32: 1\n" +
399
+ "optional_int64: 2\n" +
400
+ "optional_string: \"foo\"\n" +
401
+ "optional_foreign_message {\n" +
402
+ " c: 3\n" +
403
+ "}\n" +
404
+ "repeated_string: \"qux\"\n" +
405
+ "repeated_string: \"bar\"\n";
406
+
407
+ public void testMergeFrom() throws Exception {
408
+ AbstractMessageWrapper result =
409
+ new AbstractMessageWrapper.Builder(
410
+ TestAllTypes.newBuilder(MERGE_DEST))
411
+ .mergeFrom(MERGE_SOURCE).build();
412
+
413
+ assertEquals(MERGE_RESULT_TEXT, result.toString());
414
+ }
415
+
416
+ // -----------------------------------------------------------------
417
+ // Tests for equals and hashCode
418
+
419
+ public void testEqualsAndHashCode() throws Exception {
420
+ TestAllTypes a = TestUtil.getAllSet();
421
+ TestAllTypes b = TestAllTypes.newBuilder().build();
422
+ TestAllTypes c = TestAllTypes.newBuilder(b).addRepeatedString("x").build();
423
+ TestAllTypes d = TestAllTypes.newBuilder(c).addRepeatedString("y").build();
424
+ TestAllExtensions e = TestUtil.getAllExtensionsSet();
425
+ TestAllExtensions f = TestAllExtensions.newBuilder(e)
426
+ .addExtension(UnittestProto.repeatedInt32Extension, 999).build();
427
+
428
+ checkEqualsIsConsistent(a);
429
+ checkEqualsIsConsistent(b);
430
+ checkEqualsIsConsistent(c);
431
+ checkEqualsIsConsistent(d);
432
+ checkEqualsIsConsistent(e);
433
+ checkEqualsIsConsistent(f);
434
+
435
+ checkNotEqual(a, b);
436
+ checkNotEqual(a, c);
437
+ checkNotEqual(a, d);
438
+ checkNotEqual(a, e);
439
+ checkNotEqual(a, f);
440
+
441
+ checkNotEqual(b, c);
442
+ checkNotEqual(b, d);
443
+ checkNotEqual(b, e);
444
+ checkNotEqual(b, f);
445
+
446
+ checkNotEqual(c, d);
447
+ checkNotEqual(c, e);
448
+ checkNotEqual(c, f);
449
+
450
+ checkNotEqual(d, e);
451
+ checkNotEqual(d, f);
452
+
453
+ checkNotEqual(e, f);
454
+
455
+ // Deserializing into the TestEmptyMessage such that every field
456
+ // is an {@link UnknownFieldSet.Field}.
457
+ UnittestProto.TestEmptyMessage eUnknownFields =
458
+ UnittestProto.TestEmptyMessage.parseFrom(e.toByteArray());
459
+ UnittestProto.TestEmptyMessage fUnknownFields =
460
+ UnittestProto.TestEmptyMessage.parseFrom(f.toByteArray());
461
+ checkNotEqual(eUnknownFields, fUnknownFields);
462
+ checkEqualsIsConsistent(eUnknownFields);
463
+ checkEqualsIsConsistent(fUnknownFields);
464
+
465
+ // Subsequent reconstitutions should be identical
466
+ UnittestProto.TestEmptyMessage eUnknownFields2 =
467
+ UnittestProto.TestEmptyMessage.parseFrom(e.toByteArray());
468
+ checkEqualsIsConsistent(eUnknownFields, eUnknownFields2);
469
+ }
470
+
471
+
472
+ /**
473
+ * Asserts that the given proto has symmetric equals and hashCode methods.
474
+ */
475
+ private void checkEqualsIsConsistent(Message message) {
476
+ // Object should be equal to itself.
477
+ assertEquals(message, message);
478
+
479
+ // Object should be equal to a dynamic copy of itself.
480
+ DynamicMessage dynamic = DynamicMessage.newBuilder(message).build();
481
+ checkEqualsIsConsistent(message, dynamic);
482
+ }
483
+
484
+ /**
485
+ * Asserts that the given protos are equal and have the same hash code.
486
+ */
487
+ private void checkEqualsIsConsistent(Message message1, Message message2) {
488
+ assertEquals(message1, message2);
489
+ assertEquals(message2, message1);
490
+ assertEquals(message2.hashCode(), message1.hashCode());
491
+ }
492
+
493
+ /**
494
+ * Asserts that the given protos are not equal and have different hash codes.
495
+ *
496
+ * @warning It's valid for non-equal objects to have the same hash code, so
497
+ * this test is stricter than it needs to be. However, this should happen
498
+ * relatively rarely.
499
+ */
500
+ private void checkNotEqual(Message m1, Message m2) {
501
+ String equalsError = String.format("%s should not be equal to %s", m1, m2);
502
+ assertFalse(equalsError, m1.equals(m2));
503
+ assertFalse(equalsError, m2.equals(m1));
504
+
505
+ assertFalse(
506
+ String.format("%s should have a different hash code from %s", m1, m2),
507
+ m1.hashCode() == m2.hashCode());
508
+ }
509
+
510
+ public void testCheckByteStringIsUtf8OnUtf8() {
511
+ ByteString byteString = ByteString.copyFromUtf8("some text");
512
+ AbstractMessageLite.checkByteStringIsUtf8(byteString);
513
+ // No exception thrown.
514
+ }
515
+
516
+ public void testCheckByteStringIsUtf8OnNonUtf8() {
517
+ ByteString byteString =
518
+ ByteString.copyFrom(new byte[]{(byte) 0x80}); // A lone continuation byte.
519
+ try {
520
+ AbstractMessageLite.checkByteStringIsUtf8(byteString);
521
+ fail("Expected AbstractMessageLite.checkByteStringIsUtf8 to throw IllegalArgumentException");
522
+ } catch (IllegalArgumentException exception) {
523
+ assertEquals("Byte string is not UTF-8.", exception.getMessage());
524
+ }
525
+ }
526
+
527
+ }