From be92ffbf742de99d807e3de239a2f645db74a5bd Mon Sep 17 00:00:00 2001 From: Jisi Liu Date: Tue, 27 Oct 2015 15:11:38 -0700 Subject: [PATCH] add default_runtime attribute to cc|py rules. This adds implicit dependencies to the coressponding runtime libraries. --- BUILD | 6 +++++- protobuf.bzl | 11 +++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/BUILD b/BUILD index 4f2bc28722..f374e8a975 100644 --- a/BUILD +++ b/BUILD @@ -154,9 +154,9 @@ cc_proto_library( name = "cc_wkt_protos", srcs = WELL_KNOWN_PROTOS, include = "src", - cc_libs = [":protobuf"], internal_bootstrap_hack = 1, protoc = ":protoc", + default_runtime = ":protobuf", ) ################################################################################ @@ -334,6 +334,7 @@ cc_proto_library( srcs = LITE_TEST_PROTOS + TEST_PROTOS, include = "src", protoc = ":protoc", + default_runtime = ":protobuf", deps = [":cc_wkt_protos"], ) @@ -512,6 +513,7 @@ py_proto_library( protoc = ":protoc", py_extra_srcs = [":python_srcs"], py_libs = ["//external:six"], + default_runtime = "", visibility = ["//visibility:public"], ) @@ -532,6 +534,7 @@ py_proto_library( include = "src", protoc = ":protoc", deps = [":protobuf_python"], + default_runtime = "", ) py_proto_library( @@ -543,6 +546,7 @@ py_proto_library( include = "python", protoc = ":protoc", deps = [":python_common_test_protos"], + default_runtime = ":protobuf_python", ) py_library( diff --git a/protobuf.bzl b/protobuf.bzl index 0e2d44f750..e8bc455bbe 100644 --- a/protobuf.bzl +++ b/protobuf.bzl @@ -101,6 +101,7 @@ def cc_proto_library( include=None, protoc="//google/protobuf:protoc", internal_bootstrap_hack=False, + default_runtime="//google/protobuf:protobuf", **kargs): """Bazel rule to create a C++ protobuf library from proto source files @@ -116,6 +117,8 @@ def cc_proto_library( for bootstraping. When it is set to True, no files will be generated. The rule will simply be a provider for .proto files, so that other cc_proto_library can depend on it. + default_runtime: the implicitly default runtime which will be depended on by + the generated cc_library target. **kargs: other keyword arguments that are passed to cc_library. """ @@ -151,6 +154,8 @@ def cc_proto_library( outs=outs, ) + if default_runtime and not default_runtime in cc_libs: + cc_libs += [default_runtime] native.cc_library( name=name, @@ -197,6 +202,7 @@ def py_proto_library( py_libs=[], py_extra_srcs=[], include=None, + default_runtime="//google/protobuf:protobuf_python", protoc="//google/protobuf:protoc", **kargs): """Bazel rule to create a Python protobuf library from proto source files @@ -210,6 +216,8 @@ def py_proto_library( py_extra_srcs: extra source files that will be added to the output py_library. This attribute is used for internal bootstrapping. include: a string indicating the include path of the .proto files. + default_runtime: the implicitly default runtime which will be depended on by + the generated py_library target. protoc: the label of the protocol compiler to generate the sources. **kargs: other keyword arguments that are passed to cc_library. @@ -239,6 +247,9 @@ def py_proto_library( include=include) outs=[internal_copied_filegroup_name] + if default_runtime and not default_runtime in py_libs + deps: + py_libs += [default_runtime] + native.py_library( name=name, srcs=outs+py_extra_srcs,