Use common repository prefix everywhere

Build macros in earlier versions of Bazel (pre-1.0) needed to specify
targets in a different format, depending from where they were
included/expanded at build time.

For example, a `sapi_library()` macro invocation in one of the directories
under `examples`, always needed to depend on the SAPI main library as
`//sandboxed_api:sapi`. When using SAPI from another Bazel project, the
same macro would have needed to depend on
`@com_google_sandboxed_api//sandboxed_api:sapi`. The `sapi_library()`
macro was thus checking the repository name and conditionally changed
the dependencies. This approach is brittle and as of Bazel 3.1.0 no
longer works.

This CL simple removes the conditional prefix and unconditionally uses
`@com_google_sandboxed_api`.

Tested on Bazel 1.2.1, 2.2.0 and 3.1.0
This commit is contained in:
Christian Blichmann 2020-05-11 16:37:44 +02:00
parent aafc597630
commit 6d97220e5c
No known key found for this signature in database
GPG Key ID: 19DC5E747974E966

View File

@ -155,10 +155,9 @@ def sapi_library(
deps = [], deps = [],
tags = [], tags = [],
visibility = None): visibility = None):
"""BUILD rule providing implementation of a Sandboxed API library.""" """Provides the implementation of a Sandboxed API library."""
repo_name = native.repository_name() rprefix = "@com_google_sandboxed_api"
rprefix = "@com_google_sandboxed_api" if repo_name != "@" else ""
common = { common = {
"tags": tags, "tags": tags,
} }