我定义了以下config_setting:
config_setting(
name = "perception_env",
values = {"perception": "true"},
)
print(perception_env)然而,我似乎不能打印变量,它说它不存在。
发布于 2022-04-19 01:29:13
config_setting仅用于在select()中选择不同的可能值。config_setting实际上没有值,它更多地是变量( Bazel标志、Starlark定义的标志、平台约束)及其值的关联。values属性基本上用于标志值(“感知”必须是bazel标志)。
例如,
config_setting(
name = "my_config_setting_opt",
values = {"compilation_mode": "opt"}
)
config_setting(
name = "config_setting_dbg",
values = {"compilation_mode": "dbg"}
)
config_setting(
name = "config_setting_fastbuild",
values = {"compilation_mode": "fastbuild"}
)
genrule(
name = "gen_out",
outs = ["out"],
cmd = select({
":my_config_setting_opt": "echo Opt mode > $@",
":config_setting_dbg": "echo Dbg mode > $@",
":config_setting_fastbuild": "echo Fastbuild mode > $@",
}),
)3 config_settings声明--compilation_mode标志的3种不同的关联,每个可能的值都有一个(参见https://bazel.build/docs/user-manual#compilation-mode)
然后,select()为select() gen_out的cmd属性声明3个不同的可能值。然后将--compilation_mode标志设置为不同的值,选择cmd的值:
$ bazel build out --compilation_mode=dbg && cat bazel-bin/out
INFO: Build option --compilation_mode has changed, discarding analysis cache.
INFO: Analyzed target //:out (0 packages loaded, 11 targets configured).
INFO: Found 1 target...
Target //:out up-to-date:
bazel-bin/out
INFO: Elapsed time: 0.145s, Critical Path: 0.01s
INFO: 2 processes: 1 internal, 1 linux-sandbox.
INFO: Build completed successfully, 2 total actions
Dbg mode
$ bazel build out --compilation_mode=opt && cat bazel-bin/out
INFO: Build option --compilation_mode has changed, discarding analysis cache.
INFO: Analyzed target //:out (0 packages loaded, 11 targets configured).
INFO: Found 1 target...
Target //:out up-to-date:
bazel-bin/out
INFO: Elapsed time: 0.111s, Critical Path: 0.01s
INFO: 2 processes: 1 internal, 1 linux-sandbox.
INFO: Build completed successfully, 2 total actions
Opt mode
$ bazel build out --compilation_mode=fastbuild && cat bazel-bin/out
INFO: Build option --compilation_mode has changed, discarding analysis cache.
INFO: Analyzed target //:out (0 packages loaded, 11 targets configured).
INFO: Found 1 target...
Target //:out up-to-date:
bazel-bin/out
INFO: Elapsed time: 0.145s, Critical Path: 0.01s
INFO: 1 process: 1 internal.
INFO: Build completed successfully, 1 total action
Fastbuild modehttps://stackoverflow.com/questions/71917759
复制相似问题