BazelToolchain¶
警告
此功能为实验性功能,可能会发生重大更改。有关更多信息,请参阅 Conan 稳定性 部分。
BazelToolchain
是 Bazel 的工具链生成器。它将生成一个 conan_bzl.rc
文件,其中包含一个构建配置 conan-config
,用于将所有参数注入到 bazel build 命令中。
BazelToolchain
生成器可以在 conanfile 中按名称使用
class Pkg(ConanFile):
generators = "BazelToolchain"
[generators]
BazelToolchain
它也可以在 conanfile 的 generate()
方法中完全实例化
from conan import ConanFile
from conan.tools.google import BazelToolchain
class App(ConanFile):
settings = "os", "arch", "compiler", "build_type"
def generate(self):
tc = BazelToolchain(self)
tc.generate()
生成的文件¶
运行 conan install 命令后,BazelToolchain
会生成 conan_bzl.rc 文件,其中包含 Bazel 构建参数(这将取决于您当前的 Conan 设置和默认配置文件的选项)
# Automatic bazelrc file created by Conan
build:conan-config --cxxopt=-std=gnu++17
build:conan-config --dynamic_mode=off
build:conan-config --compilation_mode=opt
Bazel 构建助手 将使用该 conan_bzl.rc
文件来使用此配置执行调用。输出命令将如下所示:bazel --bazelrc=/path/to/conan_bzl.rc build --config=conan-config <target>。
参考¶
- class BazelToolchain(conanfile)¶
- 参数:
conanfile –
< ConanFile 对象 >
当前的 recipe 对象。始终使用self
。
- force_pic¶
布尔值,用于添加 –force_pic=True。取决于 self.options.shared 和 self.options.fPIC 的值
- dynamic_mode¶
字符串,用于添加 –dynamic_mode=[“fully”|”off”]。取决于 self.options.shared 的值。
- cppstd¶
字符串,用于添加 –cppstd=[FLAG]。取决于您的设置。
- copt¶
标志列表,用于添加 –copt=flag1 … –copt=flagN
- conlyopt¶
标志列表,用于添加 –conlyopt=flag1 … –conlyopt=flagN
- cxxopt¶
标志列表,用于添加 –cxxopt=flag1 … –cxxopt=flagN
- linkopt¶
标志列表,用于添加 –linkopt=flag1 … –linkopt=flagN
- compilation_mode¶
字符串,用于添加 –compilation_mode=[“opt”|”dbg”]。取决于 self.settings.build_type
- compiler¶
字符串,用于添加 –compiler=xxxx。
- cpu¶
字符串,用于添加 –cpu=xxxxx。目前,仅在交叉编译时添加。
- crosstool_top¶
字符串,用于添加 –crosstool_top。
- generate()¶
创建一个
conan_bzl.rc
文件,其中包含一些 bazel-build 配置。最后提到的配置被设置为conan-config
。
conf¶
BazelToolchain
受以下 [conf] 变量的影响
tools.build:cxxflags
额外的 C++ 标志列表,将由cxxopt
使用。tools.build:cflags
额外的纯 C 标志列表,将由conlyopt
使用。tools.build:sharedlinkflags
额外的链接器标志列表,将由linkopt
使用。tools.build:exelinkflags
额外的链接器标志列表,将由linkopt
使用。tools.build:linker_scripts
链接器脚本列表,每个脚本都将以-T
为前缀并添加到linkopt
。