Rules
- cc_binary
- cc_import
- cc_library
- cc_proto_library
- cc_shared_library
- fdo_prefetch_hints
- fdo_profile
- memprof_profile
- propeller_optimize
- cc_test
- cc_toolchain
- cc_toolchain_suite
cc_binary
View rule sourcecc_binary(name, deps, srcs, data, additional_linker_inputs, args, compatible_with, copts, defines, deprecation, distribs, env, exec_compatible_with, exec_properties, features, includes, licenses, link_extra_lib, linkopts, linkshared, linkstatic, local_defines, malloc, nocopts, output_licenses, restricted_to, stamp, tags, target_compatible_with, testonly, toolchains, visibility, win_def_file)
Implicit output targets
- name.stripped(only built if explicitly requested): A stripped version of the binary.- strip -gis run on the binary to remove debug symbols. Additional strip options can be provided on the command line using- --stripopt=-foo. This output is only built if explicitly requested.
- name.dwp(only built if explicitly requested): If Fission is enabled: a debug information package file suitable for debugging remotely deployed binaries. Else: an empty file.
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| deps | List of labels; default is  These can be  | 
| srcs | List of labels; default is  All  A  All  If a rule's name is in the  
            Permitted  
 ...and any rules that produce those files. Different extensions denote different programming languages in accordance with gcc convention. | 
| additional_linker_inputs | List of labels; default is  For example, compiled Windows .res files can be provided here to be embedded in the binary target. | 
| copts | List of strings; default is  
            Each string in this attribute is added in the given order to  
            If the package declares the feature
             | 
| defines | List of strings; default is  -Dand added to the compile command line to this target,
          as well as to every rule that depends on it. Be very careful, since this may have
          far-reaching effects. When in doubt, add define values tolocal_definesinstead. | 
| includes | List of strings; default is  
          Subject to "Make variable" substitution.
          Each string is prepended with  Headers must be added to srcs or hdrs, otherwise they will not be available to dependent rules when compilation is sandboxed (the default). | 
| link_extra_lib | Label; default is  
            By default, C++ binaries are linked against  | 
| linkopts | List of strings; default is  LINKOPTSbefore
          linking the binary target.
            Each element of this list that does not start with  | 
| linkshared | Boolean; nonconfigurable; default is  linkshared=Truein your rule. By default
        this option is off.
          The presence of this flag means that linking occurs with the  
          If you specify both  | 
| linkstatic | Boolean; default is  cc_binaryandcc_test: link the binary in static
           mode. Forcc_library.linkstatic: see below.
             By default this option is on for  
             If enabled and this is a binary or test, this option tells the build tool to link in
              There are really three different ways to link an executable: 
 
           The  
           If  | 
| local_defines | List of strings; default is  -Dand added to the compile command line for this target,
          but not to its dependents. | 
| malloc | Label; default is  
            By default, C++ binaries are linked against  | 
| nocopts | String; default is  COPTSthat match this regular expression
          (including values explicitly specified in the rule's copts attribute) will be removed fromCOPTSfor purposes of compiling this rule.
          This attribute should rarely be needed. | 
| stamp | Integer; default is  
 Stamped binaries are not rebuilt unless their dependencies change. | 
| win_def_file | Label; default is  This attribute should only be used when Windows is the target platform. It can be used to export symbols during linking a shared library. | 
cc_import
View rule sourcecc_import(name, deps, data, hdrs, alwayslink, compatible_with, deprecation, distribs, features, interface_library, licenses, restricted_to, shared_library, static_library, system_provided, tags, target_compatible_with, testonly, visibility)
cc_import rules allows users to import precompiled C/C++ libraries.
The following are the typical use cases: 
1. Linking a static library
cc_import( name = "mylib", hdrs = ["mylib.h"], static_library = "libmylib.a", # If alwayslink is turned on, # libmylib.a will be forcely linked into any binary that depends on it. # alwayslink = 1, )
cc_import( name = "mylib", hdrs = ["mylib.h"], shared_library = "libmylib.so", )
cc_import( name = "mylib", hdrs = ["mylib.h"], # mylib.lib is an import library for mylib.dll which will be passed to linker interface_library = "mylib.lib", # mylib.dll will be available for runtime shared_library = "mylib.dll", )
system_provided=True (Windows)
cc_import( name = "mylib", hdrs = ["mylib.h"], # mylib.lib is an import library for mylib.dll which will be passed to linker interface_library = "mylib.lib", # mylib.dll is provided by system environment, for example it can be found in PATH. # This indicates that Bazel is not responsible for making mylib.dll available. system_provided = 1, )
On Unix:
cc_import( name = "mylib", hdrs = ["mylib.h"], static_library = "libmylib.a", shared_library = "libmylib.so", ) # first will link to libmylib.a cc_binary( name = "first", srcs = ["first.cc"], deps = [":mylib"], linkstatic = 1, # default value ) # second will link to libmylib.so cc_binary( name = "second", srcs = ["second.cc"], deps = [":mylib"], linkstatic = 0, )
cc_import( name = "mylib", hdrs = ["mylib.h"], static_library = "libmylib.lib", # A normal static library interface_library = "mylib.lib", # An import library for mylib.dll shared_library = "mylib.dll", ) # first will link to libmylib.lib cc_binary( name = "first", srcs = ["first.cc"], deps = [":mylib"], linkstatic = 1, # default value ) # second will link to mylib.dll through mylib.lib cc_binary( name = "second", srcs = ["second.cc"], deps = [":mylib"], linkstatic = 0, )
cc_import supports an include attribute. For example:
cc_import( name = "curl_lib", hdrs = glob(["vendor/curl/include/curl/*.h"]), includes = [ "vendor/curl/include" ], shared_library = "vendor/curl/lib/.libs/libcurl.dylib", )
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| deps | List of labels; default is  depsat Typical attributes defined by
        most build rules. | 
| hdrs | List of labels; default is  | 
| alwayslink | Boolean; default is  If alwayslink doesn't work with VS 2017 on Windows, that is due to a known issue, please upgrade your VS 2017 to the latest version. | 
| interface_library | Label; default is   Permitted file types:
             | 
| shared_library | Label; default is   Permitted file types:
             | 
| static_library | Label; default is   Permitted file types:
             | 
| system_provided | Boolean; default is  interface_libraryshould be specified andshared_libraryshould be empty. | 
cc_library
View rule sourcecc_library(name, deps, srcs, data, hdrs, additional_compiler_inputs, additional_linker_inputs, alwayslink, compatible_with, copts, defines, deprecation, distribs, exec_compatible_with, exec_properties, features, implementation_deps, include_prefix, includes, licenses, linkopts, linkstamp, linkstatic, local_defines, nocopts, restricted_to, strip_include_prefix, tags, target_compatible_with, testonly, textual_hdrs, toolchains, visibility, win_def_file)
Header inclusion checking
  All header files that are used in the build must be declared in the hdrs or
  srcs of cc_* rules. This is enforced.
  For cc_library rules, headers in hdrs comprise the public interface of
  the library and can be directly included both from the files in hdrs and
  srcs of the library itself as well as from files in hdrs and
  srcs of cc_* rules that list the library in their deps.
  Headers in srcs must only be directly included from the files in hdrs
  and srcs of the library itself. When deciding whether to put a header into
  hdrs or srcs, you should ask whether you want consumers of this library
  to be able to directly include it. This is roughly the same decision as between
  public and private visibility in programming languages.
  cc_binary and cc_test rules do not have an exported interface, so they
  also do not have a hdrs attribute. All headers that belong to the binary or test
  directly should be listed in the srcs.
To illustrate these rules, look at the following example.
cc_binary(
    name = "foo",
    srcs = [
        "foo.cc",
        "foo.h",
    ],
    deps = [":bar"],
)
cc_library(
    name = "bar",
    srcs = [
        "bar.cc",
        "bar-impl.h",
    ],
    hdrs = ["bar.h"],
    deps = [":baz"],
)
cc_library(
    name = "baz",
    srcs = [
        "baz.cc",
        "baz-impl.h",
    ],
    hdrs = ["baz.h"],
)
  The allowed direct inclusions in this example are listed in the table below. For example
  foo.cc is allowed to directly include foo.h and bar.h, but
  not baz.h.
| Including file | Allowed inclusions | 
|---|---|
| foo.h | bar.h | 
| foo.cc | foo.h bar.h | 
| bar.h | bar-impl.h baz.h | 
| bar-impl.h | bar.h baz.h | 
| bar.cc | bar.h bar-impl.h baz.h | 
| baz.h | baz-impl.h | 
| baz-impl.h | baz.h | 
| baz.cc | baz.h baz-impl.h | 
  The inclusion checking rules only apply to direct
  inclusions. In the example above foo.cc is allowed to
  include bar.h, which may include baz.h, which in
  turn is allowed to include baz-impl.h. Technically, the
  compilation of a .cc file may transitively include any header
  file in the hdrs or srcs in
  any cc_library in the transitive deps closure. In
  this case the compiler may read baz.h and baz-impl.h
  when compiling foo.cc, but foo.cc must not
  contain #include "baz.h". For that to be
  allowed, baz must be added to the deps
  of foo.
  Bazel depends on toolchain support to enforce the inclusion checking rules.
  The layering_check feature has to be supported by the toolchain
  and requested explicitly, for example via the
  --features=layering_check command-line flag or the
  features parameter of the
  package function. The toolchains
  provided by Bazel only support this feature with clang on Unix and macOS.
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| deps | List of labels; default is  These can be  | 
| srcs | List of labels; default is  All  A  All  If a rule's name is in the  
            Permitted  
 ...and any rules that produce those files. Different extensions denote different programming languages in accordance with gcc convention. | 
| hdrs | List of labels; default is  This is the strongly preferred location for declaring header files that
             describe the interface for the library. These headers will be made
             available for inclusion by sources in this rule or in dependent rules.
             Headers not meant to be included by a client of this library should be
             listed in the  | 
| additional_compiler_inputs | List of labels; default is  | 
| additional_linker_inputs | List of labels; default is  For example, compiled Windows .res files can be provided here to be embedded in the binary target. | 
| alwayslink | Boolean; default is  srcs, even if some contain no symbols referenced by the binary.
        This is useful if your code isn't explicitly called by code in
        the binary, e.g., if your code registers to receive some callback
        provided by some service.If alwayslink doesn't work with VS 2017 on Windows, that is due to a known issue, please upgrade your VS 2017 to the latest version. | 
| copts | List of strings; default is  
            Each string in this attribute is added in the given order to  
            If the package declares the feature
             | 
| defines | List of strings; default is  -Dand added to the compile command line to this target,
          as well as to every rule that depends on it. Be very careful, since this may have
          far-reaching effects. When in doubt, add define values tolocal_definesinstead. | 
| implementation_deps | List of labels; default is  deps, the headers and include paths of these libraries (and all their
        transitive deps) are only used for compilation of this library, and not libraries that
        depend on it. Libraries specified withimplementation_depsare still linked in
        binary targets that depend on this library.For now usage is limited to cc_libraries and guarded by the flag
         | 
| include_prefix | String; default is  When set, the headers in the  The prefix in the  | 
| includes | List of strings; default is  
          Subject to "Make variable" substitution.
          Each string is prepended with  Headers must be added to srcs or hdrs, otherwise they will not be available to dependent rules when compilation is sandboxed (the default). | 
| linkopts | List of strings; default is  LINKOPTSbefore
          linking the binary target.
            Each element of this list that does not start with  | 
| linkstamp | Label; default is  basepackage. | 
| linkstatic | Boolean; default is  cc_binaryandcc_test: link the binary in static
           mode. Forcc_library.linkstatic: see below.
             By default this option is on for  
             If enabled and this is a binary or test, this option tells the build tool to link in
              There are really three different ways to link an executable: 
 
           The  
           If  | 
| local_defines | List of strings; default is  -Dand added to the compile command line for this target,
          but not to its dependents. | 
| nocopts | String; default is  COPTSthat match this regular expression
          (including values explicitly specified in the rule's copts attribute) will be removed fromCOPTSfor purposes of compiling this rule.
          This attribute should rarely be needed. | 
| strip_include_prefix | String; default is  When set, the headers in the  If it's a relative path, it's taken as a package-relative one. If it's an absolute one, it's understood as a repository-relative path. The prefix in the  | 
| textual_hdrs | List of labels; default is  This is the location for declaring header files that cannot be compiled on their own; that is, they always need to be textually included by other source files to build valid code. | 
| win_def_file | Label; default is  This attribute should only be used when Windows is the target platform. It can be used to export symbols during linking a shared library. | 
cc_proto_library
View rule sourcecc_proto_library(name, deps, data, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, features, licenses, restricted_to, tags, target_compatible_with, testonly, visibility)
cc_proto_library generates C++ code from .proto files.
deps must point to proto_library
 rules.
Example:
cc_library(
    name = "lib",
    deps = [":foo_cc_proto"],
)
cc_proto_library(
    name = "foo_cc_proto",
    deps = [":foo_proto"],
)
proto_library(
    name = "foo_proto",
)
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| deps | List of labels; default is  proto_libraryrules to generate C++ code for. | 
cc_shared_library
View rule sourcecc_shared_library(name, deps, additional_linker_inputs, dynamic_deps, exports_filter, shared_lib_name, tags, user_link_flags, win_def_file)
It produces a shared library.
Example
cc_shared_library(
    name = "foo_shared",
    deps = [
        ":foo",
    ],
    dynamic_deps = [
        ":bar_shared",
    ],
    additional_linker_inputs = [
        ":foo.lds",
    ],
    user_link_flags = [
        "-Wl,--version-script=$(location :foo.lds)",
    ],
)
cc_library(
    name = "foo",
    srcs = ["foo.cc"],
    hdrs = ["foo.h"],
    deps = [
        ":bar",
        ":baz",
    ],
)
cc_shared_library(
    name = "bar_shared",
    shared_lib_name = "bar.so",
    deps = [":bar"],
)
cc_library(
    name = "bar",
    srcs = ["bar.cc"],
    hdrs = ["bar.h"],
)
cc_library(
    name = "baz",
    srcs = ["baz.cc"],
    hdrs = ["baz.h"],
)
In the example foo_shared statically links foo
and baz, the latter being a transitive dependency. It doesn't
link bar because it is already provided dynamically by the
dynamic_dep bar_shared.
foo_shared uses a linker script *.lds file to control which
symbols should be exported. The cc_shared_library rule logic does
not control which symbols get exported, it only uses what is assumed to be
exported to give errors during analysis phase if two shared libraries export the
same targets.
Every direct dependency of cc_shared_library is assumed to be
exported. Therefore, Bazel assumes during analysis that foo is being
exported by foo_shared. baz is not assumed to be exported
by foo_shared. Every target matched by the exports_filter
is also assumed to be exported.
Every single cc_library in the example should appear at most in one
cc_shared_library. If we wanted to link baz also into
bar_shared we would need to add
tags = ["LINKABLE_MORE_THAN_ONCE"] to baz.
Due to the shared_lib_name attribute, the file produced by
bar_shared will have the name bar.so as opposed
to the name libbar.so that it would have by default on Linux.
Errors
Two shared libraries in dependencies export the same symbols.
This will happen whenever you are creating a target with two different
cc_shared_library dependencies that export the same target. To fix this
you need to stop the libraries from being exported in one of the
cc_shared_library dependencies.
Two shared libraries in dependencies link the same library statically
This will happen whenever you are creating a new cc_shared_library with two
different cc_shared_library dependencies that link the same target statically.
Similar to the error with exports.
One way to fix this is to stop linking the library into one of the
cc_shared_library dependencies. At the same time, the one that still links it
needs to export the library so that the one not linking it keeps visibility to
the symbols. Another way is to pull out a third library that exports the target.
A third way is to tag the culprit cc_library with LINKABLE_MORE_THAN_ONCE
but this fix should be rare and you should absolutely make sure that the
cc_library is indeed safe to link more than once.
'//foo:foo' is already linked statically in '//bar:bar' but not exported`
This means that a library in the transitive closure of your deps is reachable
without going through one of the cc_shared_library dependencies but is already
linked into a different cc_shared_library in dynamic_deps and is not
exported.
The solution is to export it from the cc_shared_library dependency or pull out
a third cc_shared_library that exports it.
Do not place libraries which only contain a precompiled dynamic library in deps.
If you have a precompiled dynamic library, this doesn't need to and cannot be
linked statically into the current cc_shared_library target that you are
currently creating. Therefore, it doesn't belong in deps of the
cc_shared_library. If this precompiled dynamic library is a dependency of one
of your cc_libraries, then the cc_library needs to depend on it
directly.
Trying to export a library already exported by a different shared library
You will see this error if on the current rule you are claiming to export a target that is already being exported by one of your dynamic dependencies.
To fix this, remove the target from deps and just rely on it from the dynamic
dependency or make sure that the exports_filter doesn't catch this target.
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| deps | List of labels; default is  
        Any transitive library dependency of these direct deps will be linked into this shared
        library as long as they have not already been linked by a  
        During analysis, the rule implementation will consider any target listed in
         
        The implementation will also trigger errors whenever the same library is linked statically
        into more than one  | 
| additional_linker_inputs | List of labels; default is  user_link_flagsattribute. | 
| dynamic_deps | List of labels; default is  cc_shared_librarydependencies the current target depends on.
        The  | 
| exports_filter | List of strings; default is  
        Any target  
        Note that this attribute is not actually adding a dependency edge to those targets, the
        dependency edge should instead be created by  The following syntax is allowed: 
 
 | 
| shared_lib_name | String; default is  | 
| user_link_flags | List of strings; default is  
         cc_shared_library(
            name = "foo_shared",
            additional_linker_inputs = select({
              "//src/conditions:linux": [
                ":foo.lds",
                ":additional_script.txt",
              ],
              "//conditions:default": []}),
            user_link_flags = select({
              "//src/conditions:linux": [
                "-Wl,-rpath,kittens",
                "-Wl,--version-script=$(location :foo.lds)",
                "-Wl,--script=$(location :additional_script.txt)",
              ],
              "//conditions:default": []}),
              ...
         )
         | 
| win_def_file | Label; default is  This attribute should only be used when Windows is the target platform. It can be used to export symbols during linking a shared library. | 
fdo_prefetch_hints
View rule sourcefdo_prefetch_hints(name, compatible_with, deprecation, distribs, features, licenses, profile, restricted_to, tags, target_compatible_with, testonly, visibility)
Represents an FDO prefetch hints profile that is either in the workspace or at a specified absolute path. Examples:
fdo_prefetch_hints(
    name = "hints",
    profile = "//path/to/hints:profile.afdo",
)
fdo_profile(
  name = "hints_abs",
  absolute_path_profile = "/absolute/path/profile.afdo",
)
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| profile | Label; default is  | 
fdo_profile
View rule sourcefdo_profile(name, absolute_path_profile, compatible_with, deprecation, distribs, features, licenses, profile, proto_profile, restricted_to, tags, target_compatible_with, testonly, visibility)
Represents an FDO profile that is either in the workspace or at a specified absolute path. Examples:
fdo_profile(
    name = "fdo",
    profile = "//path/to/fdo:profile.zip",
)
fdo_profile(
  name = "fdo_abs",
  absolute_path_profile = "/absolute/path/profile.zip",
)
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| absolute_path_profile | String; default is  | 
| profile | Label; default is  | 
| proto_profile | Label; default is  | 
memprof_profile
View rule sourcememprof_profile(name, absolute_path_profile, compatible_with, deprecation, distribs, features, licenses, profile, restricted_to, tags, target_compatible_with, testonly, visibility)
Represents a MEMPROF profile that is either in the workspace or at a specified absolute path. Examples:
memprof_profile(
    name = "memprof",
    profile = "//path/to/memprof:profile.afdo",
)
memprof_profile(
  name = "memprof_abs",
  absolute_path_profile = "/absolute/path/profile.afdo",
)
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| absolute_path_profile | String; default is  | 
| profile | Label; default is  | 
propeller_optimize
View rule sourcepropeller_optimize(name, compatible_with, deprecation, distribs, features, ld_profile, licenses, restricted_to, tags, target_compatible_with, testonly, visibility)
Represents a Propeller optimization profile in the workspace. Example:
propeller_optimize(
    name = "layout",
    cc_profile = "//path:cc_profile.txt",
    ld_profile = "//path:ld_profile.txt"
)
propeller_optimize(
    name = "layout_absolute",
    absolute_cc_profile = "/absolute/cc_profile.txt",
    absolute_ld_profile = "/absolute/ld_profile.txt"
)
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| ld_profile | Label; default is  | 
cc_test
View rule sourcecc_test(name, deps, srcs, data, additional_linker_inputs, args, compatible_with, copts, defines, deprecation, distribs, env, env_inherit, exec_compatible_with, exec_properties, features, flaky, includes, licenses, link_extra_lib, linkopts, linkstatic, local, local_defines, malloc, nocopts, restricted_to, shard_count, size, stamp, tags, target_compatible_with, testonly, timeout, toolchains, visibility, win_def_file)
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| deps | List of labels; default is  These can be  | 
| srcs | List of labels; default is  All  A  All  If a rule's name is in the  
            Permitted  
 ...and any rules that produce those files. Different extensions denote different programming languages in accordance with gcc convention. | 
| additional_linker_inputs | List of labels; default is  For example, compiled Windows .res files can be provided here to be embedded in the binary target. | 
| copts | List of strings; default is  
            Each string in this attribute is added in the given order to  
            If the package declares the feature
             | 
| defines | List of strings; default is  -Dand added to the compile command line to this target,
          as well as to every rule that depends on it. Be very careful, since this may have
          far-reaching effects. When in doubt, add define values tolocal_definesinstead. | 
| includes | List of strings; default is  
          Subject to "Make variable" substitution.
          Each string is prepended with  Headers must be added to srcs or hdrs, otherwise they will not be available to dependent rules when compilation is sandboxed (the default). | 
| link_extra_lib | Label; default is  
            By default, C++ binaries are linked against  | 
| linkopts | List of strings; default is  LINKOPTSbefore
          linking the binary target.
            Each element of this list that does not start with  | 
| linkstatic | Boolean; default is  cc_binaryandcc_test: link the binary in static
           mode. Forcc_library.linkstatic: see below.
             By default this option is on for  
             If enabled and this is a binary or test, this option tells the build tool to link in
              There are really three different ways to link an executable: 
 
           The  
           If  | 
| local_defines | List of strings; default is  -Dand added to the compile command line for this target,
          but not to its dependents. | 
| malloc | Label; default is  
            By default, C++ binaries are linked against  | 
| nocopts | String; default is  COPTSthat match this regular expression
          (including values explicitly specified in the rule's copts attribute) will be removed fromCOPTSfor purposes of compiling this rule.
          This attribute should rarely be needed. | 
| stamp | Integer; default is  
 Stamped binaries are not rebuilt unless their dependencies change. | 
| win_def_file | Label; default is  This attribute should only be used when Windows is the target platform. It can be used to export symbols during linking a shared library. | 
cc_toolchain
View rule sourcecc_toolchain(name, all_files, ar_files, as_files, compatible_with, compiler_files, compiler_files_without_includes, coverage_files, deprecation, distribs, dwp_files, dynamic_runtime_lib, exec_transition_for_inputs, features, libc_top, licenses, linker_files, module_map, objcopy_files, restricted_to, static_runtime_lib, strip_files, supports_header_parsing, supports_param_files, tags, target_compatible_with, testonly, toolchain_config, toolchain_identifier, visibility)
Represents a C++ toolchain.
This rule is responsible for:
- 
      Collecting all artifacts needed for C++ actions to run. This is done by
      attributes such as all_files,compiler_files,linker_files, or other attributes ending with_files). These are most commonly filegroups globbing all required files.
- 
      Generating correct command lines for C++ actions. This is done using
      CcToolchainConfigInfoprovider (details below).
  Use toolchain_config attribute to configure the C++ toolchain.
  See also this
  
    page
   for elaborate C++ toolchain configuration and toolchain selection documentation.
  Use tags = ["manual"] in order to prevent toolchains from being built and configured
  unnecessarily when invoking bazel build //...
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| all_files | Label; requiredCollection of all cc_toolchain artifacts. These artifacts will be added as inputs to all rules_cc related actions (with the exception of actions that are using more precise sets of artifacts from attributes below). Bazel assumes that all_filesis a superset
        of all other artifact-providing attributes (e.g. linkstamp compilation needs both compile
        and link files, so it takesall_files).
        This is what  | 
| ar_files | Label; default is  Collection of all cc_toolchain artifacts required for archiving actions. | 
| as_files | Label; default is  Collection of all cc_toolchain artifacts required for assembly actions. | 
| compiler_files | Label; requiredCollection of all cc_toolchain artifacts required for compile actions. | 
| compiler_files_without_includes | Label; default is  | 
| coverage_files | Label; default is  | 
| dwp_files | Label; requiredCollection of all cc_toolchain artifacts required for dwp actions. | 
| dynamic_runtime_lib | Label; default is  This will be used when 'static_link_cpp_runtimes' feature is enabled, and we're linking dependencies dynamically. | 
| exec_transition_for_inputs | Boolean; default is  | 
| libc_top | Label; default is  | 
| linker_files | Label; requiredCollection of all cc_toolchain artifacts required for linking actions. | 
| module_map | Label; default is  | 
| objcopy_files | Label; requiredCollection of all cc_toolchain artifacts required for objcopy actions. | 
| static_runtime_lib | Label; default is  This will be used when 'static_link_cpp_runtimes' feature is enabled, and we're linking dependencies statically. | 
| strip_files | Label; requiredCollection of all cc_toolchain artifacts required for strip actions. | 
| supports_header_parsing | Boolean; default is  | 
| supports_param_files | Boolean; default is  | 
| toolchain_config | Label; requiredThe label of the rule providing cc_toolchain_config_info. | 
| toolchain_identifier | String; nonconfigurable; default is  
          Until issue #5380 is fixed
          this is the recommended way of associating  | 
cc_toolchain_suite
View rule sourcecc_toolchain_suite(name, compatible_with, deprecation, distribs, features, licenses, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
Represents a collections of C++ toolchains.
This rule is responsible for:
- Collecting all relevant C++ toolchains.
- 
      Selecting one toolchain depending on --cpuand--compileroptions passed to Bazel.
See also this page for elaborate C++ toolchain configuration and toolchain selection documentation.
Arguments
| Attributes | |
|---|---|
| name | Name; required A unique name for this target. | 
| toolchains | Dictionary mapping strings to labels; nonconfigurable; requiredA map from "<cpu>" or "<cpu>|<compiler>" strings to a cc_toolchainlabel. "<cpu>" will be used when only--cpuis passed to Bazel, and "<cpu>|<compiler>" will be used when both--cpuand--compilerare passed to Bazel. Example:
 
          cc_toolchain_suite(
            name = "toolchain",
            toolchains = {
              "piii|gcc": ":my_cc_toolchain_for_piii_using_gcc",
              "piii": ":my_cc_toolchain_for_piii_using_default_compiler",
            },
          )
           |