e1c7ebb858
This CL is an alternative to unknown commit. I left the other CL seperately, because I wasn't 100% sure that we'd agree to this, since this is an API change. I did it this way because I believe it's much less hacky, and it also allows us to format things that aren't variables. BEGIN_PUBLIC Add support for select'ing on cc_args(args=...). This is quite tricky because the one parameter was being split into two in a macro, one of type label and the other of type string. For example, `args = ["--foo", format_arg("--bar=%s", "//path/to:bar")]` was rewritten by the macro to `args = [json.encode(struct(format_type="raw", format="foo")), json.encode(struct(format_type="format_arg", format="--bar=%s", value=0))], variables = ["//path/to:bar"]`. To allow it to work with selects, we need to ensure that we don't perform post-processing on the inside of the select. To solve this, we: * Ensure that args only take strings * Provide a seperate parameter for substitutions. This new mechanism also has the useful property that we can now format things that are not variables. For example, I can do the following: ``` directory(name = "sysroot", ...) cc_args( name = "sysroot_arg", args = ["--sysroot={sysroot}"], format = { ":sysroot": "sysroot" } ) ``` END_PUBLIC PiperOrigin-RevId: 656211278 Change-Id: If83f1ea5a99090c18f2a561c51ec6d39ce9fe419 |
||
---|---|---|
.bazelci | ||
.bcr | ||
cc | ||
examples | ||
tests | ||
third_party | ||
tools/migration | ||
.gitignore | ||
AUTHORS | ||
BUILD | ||
CODEOWNERS | ||
CONTRIBUTING.md | ||
ISSUE_TEMPLATE.md | ||
LICENSE | ||
MODULE.bazel | ||
README.md | ||
WORKSPACE | ||
renovate.json |
README.md
C++ rules for Bazel
This repository contains a Starlark implementation of C++ rules in Bazel.
The rules are being incrementally converted from their native implementations in the Bazel source tree.
For the list of C++ rules, see the Bazel documentation.
Getting Started
There is no need to use rules from this repository just yet. If you want to use
rules_cc
anyway, add the following to your WORKSPACE
file:
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
http_archive(
name = "rules_cc",
urls = ["https://github.com/bazelbuild/rules_cc/archive/refs/tags/<VERSION>.tar.gz"],
sha256 = "...",
)
Then, in your BUILD
files, import and use the rules:
load("@rules_cc//cc:defs.bzl", "cc_library")
cc_library(
...
)
Using the rules_cc toolchain
This repo contains an auto-detecting toolchain that expects to find tools installed on your host machine. This is non-hermetic, and may have varying behaviors depending on the versions of tools found.
There are third-party contributed hermetic toolchains you may want to investigate:
- LLVM: https://github.com/grailbio/bazel-toolchain
- GCC (Linux only): https://github.com/aspect-build/gcc-toolchain
- zig cc: https://github.com/uber/hermetic_cc_toolchain
If you'd like to use the cc toolchain defined in this repo, add this to your WORKSPACE after you include rules_cc:
load("@rules_cc//cc:repositories.bzl", "rules_cc_dependencies", "rules_cc_toolchains")
rules_cc_dependencies()
rules_cc_toolchains()
Migration Tools
This repository also contains migration tools that can be used to migrate your project for Bazel incompatible changes.
Legacy fields migrator
Script that migrates legacy crosstool fields into features (incompatible flag, tracking issue).
TLDR:
bazel run @rules_cc//tools/migration:legacy_fields_migrator -- \
--input=my_toolchain/CROSSTOOL \
--inline
Contributing
Bazel and rules_cc
are the work of many contributors. We appreciate your help!
To contribute, please read the contribution guidelines: CONTRIBUTING.md.
Note that the rules_cc
use the GitHub issue tracker for bug reports and feature requests only.
For asking questions see:
- Stack Overflow
rules_cc
mailing list- Slack channel
#cc
on slack.bazel.build