共享变量

BUILD 文件应该比较简单且具有声明性。它们通常由一系列目标声明组成。随着代码库和 BUILD 文件变大,您可能会注意到一些重复内容,例如:

cc_library(
  name = "foo",
  copts = ["-DVERSION=5"],
  srcs = ["foo.cc"],
)

cc_library(
  name = "bar",
  copts = ["-DVERSION=5"],
  srcs = ["bar.cc"],
  deps = [":foo"],
)

BUILD 文件中出现代码重复通常没什么问题。这样可提高该文件的可读性:每个声明都可以在没有任何上下文的情况下被阅读和理解。这不仅对人类而言非常重要,对外部工具而言也是如此。例如,工具或许能够读取和更新 BUILD 文件以添加缺失的依赖项。代码重构和代码重复使用可能会阻止此类自动修改。

如果共享值很有用(例如,如果值必须保持同步),您可以引入一个变量:

COPTS = ["-DVERSION=5"]

cc_library(
  name = "foo",
  copts = COPTS,
  srcs = ["foo.cc"],
)

cc_library(
  name = "bar",
  copts = COPTS,
  srcs = ["bar.cc"],
  deps = [":foo"],
)

多个声明现在使用值 COPTS。按照惯例,全局常量使用大写字母进行命名。

在多个 BUILD 文件中共享变量

如果您需要在多个 BUILD 文件中共享某个值,则必须将其放在 .bzl 文件中。.bzl 文件包含可在 BUILD 文件中使用的定义(变量和函数)。

path/to/variables.bzl 中,写入:

COPTS = ["-DVERSION=5"]

然后,您可以更新 BUILD 文件以访问该变量:

load("//path/to:variables.bzl", "COPTS")

cc_library(
  name = "foo",
  copts = COPTS,
  srcs = ["foo.cc"],
)

cc_library(
  name = "bar",
  copts = COPTS,
  srcs = ["bar.cc"],
  deps = [":foo"],
)