protobuf 1.4.2 → 2.0.0.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (198) hide show
  1. data/.gitignore +4 -0
  2. data/Rakefile +7 -7
  3. data/bin/rpc_server +2 -188
  4. data/bin/rprotoc +44 -38
  5. data/examples/addressbook.pb.rb +2 -2
  6. data/ext/Makefile +11 -0
  7. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/code_generator.h +142 -0
  8. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/command_line_interface.h +318 -0
  9. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_enum.h +99 -0
  10. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_enum_field.h +103 -0
  11. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_extension.h +85 -0
  12. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_field.h +167 -0
  13. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_file.h +98 -0
  14. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_generator.h +72 -0
  15. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_helpers.h +159 -0
  16. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_message.h +170 -0
  17. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_message_field.h +102 -0
  18. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_primitive_field.h +103 -0
  19. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_service.h +118 -0
  20. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_string_field.h +104 -0
  21. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_test_bad_identifiers.pb.h +2721 -0
  22. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/importer.h +303 -0
  23. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_enum.h +84 -0
  24. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_enum_field.h +121 -0
  25. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_extension.h +77 -0
  26. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_field.h +108 -0
  27. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_file.h +101 -0
  28. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_generator.h +72 -0
  29. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_helpers.h +213 -0
  30. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_message.h +109 -0
  31. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_message_field.h +134 -0
  32. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_primitive_field.h +121 -0
  33. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_service.h +113 -0
  34. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_string_field.h +120 -0
  35. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/mock_code_generator.h +113 -0
  36. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/package_info.h +64 -0
  37. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/parser.h +434 -0
  38. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/plugin.h +73 -0
  39. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/plugin.pb.h +790 -0
  40. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/python/python_generator.h +156 -0
  41. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/subprocess.h +108 -0
  42. data/ext/protobuf-2.4.1/src/google/protobuf/compiler/zip_writer.h +93 -0
  43. data/ext/protobuf-2.4.1/src/google/protobuf/descriptor.h +1367 -0
  44. data/ext/protobuf-2.4.1/src/google/protobuf/descriptor.pb.h +5223 -0
  45. data/ext/protobuf-2.4.1/src/google/protobuf/descriptor_database.h +366 -0
  46. data/ext/protobuf-2.4.1/src/google/protobuf/dynamic_message.h +136 -0
  47. data/ext/protobuf-2.4.1/src/google/protobuf/extension_set.h +904 -0
  48. data/ext/protobuf-2.4.1/src/google/protobuf/generated_message_reflection.h +424 -0
  49. data/ext/protobuf-2.4.1/src/google/protobuf/generated_message_util.h +82 -0
  50. data/ext/protobuf-2.4.1/src/google/protobuf/io/coded_stream.h +1102 -0
  51. data/ext/protobuf-2.4.1/src/google/protobuf/io/coded_stream_inl.h +64 -0
  52. data/ext/protobuf-2.4.1/src/google/protobuf/io/gzip_stream.h +207 -0
  53. data/ext/protobuf-2.4.1/src/google/protobuf/io/package_info.h +54 -0
  54. data/ext/protobuf-2.4.1/src/google/protobuf/io/printer.h +136 -0
  55. data/ext/protobuf-2.4.1/src/google/protobuf/io/tokenizer.h +313 -0
  56. data/ext/protobuf-2.4.1/src/google/protobuf/io/zero_copy_stream.h +238 -0
  57. data/ext/protobuf-2.4.1/src/google/protobuf/io/zero_copy_stream_impl.h +357 -0
  58. data/ext/protobuf-2.4.1/src/google/protobuf/io/zero_copy_stream_impl_lite.h +340 -0
  59. data/ext/protobuf-2.4.1/src/google/protobuf/message.h +692 -0
  60. data/ext/protobuf-2.4.1/src/google/protobuf/message_lite.h +239 -0
  61. data/ext/protobuf-2.4.1/src/google/protobuf/package_info.h +64 -0
  62. data/ext/protobuf-2.4.1/src/google/protobuf/reflection_ops.h +80 -0
  63. data/ext/protobuf-2.4.1/src/google/protobuf/repeated_field.h +1295 -0
  64. data/ext/protobuf-2.4.1/src/google/protobuf/service.h +291 -0
  65. data/ext/protobuf-2.4.1/src/google/protobuf/stubs/common.h +1211 -0
  66. data/ext/protobuf-2.4.1/src/google/protobuf/stubs/hash.h +220 -0
  67. data/ext/protobuf-2.4.1/src/google/protobuf/stubs/map-util.h +119 -0
  68. data/ext/protobuf-2.4.1/src/google/protobuf/stubs/once.h +123 -0
  69. data/ext/protobuf-2.4.1/src/google/protobuf/stubs/stl_util-inl.h +121 -0
  70. data/ext/protobuf-2.4.1/src/google/protobuf/stubs/strutil.h +457 -0
  71. data/ext/protobuf-2.4.1/src/google/protobuf/stubs/substitute.h +170 -0
  72. data/ext/protobuf-2.4.1/src/google/protobuf/test_util.h +174 -0
  73. data/ext/protobuf-2.4.1/src/google/protobuf/test_util_lite.h +101 -0
  74. data/ext/protobuf-2.4.1/src/google/protobuf/testing/file.h +83 -0
  75. data/ext/protobuf-2.4.1/src/google/protobuf/testing/googletest.h +98 -0
  76. data/ext/protobuf-2.4.1/src/google/protobuf/text_format.h +285 -0
  77. data/ext/protobuf-2.4.1/src/google/protobuf/unittest.pb.h +11915 -0
  78. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_custom_options.pb.h +2895 -0
  79. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_embed_optimize_for.pb.h +211 -0
  80. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_empty.pb.h +56 -0
  81. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_import.pb.h +188 -0
  82. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_import_lite.pb.h +151 -0
  83. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_lite.pb.h +4752 -0
  84. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_lite_imports_nonlite.pb.h +150 -0
  85. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_mset.pb.h +816 -0
  86. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_no_generic_services.pb.h +197 -0
  87. data/ext/protobuf-2.4.1/src/google/protobuf/unittest_optimize_for.pb.h +403 -0
  88. data/ext/protobuf-2.4.1/src/google/protobuf/unknown_field_set.h +268 -0
  89. data/ext/protobuf-2.4.1/src/google/protobuf/wire_format.h +304 -0
  90. data/ext/protobuf-2.4.1/src/google/protobuf/wire_format_lite.h +620 -0
  91. data/ext/protobuf-2.4.1/src/google/protobuf/wire_format_lite_inl.h +774 -0
  92. data/ext/ruby_generator/RubyGenerator.cpp +435 -0
  93. data/ext/ruby_generator/RubyGenerator.h +180 -0
  94. data/ext/ruby_generator/extconf.rb +24 -0
  95. data/lib/protobuf.rb +55 -33
  96. data/lib/protobuf/cli.rb +176 -0
  97. data/lib/protobuf/common/logger.rb +11 -11
  98. data/lib/protobuf/{message/enum.rb → enum.rb} +0 -10
  99. data/lib/protobuf/evented.rb +22 -0
  100. data/lib/protobuf/field.rb +57 -0
  101. data/lib/protobuf/field/base_field.rb +210 -0
  102. data/lib/protobuf/field/bool_field.rb +24 -0
  103. data/lib/protobuf/field/bytes_field.rb +38 -0
  104. data/lib/protobuf/field/double_field.rb +19 -0
  105. data/lib/protobuf/field/enum_field.rb +58 -0
  106. data/lib/protobuf/field/extension_fields.rb +24 -0
  107. data/lib/protobuf/field/field_array.rb +55 -0
  108. data/lib/protobuf/field/fixed32_field.rb +19 -0
  109. data/lib/protobuf/field/fixed64_field.rb +22 -0
  110. data/lib/protobuf/field/float_field.rb +29 -0
  111. data/lib/protobuf/field/int32_field.rb +10 -0
  112. data/lib/protobuf/field/int64_field.rb +10 -0
  113. data/lib/protobuf/field/integer_field.rb +19 -0
  114. data/lib/protobuf/field/message_field.rb +51 -0
  115. data/lib/protobuf/field/sfixed32_field.rb +21 -0
  116. data/lib/protobuf/field/sfixed64_field.rb +24 -0
  117. data/lib/protobuf/field/signed_integer_field.rb +23 -0
  118. data/lib/protobuf/field/sint32_field.rb +10 -0
  119. data/lib/protobuf/field/sint64_field.rb +10 -0
  120. data/lib/protobuf/field/string_field.rb +14 -0
  121. data/lib/protobuf/field/uint32_field.rb +10 -0
  122. data/lib/protobuf/field/uint64_field.rb +10 -0
  123. data/lib/protobuf/field/varint_field.rb +63 -0
  124. data/lib/protobuf/message.rb +376 -0
  125. data/lib/protobuf/message/message.rb +1 -475
  126. data/lib/protobuf/rpc/buffer.rb +1 -1
  127. data/lib/protobuf/rpc/client.rb +26 -26
  128. data/lib/protobuf/rpc/connector.rb +15 -14
  129. data/lib/protobuf/rpc/connectors/eventmachine.rb +13 -13
  130. data/lib/protobuf/rpc/rpc.pb.rb +39 -28
  131. data/lib/protobuf/rpc/server.rb +7 -28
  132. data/lib/protobuf/rpc/servers/evented_runner.rb +15 -15
  133. data/lib/protobuf/rpc/servers/socket/server.rb +2 -1
  134. data/lib/protobuf/rpc/servers/socket_runner.rb +5 -6
  135. data/lib/protobuf/rpc/servers/zmq_runner.rb +4 -5
  136. data/lib/protobuf/socket.rb +22 -0
  137. data/lib/protobuf/version.rb +2 -1
  138. data/lib/protobuf/zmq.rb +21 -0
  139. data/proto/rpc.pb.rb +48 -0
  140. data/protobuf.gemspec +14 -6
  141. data/spec/benchmark/tasks.rb +42 -23
  142. data/spec/functional/evented_server_spec.rb +2 -0
  143. data/spec/functional/socket_server_spec.rb +22 -26
  144. data/spec/functional/zmq_server_spec.rb +22 -26
  145. data/spec/lib/protobuf/cli_spec.rb +182 -0
  146. data/spec/{unit → lib/protobuf}/common/logger_spec.rb +0 -0
  147. data/spec/{unit → lib/protobuf/message}/enum_spec.rb +0 -0
  148. data/spec/{unit → lib/protobuf/message}/message_spec.rb +0 -0
  149. data/spec/{unit → lib/protobuf}/rpc/client_spec.rb +6 -4
  150. data/spec/lib/protobuf/rpc/connector_spec.rb +41 -0
  151. data/spec/{unit → lib/protobuf}/rpc/connectors/base_spec.rb +18 -18
  152. data/spec/{unit → lib/protobuf}/rpc/connectors/common_spec.rb +20 -20
  153. data/spec/{unit → lib/protobuf}/rpc/connectors/socket_spec.rb +9 -8
  154. data/spec/{unit → lib/protobuf}/rpc/connectors/zmq_spec.rb +1 -1
  155. data/spec/{unit → lib/protobuf}/rpc/servers/evented_server_spec.rb +4 -4
  156. data/spec/{unit → lib/protobuf}/rpc/servers/socket_server_spec.rb +11 -23
  157. data/spec/{unit → lib/protobuf}/rpc/servers/zmq/broker_spec.rb +5 -0
  158. data/spec/{unit → lib/protobuf}/rpc/servers/zmq/server_spec.rb +5 -0
  159. data/spec/{unit → lib/protobuf}/rpc/servers/zmq/util_spec.rb +5 -0
  160. data/spec/{unit → lib/protobuf}/rpc/servers/zmq/worker_spec.rb +5 -0
  161. data/spec/{unit → lib/protobuf}/rpc/service_spec.rb +0 -0
  162. data/spec/proto/test.pb.rb +48 -25
  163. data/spec/spec_helper.rb +9 -15
  164. data/spec/support/all.rb +7 -0
  165. data/spec/{helper → support}/server.rb +5 -7
  166. data/spec/{helper → support}/silent_constants.rb +4 -0
  167. data/spec/support/test_app_file.rb +2 -0
  168. data/spec/{helper → support}/tolerance_matcher.rb +0 -0
  169. data/test/proto/types.pb.rb +1 -1
  170. data/test/test_addressbook.rb +1 -1
  171. data/test/test_enum_value.rb +1 -1
  172. data/test/test_standard_message.rb +1 -1
  173. metadata +243 -107
  174. data/lib/protobuf/common/util.rb +0 -59
  175. data/lib/protobuf/compiler/compiler.rb +0 -52
  176. data/lib/protobuf/compiler/nodes.rb +0 -323
  177. data/lib/protobuf/compiler/proto.y +0 -216
  178. data/lib/protobuf/compiler/proto2.ebnf +0 -79
  179. data/lib/protobuf/compiler/proto_parser.rb +0 -1425
  180. data/lib/protobuf/compiler/template/rpc_service_implementation.erb +0 -42
  181. data/lib/protobuf/compiler/visitors.rb +0 -282
  182. data/lib/protobuf/descriptor/descriptor.proto +0 -286
  183. data/lib/protobuf/descriptor/descriptor.rb +0 -55
  184. data/lib/protobuf/descriptor/descriptor_builder.rb +0 -143
  185. data/lib/protobuf/descriptor/descriptor_proto.rb +0 -138
  186. data/lib/protobuf/descriptor/enum_descriptor.rb +0 -33
  187. data/lib/protobuf/descriptor/field_descriptor.rb +0 -49
  188. data/lib/protobuf/descriptor/file_descriptor.rb +0 -37
  189. data/lib/protobuf/message/field.rb +0 -684
  190. data/lib/protobuf/message/protoable.rb +0 -38
  191. data/spec/helper/all.rb +0 -7
  192. data/spec/unit/common/util_spec.rb +0 -17
  193. data/spec/unit/rpc/connector_spec.rb +0 -31
  194. data/spec/unit/rpc/connectors/eventmachine_client_spec.rb +0 -32
  195. data/spec/unit/rpc/connectors/eventmachine_spec.rb +0 -0
  196. data/test/check_unbuild.rb +0 -30
  197. data/test/test_compiler.rb +0 -325
  198. data/test/test_descriptor.rb +0 -122
@@ -0,0 +1,120 @@
1
+ // Protocol Buffers - Google's data interchange format
2
+ // Copyright 2008 Google Inc. All rights reserved.
3
+ // http://code.google.com/p/protobuf/
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
+ // Author: jonp@google.com (Jon Perlow)
33
+ // Based on original Protocol Buffers design by
34
+ // Sanjay Ghemawat, Jeff Dean, and others.
35
+
36
+ #ifndef GOOGLE_PROTOBUF_COMPILER_JAVA_STRING_FIELD_H__
37
+ #define GOOGLE_PROTOBUF_COMPILER_JAVA_STRING_FIELD_H__
38
+
39
+ #include <map>
40
+ #include <string>
41
+ #include <google/protobuf/compiler/java/java_field.h>
42
+
43
+ namespace google {
44
+ namespace protobuf {
45
+ namespace compiler {
46
+ namespace java {
47
+
48
+ class StringFieldGenerator : public FieldGenerator {
49
+ public:
50
+ explicit StringFieldGenerator(const FieldDescriptor* descriptor,
51
+ int messageBitIndex, int builderBitIndex);
52
+ ~StringFieldGenerator();
53
+
54
+ // implements FieldGenerator ---------------------------------------
55
+ int GetNumBitsForMessage() const;
56
+ int GetNumBitsForBuilder() const;
57
+ void GenerateInterfaceMembers(io::Printer* printer) const;
58
+ void GenerateMembers(io::Printer* printer) const;
59
+ void GenerateBuilderMembers(io::Printer* printer) const;
60
+ void GenerateInitializationCode(io::Printer* printer) const;
61
+ void GenerateBuilderClearCode(io::Printer* printer) const;
62
+ void GenerateMergingCode(io::Printer* printer) const;
63
+ void GenerateBuildingCode(io::Printer* printer) const;
64
+ void GenerateParsingCode(io::Printer* printer) const;
65
+ void GenerateSerializationCode(io::Printer* printer) const;
66
+ void GenerateSerializedSizeCode(io::Printer* printer) const;
67
+ void GenerateFieldBuilderInitializationCode(io::Printer* printer) const;
68
+ void GenerateEqualsCode(io::Printer* printer) const;
69
+ void GenerateHashCode(io::Printer* printer) const;
70
+ string GetBoxedType() const;
71
+
72
+ private:
73
+ const FieldDescriptor* descriptor_;
74
+ map<string, string> variables_;
75
+ const int messageBitIndex_;
76
+ const int builderBitIndex_;
77
+
78
+ GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(StringFieldGenerator);
79
+ };
80
+
81
+ class RepeatedStringFieldGenerator : public FieldGenerator {
82
+ public:
83
+ explicit RepeatedStringFieldGenerator(const FieldDescriptor* descriptor,
84
+ int messageBitIndex, int builderBitIndex);
85
+ ~RepeatedStringFieldGenerator();
86
+
87
+ // implements FieldGenerator ---------------------------------------
88
+ int GetNumBitsForMessage() const;
89
+ int GetNumBitsForBuilder() const;
90
+ void GenerateInterfaceMembers(io::Printer* printer) const;
91
+ void GenerateMembers(io::Printer* printer) const;
92
+ void GenerateBuilderMembers(io::Printer* printer) const;
93
+ void GenerateInitializationCode(io::Printer* printer) const;
94
+ void GenerateBuilderClearCode(io::Printer* printer) const;
95
+ void GenerateMergingCode(io::Printer* printer) const;
96
+ void GenerateBuildingCode(io::Printer* printer) const;
97
+ void GenerateParsingCode(io::Printer* printer) const;
98
+ void GenerateParsingCodeFromPacked(io::Printer* printer) const;
99
+ void GenerateSerializationCode(io::Printer* printer) const;
100
+ void GenerateSerializedSizeCode(io::Printer* printer) const;
101
+ void GenerateFieldBuilderInitializationCode(io::Printer* printer) const;
102
+ void GenerateEqualsCode(io::Printer* printer) const;
103
+ void GenerateHashCode(io::Printer* printer) const;
104
+ string GetBoxedType() const;
105
+
106
+ private:
107
+ const FieldDescriptor* descriptor_;
108
+ map<string, string> variables_;
109
+ const int messageBitIndex_;
110
+ const int builderBitIndex_;
111
+
112
+ GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(RepeatedStringFieldGenerator);
113
+ };
114
+
115
+ } // namespace java
116
+ } // namespace compiler
117
+ } // namespace protobuf
118
+
119
+ } // namespace google
120
+ #endif // GOOGLE_PROTOBUF_COMPILER_JAVA_STRING_FIELD_H__
@@ -0,0 +1,113 @@
1
+ // Protocol Buffers - Google's data interchange format
2
+ // Copyright 2008 Google Inc. All rights reserved.
3
+ // http://code.google.com/p/protobuf/
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
+
33
+ #ifndef GOOGLE_PROTOBUF_COMPILER_MOCK_CODE_GENERATOR_H__
34
+ #define GOOGLE_PROTOBUF_COMPILER_MOCK_CODE_GENERATOR_H__
35
+
36
+ #include <string>
37
+ #include <google/protobuf/compiler/code_generator.h>
38
+
39
+ namespace google {
40
+ namespace protobuf {
41
+ namespace compiler {
42
+
43
+ // A mock CodeGenerator, used by command_line_interface_unittest. This is in
44
+ // its own file so that it can be used both directly and as a plugin.
45
+ //
46
+ // Generate() produces some output which can be checked by ExpectCalled(). The
47
+ // generator can run in a different process (e.g. a plugin).
48
+ //
49
+ // If the parameter is "insert=NAMES", the MockCodeGenerator will insert lines
50
+ // into the files generated by other MockCodeGenerators instead of creating
51
+ // its own file. NAMES is a comma-separated list of the names of those other
52
+ // MockCodeGenerators.
53
+ //
54
+ // MockCodeGenerator will also modify its behavior slightly if the input file
55
+ // contains a message type with one of the following names:
56
+ // MockCodeGenerator_Error: Causes Generate() to return false and set the
57
+ // error message to "Saw message type MockCodeGenerator_Error."
58
+ // MockCodeGenerator_Exit: Generate() prints "Saw message type
59
+ // MockCodeGenerator_Exit." to stderr and then calls exit(123).
60
+ // MockCodeGenerator_Abort: Generate() prints "Saw message type
61
+ // MockCodeGenerator_Abort." to stderr and then calls abort().
62
+ class MockCodeGenerator : public CodeGenerator {
63
+ public:
64
+ MockCodeGenerator(const string& name);
65
+ virtual ~MockCodeGenerator();
66
+
67
+ // Expect (via gTest) that a MockCodeGenerator with the given name was called
68
+ // with the given parameters by inspecting the output location.
69
+ //
70
+ // |insertions| is a comma-separated list of names of MockCodeGenerators which
71
+ // should have inserted lines into this file.
72
+ // |parsed_file_list| is a comma-separated list of names of the files
73
+ // that are being compiled together in this run.
74
+ static void ExpectGenerated(const string& name,
75
+ const string& parameter,
76
+ const string& insertions,
77
+ const string& file,
78
+ const string& first_message_name,
79
+ const string& parsed_file_list,
80
+ const string& output_directory);
81
+
82
+ // Get the name of the file which would be written by the given generator.
83
+ static string GetOutputFileName(const string& generator_name,
84
+ const FileDescriptor* file);
85
+ static string GetOutputFileName(const string& generator_name,
86
+ const string& file);
87
+
88
+ // implements CodeGenerator ----------------------------------------
89
+
90
+ virtual bool Generate(const FileDescriptor* file,
91
+ const string& parameter,
92
+ GeneratorContext* context,
93
+ string* error) const;
94
+
95
+ private:
96
+ string name_;
97
+
98
+ static string GetOutputFileContent(const string& generator_name,
99
+ const string& parameter,
100
+ const FileDescriptor* file,
101
+ GeneratorContext *context);
102
+ static string GetOutputFileContent(const string& generator_name,
103
+ const string& parameter,
104
+ const string& file,
105
+ const string& parsed_file_list,
106
+ const string& first_message_name);
107
+ };
108
+
109
+ } // namespace compiler
110
+ } // namespace protobuf
111
+
112
+ } // namespace google
113
+ #endif // GOOGLE_PROTOBUF_COMPILER_MOCK_CODE_GENERATOR_H__
@@ -0,0 +1,64 @@
1
+ // Protocol Buffers - Google's data interchange format
2
+ // Copyright 2008 Google Inc. All rights reserved.
3
+ // http://code.google.com/p/protobuf/
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
+ // This file exists solely to document the google::protobuf::compiler namespace.
36
+ // It is not compiled into anything, but it may be read by an automated
37
+ // documentation generator.
38
+
39
+ namespace google {
40
+
41
+ namespace protobuf {
42
+
43
+ // Implementation of the Protocol Buffer compiler.
44
+ //
45
+ // This package contains code for parsing .proto files and generating code
46
+ // based on them. There are two reasons you might be interested in this
47
+ // package:
48
+ // - You want to parse .proto files at runtime. In this case, you should
49
+ // look at importer.h. Since this functionality is widely useful, it is
50
+ // included in the libprotobuf base library; you do not have to link against
51
+ // libprotoc.
52
+ // - You want to write a custom protocol compiler which generates different
53
+ // kinds of code, e.g. code in a different language which is not supported
54
+ // by the official compiler. For this purpose, command_line_interface.h
55
+ // provides you with a complete compiler front-end, so all you need to do
56
+ // is write a custom implementation of CodeGenerator and a trivial main()
57
+ // function. You can even make your compiler support the official languages
58
+ // in addition to your own. Since this functionality is only useful to those
59
+ // writing custom compilers, it is in a separate library called "libprotoc"
60
+ // which you will have to link against.
61
+ namespace compiler {}
62
+
63
+ } // namespace protobuf
64
+ } // namespace google
@@ -0,0 +1,434 @@
1
+ // Protocol Buffers - Google's data interchange format
2
+ // Copyright 2008 Google Inc. All rights reserved.
3
+ // http://code.google.com/p/protobuf/
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
+ // Implements parsing of .proto files to FileDescriptorProtos.
36
+
37
+ #ifndef GOOGLE_PROTOBUF_COMPILER_PARSER_H__
38
+ #define GOOGLE_PROTOBUF_COMPILER_PARSER_H__
39
+
40
+ #include <map>
41
+ #include <string>
42
+ #include <utility>
43
+ #include <google/protobuf/stubs/common.h>
44
+ #include <google/protobuf/descriptor.h>
45
+ #include <google/protobuf/descriptor.pb.h>
46
+ #include <google/protobuf/repeated_field.h>
47
+ #include <google/protobuf/io/tokenizer.h>
48
+
49
+ namespace google {
50
+ namespace protobuf { class Message; }
51
+
52
+ namespace protobuf {
53
+ namespace compiler {
54
+
55
+ // Defined in this file.
56
+ class Parser;
57
+ class SourceLocationTable;
58
+
59
+ // Implements parsing of protocol definitions (such as .proto files).
60
+ //
61
+ // Note that most users will be more interested in the Importer class.
62
+ // Parser is a lower-level class which simply converts a single .proto file
63
+ // to a FileDescriptorProto. It does not resolve import directives or perform
64
+ // many other kinds of validation needed to construct a complete
65
+ // FileDescriptor.
66
+ class LIBPROTOBUF_EXPORT Parser {
67
+ public:
68
+ Parser();
69
+ ~Parser();
70
+
71
+ // Parse the entire input and construct a FileDescriptorProto representing
72
+ // it. Returns true if no errors occurred, false otherwise.
73
+ bool Parse(io::Tokenizer* input, FileDescriptorProto* file);
74
+
75
+ // Optional fetaures:
76
+
77
+ // DEPRECATED: New code should use the SourceCodeInfo embedded in the
78
+ // FileDescriptorProto.
79
+ //
80
+ // Requests that locations of certain definitions be recorded to the given
81
+ // SourceLocationTable while parsing. This can be used to look up exact line
82
+ // and column numbers for errors reported by DescriptorPool during validation.
83
+ // Set to NULL (the default) to discard source location information.
84
+ void RecordSourceLocationsTo(SourceLocationTable* location_table) {
85
+ source_location_table_ = location_table;
86
+ }
87
+
88
+ // Requests that errors be recorded to the given ErrorCollector while
89
+ // parsing. Set to NULL (the default) to discard error messages.
90
+ void RecordErrorsTo(io::ErrorCollector* error_collector) {
91
+ error_collector_ = error_collector;
92
+ }
93
+
94
+ // Returns the identifier used in the "syntax = " declaration, if one was
95
+ // seen during the last call to Parse(), or the empty string otherwise.
96
+ const string& GetSyntaxIdentifier() { return syntax_identifier_; }
97
+
98
+ // If set true, input files will be required to begin with a syntax
99
+ // identifier. Otherwise, files may omit this. If a syntax identifier
100
+ // is provided, it must be 'syntax = "proto2";' and must appear at the
101
+ // top of this file regardless of whether or not it was required.
102
+ void SetRequireSyntaxIdentifier(bool value) {
103
+ require_syntax_identifier_ = value;
104
+ }
105
+
106
+ // Call SetStopAfterSyntaxIdentifier(true) to tell the parser to stop
107
+ // parsing as soon as it has seen the syntax identifier, or lack thereof.
108
+ // This is useful for quickly identifying the syntax of the file without
109
+ // parsing the whole thing. If this is enabled, no error will be recorded
110
+ // if the syntax identifier is something other than "proto2" (since
111
+ // presumably the caller intends to deal with that), but other kinds of
112
+ // errors (e.g. parse errors) will still be reported. When this is enabled,
113
+ // you may pass a NULL FileDescriptorProto to Parse().
114
+ void SetStopAfterSyntaxIdentifier(bool value) {
115
+ stop_after_syntax_identifier_ = value;
116
+ }
117
+
118
+ private:
119
+ // =================================================================
120
+ // Error recovery helpers
121
+
122
+ // Consume the rest of the current statement. This consumes tokens
123
+ // until it sees one of:
124
+ // ';' Consumes the token and returns.
125
+ // '{' Consumes the brace then calls SkipRestOfBlock().
126
+ // '}' Returns without consuming.
127
+ // EOF Returns (can't consume).
128
+ // The Parser often calls SkipStatement() after encountering a syntax
129
+ // error. This allows it to go on parsing the following lines, allowing
130
+ // it to report more than just one error in the file.
131
+ void SkipStatement();
132
+
133
+ // Consume the rest of the current block, including nested blocks,
134
+ // ending after the closing '}' is encountered and consumed, or at EOF.
135
+ void SkipRestOfBlock();
136
+
137
+ // -----------------------------------------------------------------
138
+ // Single-token consuming helpers
139
+ //
140
+ // These make parsing code more readable.
141
+
142
+ // True if the current token is TYPE_END.
143
+ inline bool AtEnd();
144
+
145
+ // True if the next token matches the given text.
146
+ inline bool LookingAt(const char* text);
147
+ // True if the next token is of the given type.
148
+ inline bool LookingAtType(io::Tokenizer::TokenType token_type);
149
+
150
+ // If the next token exactly matches the text given, consume it and return
151
+ // true. Otherwise, return false without logging an error.
152
+ bool TryConsume(const char* text);
153
+
154
+ // These attempt to read some kind of token from the input. If successful,
155
+ // they return true. Otherwise they return false and add the given error
156
+ // to the error list.
157
+
158
+ // Consume a token with the exact text given.
159
+ bool Consume(const char* text, const char* error);
160
+ // Same as above, but automatically generates the error "Expected \"text\".",
161
+ // where "text" is the expected token text.
162
+ bool Consume(const char* text);
163
+ // Consume a token of type IDENTIFIER and store its text in "output".
164
+ bool ConsumeIdentifier(string* output, const char* error);
165
+ // Consume an integer and store its value in "output".
166
+ bool ConsumeInteger(int* output, const char* error);
167
+ // Consume a 64-bit integer and store its value in "output". If the value
168
+ // is greater than max_value, an error will be reported.
169
+ bool ConsumeInteger64(uint64 max_value, uint64* output, const char* error);
170
+ // Consume a number and store its value in "output". This will accept
171
+ // tokens of either INTEGER or FLOAT type.
172
+ bool ConsumeNumber(double* output, const char* error);
173
+ // Consume a string literal and store its (unescaped) value in "output".
174
+ bool ConsumeString(string* output, const char* error);
175
+
176
+ // -----------------------------------------------------------------
177
+ // Error logging helpers
178
+
179
+ // Invokes error_collector_->AddError(), if error_collector_ is not NULL.
180
+ void AddError(int line, int column, const string& error);
181
+
182
+ // Invokes error_collector_->AddError() with the line and column number
183
+ // of the current token.
184
+ void AddError(const string& error);
185
+
186
+ // Records a location in the SourceCodeInfo.location table (see
187
+ // descriptor.proto). We use RAII to ensure that the start and end locations
188
+ // are recorded -- the constructor records the start location and the
189
+ // destructor records the end location. Since the parser is
190
+ // recursive-descent, this works out beautifully.
191
+ class LIBPROTOBUF_EXPORT LocationRecorder {
192
+ public:
193
+ // Construct the file's "root" location.
194
+ LocationRecorder(Parser* parser);
195
+
196
+ // Construct a location that represents a declaration nested within the
197
+ // given parent. E.g. a field's location is nested within the location
198
+ // for a message type. The parent's path will be copied, so you should
199
+ // call AddPath() only to add the path components leading from the parent
200
+ // to the child (as opposed to leading from the root to the child).
201
+ LocationRecorder(const LocationRecorder& parent);
202
+
203
+ // Convenience constructors that call AddPath() one or two times.
204
+ LocationRecorder(const LocationRecorder& parent, int path1);
205
+ LocationRecorder(const LocationRecorder& parent, int path1, int path2);
206
+
207
+ ~LocationRecorder();
208
+
209
+ // Add a path component. See SourceCodeInfo.Location.path in
210
+ // descriptor.proto.
211
+ void AddPath(int path_component);
212
+
213
+ // By default the location is considered to start at the current token at
214
+ // the time the LocationRecorder is created. StartAt() sets the start
215
+ // location to the given token instead.
216
+ void StartAt(const io::Tokenizer::Token& token);
217
+
218
+ // By default the location is considered to end at the previous token at
219
+ // the time the LocationRecorder is destroyed. EndAt() sets the end
220
+ // location to the given token instead.
221
+ void EndAt(const io::Tokenizer::Token& token);
222
+
223
+ // Records the start point of this location to the SourceLocationTable that
224
+ // was passed to RecordSourceLocationsTo(), if any. SourceLocationTable
225
+ // is an older way of keeping track of source locations which is still
226
+ // used in some places.
227
+ void RecordLegacyLocation(const Message* descriptor,
228
+ DescriptorPool::ErrorCollector::ErrorLocation location);
229
+
230
+ private:
231
+ Parser* parser_;
232
+ SourceCodeInfo::Location* location_;
233
+
234
+ void Init(const LocationRecorder& parent);
235
+ };
236
+
237
+ // =================================================================
238
+ // Parsers for various language constructs
239
+
240
+ // Parses the "syntax = \"proto2\";" line at the top of the file. Returns
241
+ // false if it failed to parse or if the syntax identifier was not
242
+ // recognized.
243
+ bool ParseSyntaxIdentifier();
244
+
245
+ // These methods parse various individual bits of code. They return
246
+ // false if they completely fail to parse the construct. In this case,
247
+ // it is probably necessary to skip the rest of the statement to recover.
248
+ // However, if these methods return true, it does NOT mean that there
249
+ // were no errors; only that there were no *syntax* errors. For instance,
250
+ // if a service method is defined using proper syntax but uses a primitive
251
+ // type as its input or output, ParseMethodField() still returns true
252
+ // and only reports the error by calling AddError(). In practice, this
253
+ // makes logic much simpler for the caller.
254
+
255
+ // Parse a top-level message, enum, service, etc.
256
+ bool ParseTopLevelStatement(FileDescriptorProto* file,
257
+ const LocationRecorder& root_location);
258
+
259
+ // Parse various language high-level language construrcts.
260
+ bool ParseMessageDefinition(DescriptorProto* message,
261
+ const LocationRecorder& message_location);
262
+ bool ParseEnumDefinition(EnumDescriptorProto* enum_type,
263
+ const LocationRecorder& enum_location);
264
+ bool ParseServiceDefinition(ServiceDescriptorProto* service,
265
+ const LocationRecorder& service_location);
266
+ bool ParsePackage(FileDescriptorProto* file,
267
+ const LocationRecorder& root_location);
268
+ bool ParseImport(string* import_filename,
269
+ const LocationRecorder& root_location,
270
+ int index);
271
+ bool ParseOption(Message* options,
272
+ const LocationRecorder& options_location);
273
+
274
+ // These methods parse the contents of a message, enum, or service type and
275
+ // add them to the given object. They consume the entire block including
276
+ // the beginning and ending brace.
277
+ bool ParseMessageBlock(DescriptorProto* message,
278
+ const LocationRecorder& message_location);
279
+ bool ParseEnumBlock(EnumDescriptorProto* enum_type,
280
+ const LocationRecorder& enum_location);
281
+ bool ParseServiceBlock(ServiceDescriptorProto* service,
282
+ const LocationRecorder& service_location);
283
+
284
+ // Parse one statement within a message, enum, or service block, inclunding
285
+ // final semicolon.
286
+ bool ParseMessageStatement(DescriptorProto* message,
287
+ const LocationRecorder& message_location);
288
+ bool ParseEnumStatement(EnumDescriptorProto* message,
289
+ const LocationRecorder& enum_location);
290
+ bool ParseServiceStatement(ServiceDescriptorProto* message,
291
+ const LocationRecorder& service_location);
292
+
293
+ // Parse a field of a message. If the field is a group, its type will be
294
+ // added to "messages".
295
+ //
296
+ // parent_location and location_field_number_for_nested_type are needed when
297
+ // parsing groups -- we need to generate a nested message type within the
298
+ // parent and record its location accordingly. Since the parent could be
299
+ // either a FileDescriptorProto or a DescriptorProto, we must pass in the
300
+ // correct field number to use.
301
+ bool ParseMessageField(FieldDescriptorProto* field,
302
+ RepeatedPtrField<DescriptorProto>* messages,
303
+ const LocationRecorder& parent_location,
304
+ int location_field_number_for_nested_type,
305
+ const LocationRecorder& field_location);
306
+
307
+ // Parse an "extensions" declaration.
308
+ bool ParseExtensions(DescriptorProto* message,
309
+ const LocationRecorder& extensions_location);
310
+
311
+ // Parse an "extend" declaration. (See also comments for
312
+ // ParseMessageField().)
313
+ bool ParseExtend(RepeatedPtrField<FieldDescriptorProto>* extensions,
314
+ RepeatedPtrField<DescriptorProto>* messages,
315
+ const LocationRecorder& parent_location,
316
+ int location_field_number_for_nested_type,
317
+ const LocationRecorder& extend_location);
318
+
319
+ // Parse a single enum value within an enum block.
320
+ bool ParseEnumConstant(EnumValueDescriptorProto* enum_value,
321
+ const LocationRecorder& enum_value_location);
322
+
323
+ // Parse enum constant options, i.e. the list in square brackets at the end
324
+ // of the enum constant value definition.
325
+ bool ParseEnumConstantOptions(EnumValueDescriptorProto* value,
326
+ const LocationRecorder& enum_value_location);
327
+
328
+ // Parse a single method within a service definition.
329
+ bool ParseServiceMethod(MethodDescriptorProto* method,
330
+ const LocationRecorder& method_location);
331
+
332
+ // Parse "required", "optional", or "repeated" and fill in "label"
333
+ // with the value.
334
+ bool ParseLabel(FieldDescriptorProto::Label* label);
335
+
336
+ // Parse a type name and fill in "type" (if it is a primitive) or
337
+ // "type_name" (if it is not) with the type parsed.
338
+ bool ParseType(FieldDescriptorProto::Type* type,
339
+ string* type_name);
340
+ // Parse a user-defined type and fill in "type_name" with the name.
341
+ // If a primitive type is named, it is treated as an error.
342
+ bool ParseUserDefinedType(string* type_name);
343
+
344
+ // Parses field options, i.e. the stuff in square brackets at the end
345
+ // of a field definition. Also parses default value.
346
+ bool ParseFieldOptions(FieldDescriptorProto* field,
347
+ const LocationRecorder& field_location);
348
+
349
+ // Parse the "default" option. This needs special handling because its
350
+ // type is the field's type.
351
+ bool ParseDefaultAssignment(FieldDescriptorProto* field,
352
+ const LocationRecorder& field_location);
353
+
354
+ // Parse a single option name/value pair, e.g. "ctype = CORD". The name
355
+ // identifies a field of the given Message, and the value of that field
356
+ // is set to the parsed value.
357
+ bool ParseOptionAssignment(Message* options,
358
+ const LocationRecorder& options_location);
359
+
360
+ // Parses a single part of a multipart option name. A multipart name consists
361
+ // of names separated by dots. Each name is either an identifier or a series
362
+ // of identifiers separated by dots and enclosed in parentheses. E.g.,
363
+ // "foo.(bar.baz).qux".
364
+ bool ParseOptionNamePart(UninterpretedOption* uninterpreted_option,
365
+ const LocationRecorder& part_location);
366
+
367
+ // Parses a string surrounded by balanced braces. Strips off the outer
368
+ // braces and stores the enclosed string in *value.
369
+ // E.g.,
370
+ // { foo } *value gets 'foo'
371
+ // { foo { bar: box } } *value gets 'foo { bar: box }'
372
+ // {} *value gets ''
373
+ //
374
+ // REQUIRES: LookingAt("{")
375
+ // When finished successfully, we are looking at the first token past
376
+ // the ending brace.
377
+ bool ParseUninterpretedBlock(string* value);
378
+
379
+ // =================================================================
380
+
381
+ io::Tokenizer* input_;
382
+ io::ErrorCollector* error_collector_;
383
+ SourceCodeInfo* source_code_info_;
384
+ SourceLocationTable* source_location_table_; // legacy
385
+ bool had_errors_;
386
+ bool require_syntax_identifier_;
387
+ bool stop_after_syntax_identifier_;
388
+ string syntax_identifier_;
389
+
390
+ GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(Parser);
391
+ };
392
+
393
+ // A table mapping (descriptor, ErrorLocation) pairs -- as reported by
394
+ // DescriptorPool when validating descriptors -- to line and column numbers
395
+ // within the original source code.
396
+ //
397
+ // This is semi-obsolete: FileDescriptorProto.source_code_info now contains
398
+ // far more complete information about source locations. However, as of this
399
+ // writing you still need to use SourceLocationTable when integrating with
400
+ // DescriptorPool.
401
+ class LIBPROTOBUF_EXPORT SourceLocationTable {
402
+ public:
403
+ SourceLocationTable();
404
+ ~SourceLocationTable();
405
+
406
+ // Finds the precise location of the given error and fills in *line and
407
+ // *column with the line and column numbers. If not found, sets *line to
408
+ // -1 and *column to 0 (since line = -1 is used to mean "error has no exact
409
+ // location" in the ErrorCollector interface). Returns true if found, false
410
+ // otherwise.
411
+ bool Find(const Message* descriptor,
412
+ DescriptorPool::ErrorCollector::ErrorLocation location,
413
+ int* line, int* column) const;
414
+
415
+ // Adds a location to the table.
416
+ void Add(const Message* descriptor,
417
+ DescriptorPool::ErrorCollector::ErrorLocation location,
418
+ int line, int column);
419
+
420
+ // Clears the contents of the table.
421
+ void Clear();
422
+
423
+ private:
424
+ typedef map<
425
+ pair<const Message*, DescriptorPool::ErrorCollector::ErrorLocation>,
426
+ pair<int, int> > LocationMap;
427
+ LocationMap location_map_;
428
+ };
429
+
430
+ } // namespace compiler
431
+ } // namespace protobuf
432
+
433
+ } // namespace google
434
+ #endif // GOOGLE_PROTOBUF_COMPILER_PARSER_H__