MSVC `determinism` feature should use `/Brepro` with linking Copybara Import from https://github.com/bazelbuild/rules_cc/pull/713 BEGIN_PUBLIC MSVC `determinism` feature should use `/Brepro` with linking (#713) The `/Brepro` (undocumented) argument to MSVC applies to both the compiler and the linker. The recent commit 94bda81 in #408 fixed determinism with MSVC by passing the argument to the compiler, but not the linker. Since the flag is undocumented, it is not clear whether it makes a difference when linking MSVC-compiled objects that were themselves compiled with `/Brepro`, but passing it to the linker helps ensure that it is applies in all cases, such as when linker is used with objects built from other languages. This change adds `all_link_actions` to the list of actions that get the argument. See https://github.com/llvm/llvm-project/issues/37777 for some of the scant documentation that`lld-link` (and thus real `link.exe`) accepts this option. Closes #713 END_PUBLIC COPYBARA_INTEGRATE_REVIEW=https://github.com/bazelbuild/rules_cc/pull/713 from b-spencer:patch-1 7eb345bd9c4e306b4ae3bc6203296be6de117409 PiperOrigin-RevId: 929075474 Change-Id: I823121cfc649b8b359004f91523483d1a7d2fd40
This repository contains C, C++, and Objective-C language support for the Bazel build system.
For this module's main reference, see the Bazel documentation.
Follow the official instructions to Install Bazel.
Add the latest release to your MODULE.bazel project file.
In a BUILD.bazel file, import and use the rules:
load("@rules_cc//cc:cc_binary.bzl", "cc_binary") cc_binary( name = "hello_world", srcs = ["hello_world.cc"], )
Build and run your C/C++ binary with one command:
$ bazel run hello_world
To build the project without running the binary, use Bazel's build subcommand:
$ bazel build hello_world
rules_cc includes an auto-configured toolchain that uses the local compiler installed on the host machine.
You can disable the autoconfigured C/C++ toolchain by adding the following Bazel flag to your project's .bazelrc file:
--repo_env=BAZEL_DO_NOT_DETECT_CPP_TOOLCHAIN=1
Configuring a hermetic toolchain makes your build more deterministic. rules_cc itself does not yet offer a hermetic toolchain distribution. Other community owned and maintained projects offer hermetic C/C++ toolchains:
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:
rules_cc mailing list#cc on slack.bazel.build