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,737 @@
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
+ // Author: kenton@google.com (Kenton Varda)
32
+ // Based on original Protocol Buffers design by
33
+ // Sanjay Ghemawat, Jeff Dean, and others.
34
+
35
+ #include <algorithm>
36
+ #include <google/protobuf/stubs/hash.h>
37
+ #include <limits>
38
+ #include <vector>
39
+
40
+ #include <google/protobuf/compiler/java/java_helpers.h>
41
+ #include <google/protobuf/compiler/java/java_name_resolver.h>
42
+ #include <google/protobuf/descriptor.pb.h>
43
+ #include <google/protobuf/wire_format.h>
44
+ #include <google/protobuf/stubs/strutil.h>
45
+ #include <google/protobuf/stubs/substitute.h>
46
+
47
+ namespace google {
48
+ namespace protobuf {
49
+ namespace compiler {
50
+ namespace java {
51
+
52
+ using internal::WireFormat;
53
+ using internal::WireFormatLite;
54
+
55
+ const char kThickSeparator[] =
56
+ "// ===================================================================\n";
57
+ const char kThinSeparator[] =
58
+ "// -------------------------------------------------------------------\n";
59
+
60
+ namespace {
61
+
62
+ const char* kDefaultPackage = "";
63
+
64
+ // Names that should be avoided as field names.
65
+ // Using them will cause the compiler to generate accessors whose names are
66
+ // colliding with methods defined in base classes.
67
+ const char* kForbiddenWordList[] = {
68
+ // message base class:
69
+ "cached_size", "serialized_size",
70
+ // java.lang.Object:
71
+ "class",
72
+ };
73
+
74
+ bool IsForbidden(const string& field_name) {
75
+ for (int i = 0; i < GOOGLE_ARRAYSIZE(kForbiddenWordList); ++i) {
76
+ if (field_name == kForbiddenWordList[i]) {
77
+ return true;
78
+ }
79
+ }
80
+ return false;
81
+ }
82
+
83
+ string FieldName(const FieldDescriptor* field) {
84
+ string field_name;
85
+ // Groups are hacky: The name of the field is just the lower-cased name
86
+ // of the group type. In Java, though, we would like to retain the original
87
+ // capitalization of the type name.
88
+ if (GetType(field) == FieldDescriptor::TYPE_GROUP) {
89
+ field_name = field->message_type()->name();
90
+ } else {
91
+ field_name = field->name();
92
+ }
93
+ if (IsForbidden(field_name)) {
94
+ // Append a trailing "#" to indicate that the name should be decorated to
95
+ // avoid collision with other names.
96
+ field_name += "#";
97
+ }
98
+ return field_name;
99
+ }
100
+
101
+
102
+ } // namespace
103
+
104
+ string UnderscoresToCamelCase(const string& input, bool cap_next_letter) {
105
+ string result;
106
+ // Note: I distrust ctype.h due to locales.
107
+ for (int i = 0; i < input.size(); i++) {
108
+ if ('a' <= input[i] && input[i] <= 'z') {
109
+ if (cap_next_letter) {
110
+ result += input[i] + ('A' - 'a');
111
+ } else {
112
+ result += input[i];
113
+ }
114
+ cap_next_letter = false;
115
+ } else if ('A' <= input[i] && input[i] <= 'Z') {
116
+ if (i == 0 && !cap_next_letter) {
117
+ // Force first letter to lower-case unless explicitly told to
118
+ // capitalize it.
119
+ result += input[i] + ('a' - 'A');
120
+ } else {
121
+ // Capital letters after the first are left as-is.
122
+ result += input[i];
123
+ }
124
+ cap_next_letter = false;
125
+ } else if ('0' <= input[i] && input[i] <= '9') {
126
+ result += input[i];
127
+ cap_next_letter = true;
128
+ } else {
129
+ cap_next_letter = true;
130
+ }
131
+ }
132
+ // Add a trailing "_" if the name should be altered.
133
+ if (input[input.size() - 1] == '#') {
134
+ result += '_';
135
+ }
136
+ return result;
137
+ }
138
+
139
+ string UnderscoresToCamelCase(const FieldDescriptor* field) {
140
+ return UnderscoresToCamelCase(FieldName(field), false);
141
+ }
142
+
143
+ string UnderscoresToCapitalizedCamelCase(const FieldDescriptor* field) {
144
+ return UnderscoresToCamelCase(FieldName(field), true);
145
+ }
146
+
147
+ string UnderscoresToCamelCase(const MethodDescriptor* method) {
148
+ return UnderscoresToCamelCase(method->name(), false);
149
+ }
150
+
151
+ string UniqueFileScopeIdentifier(const Descriptor* descriptor) {
152
+ return "static_" + StringReplace(descriptor->full_name(), ".", "_", true);
153
+ }
154
+
155
+ string StripProto(const string& filename) {
156
+ if (HasSuffixString(filename, ".protodevel")) {
157
+ return StripSuffixString(filename, ".protodevel");
158
+ } else {
159
+ return StripSuffixString(filename, ".proto");
160
+ }
161
+ }
162
+
163
+ string FileClassName(const FileDescriptor* file, bool immutable) {
164
+ ClassNameResolver name_resolver;
165
+ return name_resolver.GetFileClassName(file, immutable);
166
+ }
167
+
168
+ string FileJavaPackage(const FileDescriptor* file, bool immutable) {
169
+ string result;
170
+
171
+ if (file->options().has_java_package()) {
172
+ result = file->options().java_package();
173
+ } else {
174
+ result = kDefaultPackage;
175
+ if (!file->package().empty()) {
176
+ if (!result.empty()) result += '.';
177
+ result += file->package();
178
+ }
179
+ }
180
+
181
+ return result;
182
+ }
183
+
184
+ string JavaPackageToDir(string package_name) {
185
+ string package_dir =
186
+ StringReplace(package_name, ".", "/", true);
187
+ if (!package_dir.empty()) package_dir += "/";
188
+ return package_dir;
189
+ }
190
+
191
+ // TODO(xiaofeng): This function is only kept for it's publicly referenced.
192
+ // It should be removed after mutable API up-integration.
193
+ string ToJavaName(const string& full_name,
194
+ const FileDescriptor* file) {
195
+ string result;
196
+ if (file->options().java_multiple_files()) {
197
+ result = FileJavaPackage(file);
198
+ } else {
199
+ result = ClassName(file);
200
+ }
201
+ if (!result.empty()) {
202
+ result += '.';
203
+ }
204
+ if (file->package().empty()) {
205
+ result += full_name;
206
+ } else {
207
+ // Strip the proto package from full_name since we've replaced it with
208
+ // the Java package.
209
+ result += full_name.substr(file->package().size() + 1);
210
+ }
211
+ return result;
212
+ }
213
+
214
+ string ClassName(const Descriptor* descriptor) {
215
+ ClassNameResolver name_resolver;
216
+ return name_resolver.GetClassName(descriptor, true);
217
+ }
218
+
219
+ string ClassName(const EnumDescriptor* descriptor) {
220
+ ClassNameResolver name_resolver;
221
+ return name_resolver.GetClassName(descriptor, true);
222
+ }
223
+
224
+ string ClassName(const ServiceDescriptor* descriptor) {
225
+ ClassNameResolver name_resolver;
226
+ return name_resolver.GetClassName(descriptor, true);
227
+ }
228
+
229
+ string ClassName(const FileDescriptor* descriptor) {
230
+ ClassNameResolver name_resolver;
231
+ return name_resolver.GetClassName(descriptor, true);
232
+ }
233
+
234
+ string ExtraMessageInterfaces(const Descriptor* descriptor) {
235
+ string interfaces = "// @@protoc_insertion_point(message_implements:"
236
+ + descriptor->full_name() + ")";
237
+ return interfaces;
238
+ }
239
+
240
+
241
+ string ExtraBuilderInterfaces(const Descriptor* descriptor) {
242
+ string interfaces = "// @@protoc_insertion_point(builder_implements:"
243
+ + descriptor->full_name() + ")";
244
+ return interfaces;
245
+ }
246
+
247
+ string ExtraMessageOrBuilderInterfaces(const Descriptor* descriptor) {
248
+ string interfaces = "// @@protoc_insertion_point(interface_extends:"
249
+ + descriptor->full_name() + ")";
250
+ return interfaces;
251
+ }
252
+
253
+ string FieldConstantName(const FieldDescriptor *field) {
254
+ string name = field->name() + "_FIELD_NUMBER";
255
+ UpperString(&name);
256
+ return name;
257
+ }
258
+
259
+ FieldDescriptor::Type GetType(const FieldDescriptor* field) {
260
+ return field->type();
261
+ }
262
+
263
+ JavaType GetJavaType(const FieldDescriptor* field) {
264
+ switch (GetType(field)) {
265
+ case FieldDescriptor::TYPE_INT32:
266
+ case FieldDescriptor::TYPE_UINT32:
267
+ case FieldDescriptor::TYPE_SINT32:
268
+ case FieldDescriptor::TYPE_FIXED32:
269
+ case FieldDescriptor::TYPE_SFIXED32:
270
+ return JAVATYPE_INT;
271
+
272
+ case FieldDescriptor::TYPE_INT64:
273
+ case FieldDescriptor::TYPE_UINT64:
274
+ case FieldDescriptor::TYPE_SINT64:
275
+ case FieldDescriptor::TYPE_FIXED64:
276
+ case FieldDescriptor::TYPE_SFIXED64:
277
+ return JAVATYPE_LONG;
278
+
279
+ case FieldDescriptor::TYPE_FLOAT:
280
+ return JAVATYPE_FLOAT;
281
+
282
+ case FieldDescriptor::TYPE_DOUBLE:
283
+ return JAVATYPE_DOUBLE;
284
+
285
+ case FieldDescriptor::TYPE_BOOL:
286
+ return JAVATYPE_BOOLEAN;
287
+
288
+ case FieldDescriptor::TYPE_STRING:
289
+ return JAVATYPE_STRING;
290
+
291
+ case FieldDescriptor::TYPE_BYTES:
292
+ return JAVATYPE_BYTES;
293
+
294
+ case FieldDescriptor::TYPE_ENUM:
295
+ return JAVATYPE_ENUM;
296
+
297
+ case FieldDescriptor::TYPE_GROUP:
298
+ case FieldDescriptor::TYPE_MESSAGE:
299
+ return JAVATYPE_MESSAGE;
300
+
301
+ // No default because we want the compiler to complain if any new
302
+ // types are added.
303
+ }
304
+
305
+ GOOGLE_LOG(FATAL) << "Can't get here.";
306
+ return JAVATYPE_INT;
307
+ }
308
+
309
+ const char* BoxedPrimitiveTypeName(JavaType type) {
310
+ switch (type) {
311
+ case JAVATYPE_INT : return "java.lang.Integer";
312
+ case JAVATYPE_LONG : return "java.lang.Long";
313
+ case JAVATYPE_FLOAT : return "java.lang.Float";
314
+ case JAVATYPE_DOUBLE : return "java.lang.Double";
315
+ case JAVATYPE_BOOLEAN: return "java.lang.Boolean";
316
+ case JAVATYPE_STRING : return "java.lang.String";
317
+ case JAVATYPE_BYTES : return "com.google.protobuf.ByteString";
318
+ case JAVATYPE_ENUM : return NULL;
319
+ case JAVATYPE_MESSAGE: return NULL;
320
+
321
+ // No default because we want the compiler to complain if any new
322
+ // JavaTypes are added.
323
+ }
324
+
325
+ GOOGLE_LOG(FATAL) << "Can't get here.";
326
+ return NULL;
327
+ }
328
+
329
+ const char* FieldTypeName(FieldDescriptor::Type field_type) {
330
+ switch (field_type) {
331
+ case FieldDescriptor::TYPE_INT32 : return "INT32";
332
+ case FieldDescriptor::TYPE_UINT32 : return "UINT32";
333
+ case FieldDescriptor::TYPE_SINT32 : return "SINT32";
334
+ case FieldDescriptor::TYPE_FIXED32 : return "FIXED32";
335
+ case FieldDescriptor::TYPE_SFIXED32: return "SFIXED32";
336
+ case FieldDescriptor::TYPE_INT64 : return "INT64";
337
+ case FieldDescriptor::TYPE_UINT64 : return "UINT64";
338
+ case FieldDescriptor::TYPE_SINT64 : return "SINT64";
339
+ case FieldDescriptor::TYPE_FIXED64 : return "FIXED64";
340
+ case FieldDescriptor::TYPE_SFIXED64: return "SFIXED64";
341
+ case FieldDescriptor::TYPE_FLOAT : return "FLOAT";
342
+ case FieldDescriptor::TYPE_DOUBLE : return "DOUBLE";
343
+ case FieldDescriptor::TYPE_BOOL : return "BOOL";
344
+ case FieldDescriptor::TYPE_STRING : return "STRING";
345
+ case FieldDescriptor::TYPE_BYTES : return "BYTES";
346
+ case FieldDescriptor::TYPE_ENUM : return "ENUM";
347
+ case FieldDescriptor::TYPE_GROUP : return "GROUP";
348
+ case FieldDescriptor::TYPE_MESSAGE : return "MESSAGE";
349
+
350
+ // No default because we want the compiler to complain if any new
351
+ // types are added.
352
+ }
353
+
354
+ GOOGLE_LOG(FATAL) << "Can't get here.";
355
+ return NULL;
356
+ }
357
+
358
+ bool AllAscii(const string& text) {
359
+ for (int i = 0; i < text.size(); i++) {
360
+ if ((text[i] & 0x80) != 0) {
361
+ return false;
362
+ }
363
+ }
364
+ return true;
365
+ }
366
+
367
+ string DefaultValue(const FieldDescriptor* field, bool immutable,
368
+ ClassNameResolver* name_resolver) {
369
+ // Switch on CppType since we need to know which default_value_* method
370
+ // of FieldDescriptor to call.
371
+ switch (field->cpp_type()) {
372
+ case FieldDescriptor::CPPTYPE_INT32:
373
+ return SimpleItoa(field->default_value_int32());
374
+ case FieldDescriptor::CPPTYPE_UINT32:
375
+ // Need to print as a signed int since Java has no unsigned.
376
+ return SimpleItoa(static_cast<int32>(field->default_value_uint32()));
377
+ case FieldDescriptor::CPPTYPE_INT64:
378
+ return SimpleItoa(field->default_value_int64()) + "L";
379
+ case FieldDescriptor::CPPTYPE_UINT64:
380
+ return SimpleItoa(static_cast<int64>(field->default_value_uint64())) +
381
+ "L";
382
+ case FieldDescriptor::CPPTYPE_DOUBLE: {
383
+ double value = field->default_value_double();
384
+ if (value == numeric_limits<double>::infinity()) {
385
+ return "Double.POSITIVE_INFINITY";
386
+ } else if (value == -numeric_limits<double>::infinity()) {
387
+ return "Double.NEGATIVE_INFINITY";
388
+ } else if (value != value) {
389
+ return "Double.NaN";
390
+ } else {
391
+ return SimpleDtoa(value) + "D";
392
+ }
393
+ }
394
+ case FieldDescriptor::CPPTYPE_FLOAT: {
395
+ float value = field->default_value_float();
396
+ if (value == numeric_limits<float>::infinity()) {
397
+ return "Float.POSITIVE_INFINITY";
398
+ } else if (value == -numeric_limits<float>::infinity()) {
399
+ return "Float.NEGATIVE_INFINITY";
400
+ } else if (value != value) {
401
+ return "Float.NaN";
402
+ } else {
403
+ return SimpleFtoa(value) + "F";
404
+ }
405
+ }
406
+ case FieldDescriptor::CPPTYPE_BOOL:
407
+ return field->default_value_bool() ? "true" : "false";
408
+ case FieldDescriptor::CPPTYPE_STRING:
409
+ if (GetType(field) == FieldDescriptor::TYPE_BYTES) {
410
+ if (field->has_default_value()) {
411
+ // See comments in Internal.java for gory details.
412
+ return strings::Substitute(
413
+ "com.google.protobuf.Internal.bytesDefaultValue(\"$0\")",
414
+ CEscape(field->default_value_string()));
415
+ } else {
416
+ return "com.google.protobuf.ByteString.EMPTY";
417
+ }
418
+ } else {
419
+ if (AllAscii(field->default_value_string())) {
420
+ // All chars are ASCII. In this case CEscape() works fine.
421
+ return "\"" + CEscape(field->default_value_string()) + "\"";
422
+ } else {
423
+ // See comments in Internal.java for gory details.
424
+ return strings::Substitute(
425
+ "com.google.protobuf.Internal.stringDefaultValue(\"$0\")",
426
+ CEscape(field->default_value_string()));
427
+ }
428
+ }
429
+
430
+ case FieldDescriptor::CPPTYPE_ENUM:
431
+ return name_resolver->GetClassName(field->enum_type(), immutable) + "." +
432
+ field->default_value_enum()->name();
433
+
434
+ case FieldDescriptor::CPPTYPE_MESSAGE:
435
+ return name_resolver->GetClassName(field->message_type(), immutable) +
436
+ ".getDefaultInstance()";
437
+
438
+ // No default because we want the compiler to complain if any new
439
+ // types are added.
440
+ }
441
+
442
+ GOOGLE_LOG(FATAL) << "Can't get here.";
443
+ return "";
444
+ }
445
+
446
+ bool IsDefaultValueJavaDefault(const FieldDescriptor* field) {
447
+ // Switch on CppType since we need to know which default_value_* method
448
+ // of FieldDescriptor to call.
449
+ switch (field->cpp_type()) {
450
+ case FieldDescriptor::CPPTYPE_INT32:
451
+ return field->default_value_int32() == 0;
452
+ case FieldDescriptor::CPPTYPE_UINT32:
453
+ return field->default_value_uint32() == 0;
454
+ case FieldDescriptor::CPPTYPE_INT64:
455
+ return field->default_value_int64() == 0L;
456
+ case FieldDescriptor::CPPTYPE_UINT64:
457
+ return field->default_value_uint64() == 0L;
458
+ case FieldDescriptor::CPPTYPE_DOUBLE:
459
+ return field->default_value_double() == 0.0;
460
+ case FieldDescriptor::CPPTYPE_FLOAT:
461
+ return field->default_value_float() == 0.0;
462
+ case FieldDescriptor::CPPTYPE_BOOL:
463
+ return field->default_value_bool() == false;
464
+
465
+ case FieldDescriptor::CPPTYPE_STRING:
466
+ case FieldDescriptor::CPPTYPE_ENUM:
467
+ case FieldDescriptor::CPPTYPE_MESSAGE:
468
+ return false;
469
+
470
+ // No default because we want the compiler to complain if any new
471
+ // types are added.
472
+ }
473
+
474
+ GOOGLE_LOG(FATAL) << "Can't get here.";
475
+ return false;
476
+ }
477
+
478
+ const char* bit_masks[] = {
479
+ "0x00000001",
480
+ "0x00000002",
481
+ "0x00000004",
482
+ "0x00000008",
483
+ "0x00000010",
484
+ "0x00000020",
485
+ "0x00000040",
486
+ "0x00000080",
487
+
488
+ "0x00000100",
489
+ "0x00000200",
490
+ "0x00000400",
491
+ "0x00000800",
492
+ "0x00001000",
493
+ "0x00002000",
494
+ "0x00004000",
495
+ "0x00008000",
496
+
497
+ "0x00010000",
498
+ "0x00020000",
499
+ "0x00040000",
500
+ "0x00080000",
501
+ "0x00100000",
502
+ "0x00200000",
503
+ "0x00400000",
504
+ "0x00800000",
505
+
506
+ "0x01000000",
507
+ "0x02000000",
508
+ "0x04000000",
509
+ "0x08000000",
510
+ "0x10000000",
511
+ "0x20000000",
512
+ "0x40000000",
513
+ "0x80000000",
514
+ };
515
+
516
+ string GetBitFieldName(int index) {
517
+ string varName = "bitField";
518
+ varName += SimpleItoa(index);
519
+ varName += "_";
520
+ return varName;
521
+ }
522
+
523
+ string GetBitFieldNameForBit(int bitIndex) {
524
+ return GetBitFieldName(bitIndex / 32);
525
+ }
526
+
527
+ namespace {
528
+
529
+ string GenerateGetBitInternal(const string& prefix, int bitIndex) {
530
+ string varName = prefix + GetBitFieldNameForBit(bitIndex);
531
+ int bitInVarIndex = bitIndex % 32;
532
+
533
+ string mask = bit_masks[bitInVarIndex];
534
+ string result = "((" + varName + " & " + mask + ") == " + mask + ")";
535
+ return result;
536
+ }
537
+
538
+ string GenerateSetBitInternal(const string& prefix, int bitIndex) {
539
+ string varName = prefix + GetBitFieldNameForBit(bitIndex);
540
+ int bitInVarIndex = bitIndex % 32;
541
+
542
+ string mask = bit_masks[bitInVarIndex];
543
+ string result = varName + " |= " + mask;
544
+ return result;
545
+ }
546
+
547
+ } // namespace
548
+
549
+ string GenerateGetBit(int bitIndex) {
550
+ return GenerateGetBitInternal("", bitIndex);
551
+ }
552
+
553
+ string GenerateSetBit(int bitIndex) {
554
+ return GenerateSetBitInternal("", bitIndex);
555
+ }
556
+
557
+ string GenerateClearBit(int bitIndex) {
558
+ string varName = GetBitFieldNameForBit(bitIndex);
559
+ int bitInVarIndex = bitIndex % 32;
560
+
561
+ string mask = bit_masks[bitInVarIndex];
562
+ string result = varName + " = (" + varName + " & ~" + mask + ")";
563
+ return result;
564
+ }
565
+
566
+ string GenerateGetBitFromLocal(int bitIndex) {
567
+ return GenerateGetBitInternal("from_", bitIndex);
568
+ }
569
+
570
+ string GenerateSetBitToLocal(int bitIndex) {
571
+ return GenerateSetBitInternal("to_", bitIndex);
572
+ }
573
+
574
+ string GenerateGetBitMutableLocal(int bitIndex) {
575
+ return GenerateGetBitInternal("mutable_", bitIndex);
576
+ }
577
+
578
+ string GenerateSetBitMutableLocal(int bitIndex) {
579
+ return GenerateSetBitInternal("mutable_", bitIndex);
580
+ }
581
+
582
+ bool IsReferenceType(JavaType type) {
583
+ switch (type) {
584
+ case JAVATYPE_INT : return false;
585
+ case JAVATYPE_LONG : return false;
586
+ case JAVATYPE_FLOAT : return false;
587
+ case JAVATYPE_DOUBLE : return false;
588
+ case JAVATYPE_BOOLEAN: return false;
589
+ case JAVATYPE_STRING : return true;
590
+ case JAVATYPE_BYTES : return true;
591
+ case JAVATYPE_ENUM : return true;
592
+ case JAVATYPE_MESSAGE: return true;
593
+
594
+ // No default because we want the compiler to complain if any new
595
+ // JavaTypes are added.
596
+ }
597
+
598
+ GOOGLE_LOG(FATAL) << "Can't get here.";
599
+ return false;
600
+ }
601
+
602
+ const char* GetCapitalizedType(const FieldDescriptor* field, bool immutable) {
603
+ switch (GetType(field)) {
604
+ case FieldDescriptor::TYPE_INT32 : return "Int32";
605
+ case FieldDescriptor::TYPE_UINT32 : return "UInt32";
606
+ case FieldDescriptor::TYPE_SINT32 : return "SInt32";
607
+ case FieldDescriptor::TYPE_FIXED32 : return "Fixed32";
608
+ case FieldDescriptor::TYPE_SFIXED32: return "SFixed32";
609
+ case FieldDescriptor::TYPE_INT64 : return "Int64";
610
+ case FieldDescriptor::TYPE_UINT64 : return "UInt64";
611
+ case FieldDescriptor::TYPE_SINT64 : return "SInt64";
612
+ case FieldDescriptor::TYPE_FIXED64 : return "Fixed64";
613
+ case FieldDescriptor::TYPE_SFIXED64: return "SFixed64";
614
+ case FieldDescriptor::TYPE_FLOAT : return "Float";
615
+ case FieldDescriptor::TYPE_DOUBLE : return "Double";
616
+ case FieldDescriptor::TYPE_BOOL : return "Bool";
617
+ case FieldDescriptor::TYPE_STRING : return "String";
618
+ case FieldDescriptor::TYPE_BYTES : {
619
+ return "Bytes";
620
+ }
621
+ case FieldDescriptor::TYPE_ENUM : return "Enum";
622
+ case FieldDescriptor::TYPE_GROUP : return "Group";
623
+ case FieldDescriptor::TYPE_MESSAGE : return "Message";
624
+
625
+ // No default because we want the compiler to complain if any new
626
+ // types are added.
627
+ }
628
+
629
+ GOOGLE_LOG(FATAL) << "Can't get here.";
630
+ return NULL;
631
+ }
632
+
633
+ // For encodings with fixed sizes, returns that size in bytes. Otherwise
634
+ // returns -1.
635
+ int FixedSize(FieldDescriptor::Type type) {
636
+ switch (type) {
637
+ case FieldDescriptor::TYPE_INT32 : return -1;
638
+ case FieldDescriptor::TYPE_INT64 : return -1;
639
+ case FieldDescriptor::TYPE_UINT32 : return -1;
640
+ case FieldDescriptor::TYPE_UINT64 : return -1;
641
+ case FieldDescriptor::TYPE_SINT32 : return -1;
642
+ case FieldDescriptor::TYPE_SINT64 : return -1;
643
+ case FieldDescriptor::TYPE_FIXED32 : return WireFormatLite::kFixed32Size;
644
+ case FieldDescriptor::TYPE_FIXED64 : return WireFormatLite::kFixed64Size;
645
+ case FieldDescriptor::TYPE_SFIXED32: return WireFormatLite::kSFixed32Size;
646
+ case FieldDescriptor::TYPE_SFIXED64: return WireFormatLite::kSFixed64Size;
647
+ case FieldDescriptor::TYPE_FLOAT : return WireFormatLite::kFloatSize;
648
+ case FieldDescriptor::TYPE_DOUBLE : return WireFormatLite::kDoubleSize;
649
+
650
+ case FieldDescriptor::TYPE_BOOL : return WireFormatLite::kBoolSize;
651
+ case FieldDescriptor::TYPE_ENUM : return -1;
652
+
653
+ case FieldDescriptor::TYPE_STRING : return -1;
654
+ case FieldDescriptor::TYPE_BYTES : return -1;
655
+ case FieldDescriptor::TYPE_GROUP : return -1;
656
+ case FieldDescriptor::TYPE_MESSAGE : return -1;
657
+
658
+ // No default because we want the compiler to complain if any new
659
+ // types are added.
660
+ }
661
+ GOOGLE_LOG(FATAL) << "Can't get here.";
662
+ return -1;
663
+ }
664
+
665
+ // Sort the fields of the given Descriptor by number into a new[]'d array
666
+ // and return it. The caller should delete the returned array.
667
+ const FieldDescriptor** SortFieldsByNumber(const Descriptor* descriptor) {
668
+ const FieldDescriptor** fields =
669
+ new const FieldDescriptor*[descriptor->field_count()];
670
+ for (int i = 0; i < descriptor->field_count(); i++) {
671
+ fields[i] = descriptor->field(i);
672
+ }
673
+ sort(fields, fields + descriptor->field_count(),
674
+ FieldOrderingByNumber());
675
+ return fields;
676
+ }
677
+
678
+ // Returns true if the message type has any required fields. If it doesn't,
679
+ // we can optimize out calls to its isInitialized() method.
680
+ //
681
+ // already_seen is used to avoid checking the same type multiple times
682
+ // (and also to protect against recursion).
683
+ bool HasRequiredFields(
684
+ const Descriptor* type,
685
+ hash_set<const Descriptor*>* already_seen) {
686
+ if (already_seen->count(type) > 0) {
687
+ // The type is already in cache. This means that either:
688
+ // a. The type has no required fields.
689
+ // b. We are in the midst of checking if the type has required fields,
690
+ // somewhere up the stack. In this case, we know that if the type
691
+ // has any required fields, they'll be found when we return to it,
692
+ // and the whole call to HasRequiredFields() will return true.
693
+ // Therefore, we don't have to check if this type has required fields
694
+ // here.
695
+ return false;
696
+ }
697
+ already_seen->insert(type);
698
+
699
+ // If the type has extensions, an extension with message type could contain
700
+ // required fields, so we have to be conservative and assume such an
701
+ // extension exists.
702
+ if (type->extension_range_count() > 0) return true;
703
+
704
+ for (int i = 0; i < type->field_count(); i++) {
705
+ const FieldDescriptor* field = type->field(i);
706
+ if (field->is_required()) {
707
+ return true;
708
+ }
709
+ if (GetJavaType(field) == JAVATYPE_MESSAGE) {
710
+ if (HasRequiredFields(field->message_type(), already_seen)) {
711
+ return true;
712
+ }
713
+ }
714
+ }
715
+
716
+ return false;
717
+ }
718
+
719
+ bool HasRequiredFields(const Descriptor* type) {
720
+ hash_set<const Descriptor*> already_seen;
721
+ return HasRequiredFields(type, &already_seen);
722
+ }
723
+
724
+ bool HasRepeatedFields(const Descriptor* descriptor) {
725
+ for (int i = 0; i < descriptor->field_count(); ++i) {
726
+ const FieldDescriptor* field = descriptor->field(i);
727
+ if (field->is_repeated()) {
728
+ return true;
729
+ }
730
+ }
731
+ return false;
732
+ }
733
+
734
+ } // namespace java
735
+ } // namespace compiler
736
+ } // namespace protobuf
737
+ } // namespace google