diff options
author | agl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-09-30 16:14:09 +0000 |
---|---|---|
committer | agl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-09-30 16:14:09 +0000 |
commit | a9fdefce3f499c046e4f0dd9c19b82ff5462200c (patch) | |
tree | 844e2107f322b31660799636e028bb286072aec9 /third_party/protobuf/protobuf.gyp | |
parent | 9cf1e9da7f5afc614ef102863a8a3b924e662cce (diff) | |
download | chromium_src-a9fdefce3f499c046e4f0dd9c19b82ff5462200c.zip chromium_src-a9fdefce3f499c046e4f0dd9c19b82ff5462200c.tar.gz chromium_src-a9fdefce3f499c046e4f0dd9c19b82ff5462200c.tar.bz2 |
protobuf: check in local copy.
This change doesn't make us *use* the local copy yet, that's the next
step. The checked in code is taken from the same SVN revision which we
currently pull with DEPS.
(This is a no-op change from the point of view of the build.)
BUG=56579
TEST=none
http://codereview.chromium.org/3549005
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@61072 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'third_party/protobuf/protobuf.gyp')
-rw-r--r-- | third_party/protobuf/protobuf.gyp | 309 |
1 files changed, 309 insertions, 0 deletions
diff --git a/third_party/protobuf/protobuf.gyp b/third_party/protobuf/protobuf.gyp new file mode 100644 index 0000000..923ba77 --- /dev/null +++ b/third_party/protobuf/protobuf.gyp @@ -0,0 +1,309 @@ +# Copyright (c) 2009 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +{ + 'conditions': [ + ['OS!="win"', { + 'variables': { + 'config_h_dir': + '.', # crafted for gcc/linux. + }, + }, { # else, OS=="win" + 'variables': { + 'config_h_dir': + 'vsprojects', # crafted for msvc. + }, + 'target_defaults': { + 'msvs_disabled_warnings': [ + 4018, # signed/unsigned mismatch in comparison + 4244, # implicit conversion, possible loss of data + 4355, # 'this' used in base member initializer list + ], + 'defines!': [ + 'WIN32_LEAN_AND_MEAN', # Protobuf defines this itself. + ], + }, + }] + ], + 'targets': [ + # The "lite" lib is about 1/7th the size of the heavy lib, + # but it doesn't support some of the more exotic features of + # protobufs, like reflection. To generate C++ code that can link + # against the lite version of the library, add the option line: + # + # option optimize_for = LITE_RUNTIME; + # + # to your .proto file. + { + 'target_name': 'protobuf_lite', + 'type': '<(library)', + 'toolsets': ['host', 'target'], + 'sources': [ + 'src/google/protobuf/stubs/common.h', + 'src/google/protobuf/stubs/once.h', + 'src/google/protobuf/extension_set.h', + 'src/google/protobuf/generated_message_util.h', + 'src/google/protobuf/message_lite.h', + 'src/google/protobuf/repeated_field.h', + 'src/google/protobuf/wire_format_lite.h', + 'src/google/protobuf/wire_format_lite_inl.h', + 'src/google/protobuf/io/coded_stream.h', + 'src/google/protobuf/io/zero_copy_stream.h', + 'src/google/protobuf/io/zero_copy_stream_impl_lite.h', + + 'src/google/protobuf/stubs/common.cc', + 'src/google/protobuf/stubs/once.cc', + 'src/google/protobuf/stubs/hash.cc', + 'src/google/protobuf/stubs/hash.h', + 'src/google/protobuf/stubs/map-util.h', + 'src/google/protobuf/stubs/stl_util-inl.h', + 'src/google/protobuf/extension_set.cc', + 'src/google/protobuf/generated_message_util.cc', + 'src/google/protobuf/message_lite.cc', + 'src/google/protobuf/repeated_field.cc', + 'src/google/protobuf/wire_format_lite.cc', + 'src/google/protobuf/io/coded_stream.cc', + 'src/google/protobuf/io/coded_stream_inl.h', + 'src/google/protobuf/io/zero_copy_stream.cc', + 'src/google/protobuf/io/zero_copy_stream_impl_lite.cc', + '<(config_h_dir)/config.h', + ], + 'include_dirs': [ + '<(config_h_dir)', + 'src', + ], + # This macro must be defined to suppress the use of dynamic_cast<>, + # which requires RTTI. + 'defines': [ + 'GOOGLE_PROTOBUF_NO_RTTI', + ], + + 'direct_dependent_settings': { + 'include_dirs': [ + '<(config_h_dir)', + 'src', + ], + 'defines': [ + 'GOOGLE_PROTOBUF_NO_RTTI', + ], + }, + }, + # This is the full, heavy protobuf lib that's needed for c++ .proto's + # that don't specify the LITE_RUNTIME option. The protocol + # compiler itself (protoc) falls into that category. + { + 'target_name': 'protobuf', + 'type': '<(library)', + 'toolsets': ['host','target'], + 'sources': [ + 'src/google/protobuf/descriptor.h', + 'src/google/protobuf/descriptor.pb.h', + 'src/google/protobuf/descriptor_database.h', + 'src/google/protobuf/dynamic_message.h', + 'src/google/protobuf/generated_message_reflection.h', + 'src/google/protobuf/message.h', + 'src/google/protobuf/reflection_ops.h', + 'src/google/protobuf/service.h', + 'src/google/protobuf/text_format.h', + 'src/google/protobuf/unknown_field_set.h', + 'src/google/protobuf/wire_format.h', + 'src/google/protobuf/wire_format_inl.h', + 'src/google/protobuf/io/gzip_stream.h', + 'src/google/protobuf/io/printer.h', + 'src/google/protobuf/io/tokenizer.h', + 'src/google/protobuf/io/zero_copy_stream_impl.h', + 'src/google/protobuf/compiler/code_generator.h', + 'src/google/protobuf/compiler/command_line_interface.h', + 'src/google/protobuf/compiler/importer.h', + 'src/google/protobuf/compiler/parser.h', + + 'src/google/protobuf/stubs/strutil.cc', + 'src/google/protobuf/stubs/strutil.h', + 'src/google/protobuf/stubs/substitute.cc', + 'src/google/protobuf/stubs/substitute.h', + 'src/google/protobuf/stubs/structurally_valid.cc', + 'src/google/protobuf/descriptor.cc', + 'src/google/protobuf/descriptor.pb.cc', + 'src/google/protobuf/descriptor_database.cc', + 'src/google/protobuf/dynamic_message.cc', + 'src/google/protobuf/extension_set_heavy.cc', + 'src/google/protobuf/generated_message_reflection.cc', + 'src/google/protobuf/message.cc', + 'src/google/protobuf/reflection_ops.cc', + 'src/google/protobuf/service.cc', + 'src/google/protobuf/text_format.cc', + 'src/google/protobuf/unknown_field_set.cc', + 'src/google/protobuf/wire_format.cc', + # This file pulls in zlib, but it's not actually used by protoc, so + # instead of compiling zlib for the host, let's just exclude this. + # 'src/src/google/protobuf/io/gzip_stream.cc', + 'src/google/protobuf/io/printer.cc', + 'src/google/protobuf/io/tokenizer.cc', + 'src/google/protobuf/io/zero_copy_stream_impl.cc', + 'src/google/protobuf/compiler/importer.cc', + 'src/google/protobuf/compiler/parser.cc', + ], + 'dependencies': [ + 'protobuf_lite', + ], + 'export_dependent_settings': [ + 'protobuf_lite', + ], + }, + { + 'target_name': 'protoc', + 'type': 'executable', + 'toolsets': ['host'], + 'sources': [ + 'src/google/protobuf/compiler/code_generator.cc', + 'src/google/protobuf/compiler/command_line_interface.cc', + 'src/google/protobuf/compiler/plugin.cc', + 'src/google/protobuf/compiler/plugin.pb.cc', + 'src/google/protobuf/compiler/subprocess.cc', + 'src/google/protobuf/compiler/subprocess.h', + 'src/google/protobuf/compiler/zip_writer.cc', + 'src/google/protobuf/compiler/zip_writer.h', + 'src/google/protobuf/compiler/cpp/cpp_enum.cc', + 'src/google/protobuf/compiler/cpp/cpp_enum.h', + 'src/google/protobuf/compiler/cpp/cpp_enum_field.cc', + 'src/google/protobuf/compiler/cpp/cpp_enum_field.h', + 'src/google/protobuf/compiler/cpp/cpp_extension.cc', + 'src/google/protobuf/compiler/cpp/cpp_extension.h', + 'src/google/protobuf/compiler/cpp/cpp_field.cc', + 'src/google/protobuf/compiler/cpp/cpp_field.h', + 'src/google/protobuf/compiler/cpp/cpp_file.cc', + 'src/google/protobuf/compiler/cpp/cpp_file.h', + 'src/google/protobuf/compiler/cpp/cpp_generator.cc', + 'src/google/protobuf/compiler/cpp/cpp_helpers.cc', + 'src/google/protobuf/compiler/cpp/cpp_helpers.h', + 'src/google/protobuf/compiler/cpp/cpp_message.cc', + 'src/google/protobuf/compiler/cpp/cpp_message.h', + 'src/google/protobuf/compiler/cpp/cpp_message_field.cc', + 'src/google/protobuf/compiler/cpp/cpp_message_field.h', + 'src/google/protobuf/compiler/cpp/cpp_primitive_field.cc', + 'src/google/protobuf/compiler/cpp/cpp_primitive_field.h', + 'src/google/protobuf/compiler/cpp/cpp_service.cc', + 'src/google/protobuf/compiler/cpp/cpp_service.h', + 'src/google/protobuf/compiler/cpp/cpp_string_field.cc', + 'src/google/protobuf/compiler/cpp/cpp_string_field.h', + 'src/google/protobuf/compiler/java/java_enum.cc', + 'src/google/protobuf/compiler/java/java_enum.h', + 'src/google/protobuf/compiler/java/java_enum_field.cc', + 'src/google/protobuf/compiler/java/java_enum_field.h', + 'src/google/protobuf/compiler/java/java_extension.cc', + 'src/google/protobuf/compiler/java/java_extension.h', + 'src/google/protobuf/compiler/java/java_field.cc', + 'src/google/protobuf/compiler/java/java_field.h', + 'src/google/protobuf/compiler/java/java_file.cc', + 'src/google/protobuf/compiler/java/java_file.h', + 'src/google/protobuf/compiler/java/java_generator.cc', + 'src/google/protobuf/compiler/java/java_helpers.cc', + 'src/google/protobuf/compiler/java/java_helpers.h', + 'src/google/protobuf/compiler/java/java_message.cc', + 'src/google/protobuf/compiler/java/java_message.h', + 'src/google/protobuf/compiler/java/java_message_field.cc', + 'src/google/protobuf/compiler/java/java_message_field.h', + 'src/google/protobuf/compiler/java/java_primitive_field.cc', + 'src/google/protobuf/compiler/java/java_primitive_field.h', + 'src/google/protobuf/compiler/java/java_service.cc', + 'src/google/protobuf/compiler/java/java_service.h', + 'src/google/protobuf/compiler/python/python_generator.cc', + 'src/google/protobuf/compiler/main.cc', + ], + 'dependencies': [ + 'protobuf', + ], + 'include_dirs': [ + '<(config_h_dir)', + 'src/src', + ], + }, + { + # Generate the python module needed by all protoc-generated Python code. + 'target_name': 'py_proto', + 'type': 'none', + 'copies': [ + { + 'destination': '<(PRODUCT_DIR)/pyproto/google/', + 'files': [ + # google/ module gets an empty __init__.py. + '__init__.py', + ], + }, + { + 'destination': '<(PRODUCT_DIR)/pyproto/google/protobuf', + 'files': [ + 'python/google/protobuf/__init__.py', + 'python/google/protobuf/descriptor.py', + 'python/google/protobuf/message.py', + 'python/google/protobuf/reflection.py', + 'python/google/protobuf/service.py', + 'python/google/protobuf/service_reflection.py', + 'python/google/protobuf/text_format.py', + + # TODO(ncarter): protoc's python generator treats descriptor.proto + # specially, but it's not possible to trigger the special treatment + # unless you run protoc from ./src/src (the treatment is based + # on the path to the .proto file matching a constant exactly). + # I'm not sure how to convince gyp to execute a rule from a + # different directory. Until this is resolved, use a copy of + # descriptor_pb2.py that I manually generated. + 'descriptor_pb2.py', + ], + }, + { + 'destination': '<(PRODUCT_DIR)/pyproto/google/protobuf/internal', + 'files': [ + 'python/google/protobuf/internal/__init__.py', + 'python/google/protobuf/internal/containers.py', + 'python/google/protobuf/internal/decoder.py', + 'python/google/protobuf/internal/encoder.py', + 'python/google/protobuf/internal/generator_test.py', + 'python/google/protobuf/internal/message_listener.py', + 'python/google/protobuf/internal/type_checkers.py', + 'python/google/protobuf/internal/wire_format.py', + ], + }, + ], + # # We can't generate a proper descriptor_pb2.py -- see earlier comment. + # 'rules': [ + # { + # 'rule_name': 'genproto', + # 'extension': 'proto', + # 'inputs': [ + # '<(PRODUCT_DIR)/<(EXECUTABLE_PREFIX)protoc<(EXECUTABLE_SUFFIX)', + # ], + # 'variables': { + # # The protoc compiler requires a proto_path argument with the + # # directory containing the .proto file. + # 'rule_input_relpath': 'src/google/protobuf', + # }, + # 'outputs': [ + # '<(PRODUCT_DIR)/pyproto/google/protobuf/<(RULE_INPUT_ROOT)_pb2.py', + # ], + # 'action': [ + # '<(PRODUCT_DIR)/<(EXECUTABLE_PREFIX)protoc<(EXECUTABLE_SUFFIX)', + # '-I./src', + # '-I.', + # '--python_out=<(PRODUCT_DIR)/pyproto/google/protobuf', + # 'google/protobuf/descriptor.proto', + # ], + # 'message': 'Generating Python code from <(RULE_INPUT_PATH)', + # }, + # ], + # 'dependencies': [ + # 'protoc#host', + # ], + # 'sources': [ + # 'src/google/protobuf/descriptor.proto', + # ], + }, + ], +} + +# Local Variables: +# tab-width:2 +# indent-tabs-mode:nil +# End: +# vim: set expandtab tabstop=2 shiftwidth=2: |