protobuf 2.2.5-java
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +17 -0
- data/.travis.yml +9 -0
- data/.yardopts +5 -0
- data/Gemfile +3 -0
- data/README.md +316 -0
- data/Rakefile +29 -0
- data/UPGRADING.md +60 -0
- data/bin/rpc_server +5 -0
- data/bin/rprotoc +62 -0
- data/examples/addressbook.pb.rb +55 -0
- data/examples/addressbook.proto +24 -0
- data/examples/reading_a_message.rb +32 -0
- data/examples/writing_a_message.rb +46 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/code_generator.h +142 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/command_line_interface.h +318 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_enum.h +99 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_enum_field.h +103 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_extension.h +85 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_field.h +167 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_file.h +98 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_generator.h +72 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_helpers.h +159 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_message.h +170 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_message_field.h +102 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_primitive_field.h +103 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_service.h +118 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_string_field.h +104 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/cpp/cpp_test_bad_identifiers.pb.h +2721 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/importer.h +303 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_enum.h +84 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_enum_field.h +121 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_extension.h +77 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_field.h +108 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_file.h +101 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_generator.h +72 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_helpers.h +213 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_message.h +109 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_message_field.h +134 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_primitive_field.h +121 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_service.h +113 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/java/java_string_field.h +120 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/mock_code_generator.h +113 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/package_info.h +64 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/parser.h +434 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/plugin.h +73 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/plugin.pb.h +790 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/python/python_generator.h +156 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/subprocess.h +108 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/compiler/zip_writer.h +93 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/descriptor.h +1367 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/descriptor.pb.h +5223 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/descriptor_database.h +366 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/dynamic_message.h +136 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/extension_set.h +904 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/generated_message_reflection.h +424 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/generated_message_util.h +82 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/io/coded_stream.h +1102 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/io/coded_stream_inl.h +64 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/io/gzip_stream.h +207 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/io/package_info.h +54 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/io/printer.h +136 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/io/tokenizer.h +313 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/io/zero_copy_stream.h +238 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/io/zero_copy_stream_impl.h +357 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/io/zero_copy_stream_impl_lite.h +340 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/message.h +692 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/message_lite.h +239 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/package_info.h +64 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/reflection_ops.h +80 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/repeated_field.h +1295 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/service.h +291 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/stubs/common.h +1211 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/stubs/hash.h +220 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/stubs/map-util.h +119 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/stubs/once.h +123 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/stubs/stl_util-inl.h +121 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/stubs/strutil.h +457 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/stubs/substitute.h +170 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/test_util.h +174 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/test_util_lite.h +101 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/testing/file.h +83 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/testing/googletest.h +98 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/text_format.h +285 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest.pb.h +11915 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_custom_options.pb.h +2895 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_embed_optimize_for.pb.h +211 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_empty.pb.h +56 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_import.pb.h +188 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_import_lite.pb.h +151 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_lite.pb.h +4752 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_lite_imports_nonlite.pb.h +150 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_mset.pb.h +816 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_no_generic_services.pb.h +197 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unittest_optimize_for.pb.h +403 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/unknown_field_set.h +268 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/wire_format.h +304 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/wire_format_lite.h +620 -0
- data/ext/protobuf-2.4.1/src/google/protobuf/wire_format_lite_inl.h +774 -0
- data/ext/ruby_generator/Makefile +10 -0
- data/ext/ruby_generator/RubyGenerator.cpp +450 -0
- data/ext/ruby_generator/RubyGenerator.h +199 -0
- data/ext/ruby_generator/extconf.rb +36 -0
- data/ext/ruby_generator/protoc-ruby +0 -0
- data/lib/protobuf/cli.rb +188 -0
- data/lib/protobuf/enum.rb +58 -0
- data/lib/protobuf/enum_value.rb +59 -0
- data/lib/protobuf/evented.rb +22 -0
- data/lib/protobuf/exceptions.rb +11 -0
- data/lib/protobuf/ext/eventmachine.rb +14 -0
- data/lib/protobuf/field/base_field.rb +240 -0
- data/lib/protobuf/field/bool_field.rb +36 -0
- data/lib/protobuf/field/bytes_field.rb +38 -0
- data/lib/protobuf/field/double_field.rb +19 -0
- data/lib/protobuf/field/enum_field.rb +50 -0
- data/lib/protobuf/field/extension_fields.rb +32 -0
- data/lib/protobuf/field/field_array.rb +65 -0
- data/lib/protobuf/field/fixed32_field.rb +19 -0
- data/lib/protobuf/field/fixed64_field.rb +22 -0
- data/lib/protobuf/field/float_field.rb +31 -0
- data/lib/protobuf/field/int32_field.rb +12 -0
- data/lib/protobuf/field/int64_field.rb +12 -0
- data/lib/protobuf/field/integer_field.rb +19 -0
- data/lib/protobuf/field/message_field.rb +53 -0
- data/lib/protobuf/field/sfixed32_field.rb +21 -0
- data/lib/protobuf/field/sfixed64_field.rb +24 -0
- data/lib/protobuf/field/signed_integer_field.rb +23 -0
- data/lib/protobuf/field/sint32_field.rb +12 -0
- data/lib/protobuf/field/sint64_field.rb +12 -0
- data/lib/protobuf/field/string_field.rb +14 -0
- data/lib/protobuf/field/uint32_field.rb +12 -0
- data/lib/protobuf/field/uint64_field.rb +12 -0
- data/lib/protobuf/field/varint_field.rb +61 -0
- data/lib/protobuf/field.rb +57 -0
- data/lib/protobuf/logger.rb +86 -0
- data/lib/protobuf/message/decoder.rb +83 -0
- data/lib/protobuf/message/encoder.rb +48 -0
- data/lib/protobuf/message/extend.rb +8 -0
- data/lib/protobuf/message/message.rb +1 -0
- data/lib/protobuf/message.rb +320 -0
- data/lib/protobuf/rpc/buffer.rb +79 -0
- data/lib/protobuf/rpc/client.rb +166 -0
- data/lib/protobuf/rpc/connector.rb +19 -0
- data/lib/protobuf/rpc/connectors/base.rb +38 -0
- data/lib/protobuf/rpc/connectors/common.rb +156 -0
- data/lib/protobuf/rpc/connectors/em_client.rb +84 -0
- data/lib/protobuf/rpc/connectors/eventmachine.rb +87 -0
- data/lib/protobuf/rpc/connectors/socket.rb +73 -0
- data/lib/protobuf/rpc/connectors/zmq.rb +69 -0
- data/lib/protobuf/rpc/error/client_error.rb +31 -0
- data/lib/protobuf/rpc/error/server_error.rb +43 -0
- data/lib/protobuf/rpc/error.rb +25 -0
- data/lib/protobuf/rpc/rpc.pb.rb +118 -0
- data/lib/protobuf/rpc/server.rb +89 -0
- data/lib/protobuf/rpc/servers/evented/server.rb +41 -0
- data/lib/protobuf/rpc/servers/evented_runner.rb +21 -0
- data/lib/protobuf/rpc/servers/socket/server.rb +111 -0
- data/lib/protobuf/rpc/servers/socket/worker.rb +66 -0
- data/lib/protobuf/rpc/servers/socket_runner.rb +27 -0
- data/lib/protobuf/rpc/servers/zmq/broker.rb +87 -0
- data/lib/protobuf/rpc/servers/zmq/server.rb +50 -0
- data/lib/protobuf/rpc/servers/zmq/util.rb +27 -0
- data/lib/protobuf/rpc/servers/zmq/worker.rb +60 -0
- data/lib/protobuf/rpc/servers/zmq_runner.rb +25 -0
- data/lib/protobuf/rpc/service.rb +173 -0
- data/lib/protobuf/rpc/service_dispatcher.rb +130 -0
- data/lib/protobuf/rpc/service_filters.rb +267 -0
- data/lib/protobuf/rpc/stat.rb +83 -0
- data/lib/protobuf/socket.rb +22 -0
- data/lib/protobuf/version.rb +4 -0
- data/lib/protobuf/wire_type.rb +10 -0
- data/lib/protobuf/zmq.rb +21 -0
- data/lib/protobuf.rb +86 -0
- data/proto/rpc.pb.rb +48 -0
- data/proto/rpc.proto +73 -0
- data/protobuf.gemspec +44 -0
- data/spec/benchmark/tasks.rb +179 -0
- data/spec/functional/embedded_service_spec.rb +7 -0
- data/spec/functional/evented_server_spec.rb +64 -0
- data/spec/functional/socket_server_spec.rb +58 -0
- data/spec/functional/zmq_server_spec.rb +58 -0
- data/spec/lib/protobuf/cli_spec.rb +212 -0
- data/spec/lib/protobuf/enum_spec.rb +98 -0
- data/spec/lib/protobuf/enum_value_spec.rb +15 -0
- data/spec/lib/protobuf/logger_spec.rb +131 -0
- data/spec/lib/protobuf/message/encoder_spec.rb +19 -0
- data/spec/lib/protobuf/message_spec.rb +209 -0
- data/spec/lib/protobuf/rpc/client_spec.rb +158 -0
- data/spec/lib/protobuf/rpc/connector_spec.rb +32 -0
- data/spec/lib/protobuf/rpc/connectors/base_spec.rb +50 -0
- data/spec/lib/protobuf/rpc/connectors/common_spec.rb +128 -0
- data/spec/lib/protobuf/rpc/connectors/socket_spec.rb +36 -0
- data/spec/lib/protobuf/rpc/connectors/zmq_spec.rb +22 -0
- data/spec/lib/protobuf/rpc/servers/evented_server_spec.rb +18 -0
- data/spec/lib/protobuf/rpc/servers/socket_server_spec.rb +43 -0
- data/spec/lib/protobuf/rpc/servers/zmq/broker_spec.rb +35 -0
- data/spec/lib/protobuf/rpc/servers/zmq/server_spec.rb +41 -0
- data/spec/lib/protobuf/rpc/servers/zmq/util_spec.rb +45 -0
- data/spec/lib/protobuf/rpc/servers/zmq/worker_spec.rb +44 -0
- data/spec/lib/protobuf/rpc/service_dispatcher_spec.rb +116 -0
- data/spec/lib/protobuf/rpc/service_filters_spec.rb +451 -0
- data/spec/lib/protobuf/rpc/service_spec.rb +165 -0
- data/spec/lib/protobuf_spec.rb +62 -0
- data/spec/spec_helper.rb +51 -0
- data/spec/support/all.rb +6 -0
- data/spec/support/server.rb +101 -0
- data/spec/support/test/enum.pb.rb +34 -0
- data/spec/support/test/enum.proto +12 -0
- data/spec/support/test/resource.pb.rb +58 -0
- data/spec/support/test/resource.proto +31 -0
- data/spec/support/test/resource_service.rb +14 -0
- data/spec/support/test_app_file.rb +2 -0
- data/spec/support/tolerance_matcher.rb +40 -0
- data/test/data/data.bin +3 -0
- data/test/data/data_source.py +14 -0
- data/test/data/types.bin +0 -0
- data/test/data/types_source.py +22 -0
- data/test/data/unk.png +0 -0
- data/test/proto/addressbook.pb.rb +66 -0
- data/test/proto/addressbook.proto +33 -0
- data/test/proto/addressbook_base.pb.rb +58 -0
- data/test/proto/addressbook_base.proto +26 -0
- data/test/proto/addressbook_ext.pb.rb +20 -0
- data/test/proto/addressbook_ext.proto +6 -0
- data/test/proto/collision.pb.rb +17 -0
- data/test/proto/collision.proto +5 -0
- data/test/proto/ext_collision.pb.rb +24 -0
- data/test/proto/ext_collision.proto +8 -0
- data/test/proto/ext_range.pb.rb +22 -0
- data/test/proto/ext_range.proto +7 -0
- data/test/proto/float_default.proto +10 -0
- data/test/proto/lowercase.pb.rb +30 -0
- data/test/proto/lowercase.proto +9 -0
- data/test/proto/merge.pb.rb +39 -0
- data/test/proto/merge.proto +15 -0
- data/test/proto/nested.pb.rb +30 -0
- data/test/proto/nested.proto +9 -0
- data/test/proto/optional_field.pb.rb +35 -0
- data/test/proto/optional_field.proto +12 -0
- data/test/proto/packed.pb.rb +22 -0
- data/test/proto/packed.proto +6 -0
- data/test/proto/rpc.proto +6 -0
- data/test/proto/types.pb.rb +84 -0
- data/test/proto/types.proto +37 -0
- data/test/test_addressbook.rb +56 -0
- data/test/test_enum_value.rb +41 -0
- data/test/test_extension.rb +36 -0
- data/test/test_lowercase.rb +11 -0
- data/test/test_message.rb +128 -0
- data/test/test_optional_field.rb +103 -0
- data/test/test_packed_field.rb +40 -0
- data/test/test_parse.rb +15 -0
- data/test/test_repeated_types.rb +132 -0
- data/test/test_serialize.rb +61 -0
- data/test/test_standard_message.rb +96 -0
- data/test/test_types.rb +226 -0
- metadata +461 -0
@@ -0,0 +1,85 @@
|
|
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
|
+
#ifndef GOOGLE_PROTOBUF_COMPILER_CPP_EXTENSION_H__
|
36
|
+
#define GOOGLE_PROTOBUF_COMPILER_CPP_EXTENSION_H__
|
37
|
+
|
38
|
+
#include <string>
|
39
|
+
#include <google/protobuf/stubs/common.h>
|
40
|
+
|
41
|
+
namespace google {
|
42
|
+
namespace protobuf {
|
43
|
+
class FieldDescriptor; // descriptor.h
|
44
|
+
namespace io {
|
45
|
+
class Printer; // printer.h
|
46
|
+
}
|
47
|
+
}
|
48
|
+
|
49
|
+
namespace protobuf {
|
50
|
+
namespace compiler {
|
51
|
+
namespace cpp {
|
52
|
+
|
53
|
+
// Generates code for an extension, which may be within the scope of some
|
54
|
+
// message or may be at file scope. This is much simpler than FieldGenerator
|
55
|
+
// since extensions are just simple identifiers with interesting types.
|
56
|
+
class ExtensionGenerator {
|
57
|
+
public:
|
58
|
+
// See generator.cc for the meaning of dllexport_decl.
|
59
|
+
explicit ExtensionGenerator(const FieldDescriptor* descriptor,
|
60
|
+
const string& dllexport_decl);
|
61
|
+
~ExtensionGenerator();
|
62
|
+
|
63
|
+
// Header stuff.
|
64
|
+
void GenerateDeclaration(io::Printer* printer);
|
65
|
+
|
66
|
+
// Source file stuff.
|
67
|
+
void GenerateDefinition(io::Printer* printer);
|
68
|
+
|
69
|
+
// Generate code to register the extension.
|
70
|
+
void GenerateRegistration(io::Printer* printer);
|
71
|
+
|
72
|
+
private:
|
73
|
+
const FieldDescriptor* descriptor_;
|
74
|
+
string type_traits_;
|
75
|
+
string dllexport_decl_;
|
76
|
+
|
77
|
+
GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(ExtensionGenerator);
|
78
|
+
};
|
79
|
+
|
80
|
+
} // namespace cpp
|
81
|
+
} // namespace compiler
|
82
|
+
} // namespace protobuf
|
83
|
+
|
84
|
+
} // namespace google
|
85
|
+
#endif // GOOGLE_PROTOBUF_COMPILER_CPP_MESSAGE_H__
|
@@ -0,0 +1,167 @@
|
|
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
|
+
#ifndef GOOGLE_PROTOBUF_COMPILER_CPP_FIELD_H__
|
36
|
+
#define GOOGLE_PROTOBUF_COMPILER_CPP_FIELD_H__
|
37
|
+
|
38
|
+
#include <map>
|
39
|
+
#include <string>
|
40
|
+
|
41
|
+
#include <google/protobuf/stubs/common.h>
|
42
|
+
#include <google/protobuf/descriptor.h>
|
43
|
+
|
44
|
+
namespace google {
|
45
|
+
namespace protobuf {
|
46
|
+
namespace io {
|
47
|
+
class Printer; // printer.h
|
48
|
+
}
|
49
|
+
}
|
50
|
+
|
51
|
+
namespace protobuf {
|
52
|
+
namespace compiler {
|
53
|
+
namespace cpp {
|
54
|
+
|
55
|
+
// Helper function: set variables in the map that are the same for all
|
56
|
+
// field code generators.
|
57
|
+
// ['name', 'index', 'number', 'classname', 'declared_type', 'tag_size',
|
58
|
+
// 'deprecation'].
|
59
|
+
void SetCommonFieldVariables(const FieldDescriptor* descriptor,
|
60
|
+
map<string, string>* variables);
|
61
|
+
|
62
|
+
class FieldGenerator {
|
63
|
+
public:
|
64
|
+
FieldGenerator() {}
|
65
|
+
virtual ~FieldGenerator();
|
66
|
+
|
67
|
+
// Generate lines of code declaring members fields of the message class
|
68
|
+
// needed to represent this field. These are placed inside the message
|
69
|
+
// class.
|
70
|
+
virtual void GeneratePrivateMembers(io::Printer* printer) const = 0;
|
71
|
+
|
72
|
+
// Generate prototypes for all of the accessor functions related to this
|
73
|
+
// field. These are placed inside the class definition.
|
74
|
+
virtual void GenerateAccessorDeclarations(io::Printer* printer) const = 0;
|
75
|
+
|
76
|
+
// Generate inline definitions of accessor functions for this field.
|
77
|
+
// These are placed inside the header after all class definitions.
|
78
|
+
virtual void GenerateInlineAccessorDefinitions(
|
79
|
+
io::Printer* printer) const = 0;
|
80
|
+
|
81
|
+
// Generate definitions of accessors that aren't inlined. These are
|
82
|
+
// placed somewhere in the .cc file.
|
83
|
+
// Most field types don't need this, so the default implementation is empty.
|
84
|
+
virtual void GenerateNonInlineAccessorDefinitions(
|
85
|
+
io::Printer* printer) const {}
|
86
|
+
|
87
|
+
// Generate lines of code (statements, not declarations) which clear the
|
88
|
+
// field. This is used to define the clear_$name$() method as well as
|
89
|
+
// the Clear() method for the whole message.
|
90
|
+
virtual void GenerateClearingCode(io::Printer* printer) const = 0;
|
91
|
+
|
92
|
+
// Generate lines of code (statements, not declarations) which merges the
|
93
|
+
// contents of the field from the current message to the target message,
|
94
|
+
// which is stored in the generated code variable "from".
|
95
|
+
// This is used to fill in the MergeFrom method for the whole message.
|
96
|
+
// Details of this usage can be found in message.cc under the
|
97
|
+
// GenerateMergeFrom method.
|
98
|
+
virtual void GenerateMergingCode(io::Printer* printer) const = 0;
|
99
|
+
|
100
|
+
// Generate lines of code (statements, not declarations) which swaps
|
101
|
+
// this field and the corresponding field of another message, which
|
102
|
+
// is stored in the generated code variable "other". This is used to
|
103
|
+
// define the Swap method. Details of usage can be found in
|
104
|
+
// message.cc under the GenerateSwap method.
|
105
|
+
virtual void GenerateSwappingCode(io::Printer* printer) const = 0;
|
106
|
+
|
107
|
+
// Generate initialization code for private members declared by
|
108
|
+
// GeneratePrivateMembers(). These go into the message class's SharedCtor()
|
109
|
+
// method, invoked by each of the generated constructors.
|
110
|
+
virtual void GenerateConstructorCode(io::Printer* printer) const = 0;
|
111
|
+
|
112
|
+
// Generate any code that needs to go in the class's SharedDtor() method,
|
113
|
+
// invoked by the destructor.
|
114
|
+
// Most field types don't need this, so the default implementation is empty.
|
115
|
+
virtual void GenerateDestructorCode(io::Printer* printer) const {}
|
116
|
+
|
117
|
+
// Generate lines to decode this field, which will be placed inside the
|
118
|
+
// message's MergeFromCodedStream() method.
|
119
|
+
virtual void GenerateMergeFromCodedStream(io::Printer* printer) const = 0;
|
120
|
+
|
121
|
+
// Generate lines to decode this field from a packed value, which will be
|
122
|
+
// placed inside the message's MergeFromCodedStream() method.
|
123
|
+
virtual void GenerateMergeFromCodedStreamWithPacking(io::Printer* printer)
|
124
|
+
const;
|
125
|
+
|
126
|
+
// Generate lines to serialize this field, which are placed within the
|
127
|
+
// message's SerializeWithCachedSizes() method.
|
128
|
+
virtual void GenerateSerializeWithCachedSizes(io::Printer* printer) const = 0;
|
129
|
+
|
130
|
+
// Generate lines to serialize this field directly to the array "target",
|
131
|
+
// which are placed within the message's SerializeWithCachedSizesToArray()
|
132
|
+
// method. This must also advance "target" past the written bytes.
|
133
|
+
virtual void GenerateSerializeWithCachedSizesToArray(
|
134
|
+
io::Printer* printer) const = 0;
|
135
|
+
|
136
|
+
// Generate lines to compute the serialized size of this field, which
|
137
|
+
// are placed in the message's ByteSize() method.
|
138
|
+
virtual void GenerateByteSize(io::Printer* printer) const = 0;
|
139
|
+
|
140
|
+
private:
|
141
|
+
GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(FieldGenerator);
|
142
|
+
};
|
143
|
+
|
144
|
+
// Convenience class which constructs FieldGenerators for a Descriptor.
|
145
|
+
class FieldGeneratorMap {
|
146
|
+
public:
|
147
|
+
explicit FieldGeneratorMap(const Descriptor* descriptor);
|
148
|
+
~FieldGeneratorMap();
|
149
|
+
|
150
|
+
const FieldGenerator& get(const FieldDescriptor* field) const;
|
151
|
+
|
152
|
+
private:
|
153
|
+
const Descriptor* descriptor_;
|
154
|
+
scoped_array<scoped_ptr<FieldGenerator> > field_generators_;
|
155
|
+
|
156
|
+
static FieldGenerator* MakeGenerator(const FieldDescriptor* field);
|
157
|
+
|
158
|
+
GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(FieldGeneratorMap);
|
159
|
+
};
|
160
|
+
|
161
|
+
|
162
|
+
} // namespace cpp
|
163
|
+
} // namespace compiler
|
164
|
+
} // namespace protobuf
|
165
|
+
|
166
|
+
} // namespace google
|
167
|
+
#endif // GOOGLE_PROTOBUF_COMPILER_CPP_FIELD_H__
|
@@ -0,0 +1,98 @@
|
|
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
|
+
#ifndef GOOGLE_PROTOBUF_COMPILER_CPP_FILE_H__
|
36
|
+
#define GOOGLE_PROTOBUF_COMPILER_CPP_FILE_H__
|
37
|
+
|
38
|
+
#include <string>
|
39
|
+
#include <vector>
|
40
|
+
#include <google/protobuf/stubs/common.h>
|
41
|
+
#include <google/protobuf/compiler/cpp/cpp_field.h>
|
42
|
+
|
43
|
+
namespace google {
|
44
|
+
namespace protobuf {
|
45
|
+
class FileDescriptor; // descriptor.h
|
46
|
+
namespace io {
|
47
|
+
class Printer; // printer.h
|
48
|
+
}
|
49
|
+
}
|
50
|
+
|
51
|
+
namespace protobuf {
|
52
|
+
namespace compiler {
|
53
|
+
namespace cpp {
|
54
|
+
|
55
|
+
class EnumGenerator; // enum.h
|
56
|
+
class MessageGenerator; // message.h
|
57
|
+
class ServiceGenerator; // service.h
|
58
|
+
class ExtensionGenerator; // extension.h
|
59
|
+
|
60
|
+
class FileGenerator {
|
61
|
+
public:
|
62
|
+
// See generator.cc for the meaning of dllexport_decl.
|
63
|
+
explicit FileGenerator(const FileDescriptor* file,
|
64
|
+
const string& dllexport_decl);
|
65
|
+
~FileGenerator();
|
66
|
+
|
67
|
+
void GenerateHeader(io::Printer* printer);
|
68
|
+
void GenerateSource(io::Printer* printer);
|
69
|
+
|
70
|
+
private:
|
71
|
+
// Generate the BuildDescriptors() procedure, which builds all descriptors
|
72
|
+
// for types defined in the file.
|
73
|
+
void GenerateBuildDescriptors(io::Printer* printer);
|
74
|
+
|
75
|
+
void GenerateNamespaceOpeners(io::Printer* printer);
|
76
|
+
void GenerateNamespaceClosers(io::Printer* printer);
|
77
|
+
|
78
|
+
const FileDescriptor* file_;
|
79
|
+
|
80
|
+
scoped_array<scoped_ptr<MessageGenerator> > message_generators_;
|
81
|
+
scoped_array<scoped_ptr<EnumGenerator> > enum_generators_;
|
82
|
+
scoped_array<scoped_ptr<ServiceGenerator> > service_generators_;
|
83
|
+
scoped_array<scoped_ptr<ExtensionGenerator> > extension_generators_;
|
84
|
+
|
85
|
+
// E.g. if the package is foo.bar, package_parts_ is {"foo", "bar"}.
|
86
|
+
vector<string> package_parts_;
|
87
|
+
|
88
|
+
string dllexport_decl_;
|
89
|
+
|
90
|
+
GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(FileGenerator);
|
91
|
+
};
|
92
|
+
|
93
|
+
} // namespace cpp
|
94
|
+
} // namespace compiler
|
95
|
+
} // namespace protobuf
|
96
|
+
|
97
|
+
} // namespace google
|
98
|
+
#endif // GOOGLE_PROTOBUF_COMPILER_CPP_FILE_H__
|
@@ -0,0 +1,72 @@
|
|
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
|
+
// Generates C++ code for a given .proto file.
|
36
|
+
|
37
|
+
#ifndef GOOGLE_PROTOBUF_COMPILER_CPP_GENERATOR_H__
|
38
|
+
#define GOOGLE_PROTOBUF_COMPILER_CPP_GENERATOR_H__
|
39
|
+
|
40
|
+
#include <string>
|
41
|
+
#include <google/protobuf/compiler/code_generator.h>
|
42
|
+
|
43
|
+
namespace google {
|
44
|
+
namespace protobuf {
|
45
|
+
namespace compiler {
|
46
|
+
namespace cpp {
|
47
|
+
|
48
|
+
// CodeGenerator implementation which generates a C++ source file and
|
49
|
+
// header. If you create your own protocol compiler binary and you want
|
50
|
+
// it to support C++ output, you can do so by registering an instance of this
|
51
|
+
// CodeGenerator with the CommandLineInterface in your main() function.
|
52
|
+
class LIBPROTOC_EXPORT CppGenerator : public CodeGenerator {
|
53
|
+
public:
|
54
|
+
CppGenerator();
|
55
|
+
~CppGenerator();
|
56
|
+
|
57
|
+
// implements CodeGenerator ----------------------------------------
|
58
|
+
bool Generate(const FileDescriptor* file,
|
59
|
+
const string& parameter,
|
60
|
+
GeneratorContext* generator_context,
|
61
|
+
string* error) const;
|
62
|
+
|
63
|
+
private:
|
64
|
+
GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(CppGenerator);
|
65
|
+
};
|
66
|
+
|
67
|
+
} // namespace cpp
|
68
|
+
} // namespace compiler
|
69
|
+
} // namespace protobuf
|
70
|
+
|
71
|
+
} // namespace google
|
72
|
+
#endif // GOOGLE_PROTOBUF_COMPILER_CPP_GENERATOR_H__
|
@@ -0,0 +1,159 @@
|
|
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
|
+
#ifndef GOOGLE_PROTOBUF_COMPILER_CPP_HELPERS_H__
|
36
|
+
#define GOOGLE_PROTOBUF_COMPILER_CPP_HELPERS_H__
|
37
|
+
|
38
|
+
#include <string>
|
39
|
+
#include <google/protobuf/descriptor.h>
|
40
|
+
#include <google/protobuf/descriptor.pb.h>
|
41
|
+
|
42
|
+
namespace google {
|
43
|
+
namespace protobuf {
|
44
|
+
namespace compiler {
|
45
|
+
namespace cpp {
|
46
|
+
|
47
|
+
// Commonly-used separator comments. Thick is a line of '=', thin is a line
|
48
|
+
// of '-'.
|
49
|
+
extern const char kThickSeparator[];
|
50
|
+
extern const char kThinSeparator[];
|
51
|
+
|
52
|
+
// Returns the non-nested type name for the given type. If "qualified" is
|
53
|
+
// true, prefix the type with the full namespace. For example, if you had:
|
54
|
+
// package foo.bar;
|
55
|
+
// message Baz { message Qux {} }
|
56
|
+
// Then the qualified ClassName for Qux would be:
|
57
|
+
// ::foo::bar::Baz_Qux
|
58
|
+
// While the non-qualified version would be:
|
59
|
+
// Baz_Qux
|
60
|
+
string ClassName(const Descriptor* descriptor, bool qualified);
|
61
|
+
string ClassName(const EnumDescriptor* enum_descriptor, bool qualified);
|
62
|
+
|
63
|
+
string SuperClassName(const Descriptor* descriptor);
|
64
|
+
|
65
|
+
// Get the (unqualified) name that should be used for this field in C++ code.
|
66
|
+
// The name is coerced to lower-case to emulate proto1 behavior. People
|
67
|
+
// should be using lowercase-with-underscores style for proto field names
|
68
|
+
// anyway, so normally this just returns field->name().
|
69
|
+
string FieldName(const FieldDescriptor* field);
|
70
|
+
|
71
|
+
// Get the unqualified name that should be used for a field's field
|
72
|
+
// number constant.
|
73
|
+
string FieldConstantName(const FieldDescriptor *field);
|
74
|
+
|
75
|
+
// Returns the scope where the field was defined (for extensions, this is
|
76
|
+
// different from the message type to which the field applies).
|
77
|
+
inline const Descriptor* FieldScope(const FieldDescriptor* field) {
|
78
|
+
return field->is_extension() ?
|
79
|
+
field->extension_scope() : field->containing_type();
|
80
|
+
}
|
81
|
+
|
82
|
+
// Returns the fully-qualified type name field->message_type(). Usually this
|
83
|
+
// is just ClassName(field->message_type(), true);
|
84
|
+
string FieldMessageTypeName(const FieldDescriptor* field);
|
85
|
+
|
86
|
+
// Strips ".proto" or ".protodevel" from the end of a filename.
|
87
|
+
string StripProto(const string& filename);
|
88
|
+
|
89
|
+
// Get the C++ type name for a primitive type (e.g. "double", "::google::protobuf::int32", etc.).
|
90
|
+
// Note: non-built-in type names will be qualified, meaning they will start
|
91
|
+
// with a ::. If you are using the type as a template parameter, you will
|
92
|
+
// need to insure there is a space between the < and the ::, because the
|
93
|
+
// ridiculous C++ standard defines "<:" to be a synonym for "[".
|
94
|
+
const char* PrimitiveTypeName(FieldDescriptor::CppType type);
|
95
|
+
|
96
|
+
// Get the declared type name in CamelCase format, as is used e.g. for the
|
97
|
+
// methods of WireFormat. For example, TYPE_INT32 becomes "Int32".
|
98
|
+
const char* DeclaredTypeMethodName(FieldDescriptor::Type type);
|
99
|
+
|
100
|
+
// Get code that evaluates to the field's default value.
|
101
|
+
string DefaultValue(const FieldDescriptor* field);
|
102
|
+
|
103
|
+
// Convert a file name into a valid identifier.
|
104
|
+
string FilenameIdentifier(const string& filename);
|
105
|
+
|
106
|
+
// Return the name of the AddDescriptors() function for a given file.
|
107
|
+
string GlobalAddDescriptorsName(const string& filename);
|
108
|
+
|
109
|
+
// Return the name of the AssignDescriptors() function for a given file.
|
110
|
+
string GlobalAssignDescriptorsName(const string& filename);
|
111
|
+
|
112
|
+
// Return the name of the ShutdownFile() function for a given file.
|
113
|
+
string GlobalShutdownFileName(const string& filename);
|
114
|
+
|
115
|
+
// Escape C++ trigraphs by escaping question marks to \?
|
116
|
+
string EscapeTrigraphs(const string& to_escape);
|
117
|
+
|
118
|
+
// Do message classes in this file keep track of unknown fields?
|
119
|
+
inline bool HasUnknownFields(const FileDescriptor *file) {
|
120
|
+
return file->options().optimize_for() != FileOptions::LITE_RUNTIME;
|
121
|
+
}
|
122
|
+
|
123
|
+
// Does this file have generated parsing, serialization, and other
|
124
|
+
// standard methods for which reflection-based fallback implementations exist?
|
125
|
+
inline bool HasGeneratedMethods(const FileDescriptor *file) {
|
126
|
+
return file->options().optimize_for() != FileOptions::CODE_SIZE;
|
127
|
+
}
|
128
|
+
|
129
|
+
// Do message classes in this file have descriptor and refelction methods?
|
130
|
+
inline bool HasDescriptorMethods(const FileDescriptor *file) {
|
131
|
+
return file->options().optimize_for() != FileOptions::LITE_RUNTIME;
|
132
|
+
}
|
133
|
+
|
134
|
+
// Should we generate generic services for this file?
|
135
|
+
inline bool HasGenericServices(const FileDescriptor *file) {
|
136
|
+
return file->service_count() > 0 &&
|
137
|
+
file->options().optimize_for() != FileOptions::LITE_RUNTIME &&
|
138
|
+
file->options().cc_generic_services();
|
139
|
+
}
|
140
|
+
|
141
|
+
// Should string fields in this file verify that their contents are UTF-8?
|
142
|
+
inline bool HasUtf8Verification(const FileDescriptor* file) {
|
143
|
+
return file->options().optimize_for() != FileOptions::LITE_RUNTIME;
|
144
|
+
}
|
145
|
+
|
146
|
+
// Should we generate a separate, super-optimized code path for serializing to
|
147
|
+
// flat arrays? We don't do this in Lite mode because we'd rather reduce code
|
148
|
+
// size.
|
149
|
+
inline bool HasFastArraySerialization(const FileDescriptor* file) {
|
150
|
+
return file->options().optimize_for() == FileOptions::SPEED;
|
151
|
+
}
|
152
|
+
|
153
|
+
|
154
|
+
} // namespace cpp
|
155
|
+
} // namespace compiler
|
156
|
+
} // namespace protobuf
|
157
|
+
|
158
|
+
} // namespace google
|
159
|
+
#endif // GOOGLE_PROTOBUF_COMPILER_CPP_HELPERS_H__
|