Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Due to limitations in the toolchains implementation this is required … #801

Merged
15 changes: 15 additions & 0 deletions scala_proto/BUILD
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
load("//scala_proto:scala_proto_toolchain.bzl", "scala_proto_toolchain")
load("//scala_proto:default_dep_sets.bzl", "DEFAULT_SCALAPB_COMPILE_DEPS", "DEFAULT_SCALAPB_GRPC_DEPS")


toolchain_type(
name = "toolchain_type",
Expand Down Expand Up @@ -36,3 +38,16 @@ toolchain(
toolchain_type = "@io_bazel_rules_scala//scala_proto:toolchain_type",
visibility = ["//visibility:public"],
)


java_library(
name="default_scalapb_compile_dependencies",
exports = DEFAULT_SCALAPB_COMPILE_DEPS,
visibility = ["//visibility:public"],
)

java_library(
name="default_scalapb_grpc_dependencies",
exports = DEFAULT_SCALAPB_GRPC_DEPS,
visibility = ["//visibility:public"],
)
10 changes: 8 additions & 2 deletions scala_proto/private/scalapb_aspect.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -133,11 +133,11 @@ def _scalapb_aspect_impl(target, ctx):

toolchain = ctx.toolchains["@io_bazel_rules_scala//scala_proto:toolchain_type"]
flags = []
imps = [j[JavaInfo] for j in toolchain.implicit_compile_deps]
imps = [j[JavaInfo] for j in ctx.attr._implicit_compile_deps]

if toolchain.with_grpc:
flags.append("grpc")
imps.extend([j[JavaInfo] for j in toolchain.grpc_deps])
imps.extend([j[JavaInfo] for j in ctx.attr._grpc_deps])

if toolchain.with_flat_package:
flags.append("flat_package")
Expand Down Expand Up @@ -224,6 +224,12 @@ scalapb_aspect = aspect(
],
attrs = {
"_protoc": attr.label(executable = True, cfg = "host", default = "@com_google_protobuf//:protoc"),
"_implicit_compile_deps": attr.label_list(cfg = "target", default = [
"//external:io_bazel_rules_scala/dependency/proto/implicit_compile_deps",
]),
"_grpc_deps": attr.label_list(cfg = "target", default = [
"//external:io_bazel_rules_scala/dependency/proto/grpc_deps",
])
},
toolchains = [
"@io_bazel_rules_scala//scala:toolchain_type",
Expand Down
21 changes: 20 additions & 1 deletion scala_proto/scala_proto.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,29 @@ load(
"scalapb_aspect",
)

def register_default_proto_dependencies():
if native.existing_rule("io_bazel_rules_scala/dependency/proto/grpc_deps") == None:
native.bind(
name = "io_bazel_rules_scala/dependency/proto/grpc_deps",
actual = "@io_bazel_rules_scala//scala_proto:default_scalapb_compile_dependencies",
)

if native.existing_rule("io_bazel_rules_scala/dependency/proto/implicit_compile_deps") == None:
native.bind(
name = "io_bazel_rules_scala/dependency/proto/implicit_compile_deps",
actual = "@io_bazel_rules_scala//scala_proto:default_scalapb_grpc_dependencies",
)



def scala_proto_repositories(
scala_version = _default_scala_version(),
maven_servers = ["http://central.maven.org/maven2"]):
return scala_proto_default_repositories(scala_version, maven_servers)
ret = scala_proto_default_repositories(scala_version, maven_servers)
register_default_proto_dependencies()
return ret



def _scalapb_proto_library_impl(ctx):
aspect_info = merge_scalapb_aspect_info(
Expand Down
10 changes: 0 additions & 10 deletions scala_proto/scala_proto_toolchain.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,6 @@ def _scala_proto_toolchain_impl(ctx):
with_single_line_to_string = ctx.attr.with_single_line_to_string,
blacklisted_protos = ctx.attr.blacklisted_protos,
code_generator = ctx.attr.code_generator,
grpc_deps=ctx.attr.grpc_deps,
implicit_compile_deps=ctx.attr.implicit_compile_deps,
extra_generator_dependencies = ctx.attr.extra_generator_dependencies,
scalac=ctx.attr.scalac,
named_generators = ctx.attr.named_generators,
Expand Down Expand Up @@ -39,14 +37,6 @@ scala_proto_toolchain = rule(
"extra_generator_dependencies": attr.label_list(
providers = [JavaInfo]
),
"grpc_deps": attr.label_list(
providers = [JavaInfo],
default = DEFAULT_SCALAPB_GRPC_DEPS
),
"implicit_compile_deps": attr.label_list(
providers = [JavaInfo],
default = DEFAULT_SCALAPB_COMPILE_DEPS,
),
"scalac": attr.label(
default = Label(
"@io_bazel_rules_scala//src/java/io/bazel/rulesscala/scalac",
Expand Down
7 changes: 7 additions & 0 deletions test/proto/BUILD
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,13 @@ scalapb_proto_library(
deps = [":test2"],
)

scala_binary(
name = "test_binary_to_ensure_no_host_deps",
main_class = "a.b.c",
visibility = ["//visibility:public"],
deps = [":test_proto_nogrpc"],
)

java_proto_library(
name = "test_proto_java_lib",
deps = [
Expand Down
16 changes: 16 additions & 0 deletions test_rules_scala.sh
Original file line number Diff line number Diff line change
Expand Up @@ -887,6 +887,21 @@ test_scala_classpath_resources_expect_warning_on_namespace_conflict() {
fi
}

scala_pb_library_targets_do_not_have_host_deps() {
set -e
bazel build test/proto:test_binary_to_ensure_no_host_deps
set +e
find bazel-bin/test/proto/test_binary_to_ensure_no_host_deps.runfiles -name '*.jar' -exec readlink {} \; | grep 'bazel-out/host'
RET=$?
set -e
if [ "$RET" == "0" ]; then
echo "Host deps exist in output of target:"
echo "Possibly toolchains limitation?"
find bazel-bin/test/proto/test_binary_to_ensure_no_host_deps.runfiles -name '*.jar' -exec readlink {} \; | grep 'bazel-out/host'
exit 1
fi
}

scala_binary_common_jar_is_exposed_in_build_event_protocol() {
local target=$1
set +e
Expand Down Expand Up @@ -1088,3 +1103,4 @@ $runner test_plus_one_deps_only_works_for_java_info_targets
$runner bazel test //test/... --extra_toolchains="//test_expect_failure/plus_one_deps:plus_one_deps"
$runner test_unused_dependency_fails_even_if_also_exists_in_plus_one_deps
$runner test_coverage_on
$runner scala_pb_library_targets_do_not_have_host_deps