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 设置和 default profile 中的选项)
# 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 object >
当前的配方对象。始终使用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
。