代码库 ctx

<ph type="x-smartling-placeholder"></ph> 报告问题 查看来源 敬上 每晚 · 7.3。 · 7.2 条 · 7.1。 · 7.0。 · 6.5

包含辅助函数和属性相关信息的代码库规则的上下文。创建仓库规则时,您需要获取仓库_ctx 对象作为 implementation 函数的参数。

成员

attr

struct repository_ctx.attr

用于访问属性值的结构体。值由用户提供(如果未提供,则使用默认值)。

删除

bool repository_ctx.delete(path)

删除文件或目录。返回布尔值,指示此调用是否实际删除了文件或目录。

参数

参数 说明
path string;或 path; 必需
要删除的文件的路径(相对于代码库目录或绝对路径)。可以是路径或字符串。

下载

unknown repository_ctx.download(url, output='', sha256='', executable=False, allow_fail=False, canonical_id='', auth={}, headers={}, *, integrity='', block=True)

将文件下载到所提供网址的输出路径,并返回一个包含 success 的结构体。如果下载成功完成,该标志为 true;如果下载成功,则会返回一个包含 sha256integrity 字段的文件哈希值。如果用户指定了 sha256integrity,则强烈建议设置明确的 canonical_id。例如get_default_canonical_id

参数

参数 说明
url string;或 string 的 Iterable; 必需
引用同一文件的镜像网址列表。
output string;或标签;或 path; 默认值为 ''
输出文件的路径(相对于代码库目录)。
sha256 string; 默认值为 ''
所下载文件的预期 SHA-256 哈希。此哈希值必须与所下载文件的 SHA-256 哈希值一致。省略 SHA-256 会带来安全风险,因为远程文件可能会发生变化。省略此字段最好会导致您的 build 不封闭。为简化开发工作,您可以视需要进行设置,但应在发布前进行设置。如果提供,系统会首先检查代码库缓存是否存在具有给定哈希的文件;仅当未在缓存中找到相应文件时才会尝试下载。下载成功后,系统会将该文件添加到缓存中。
executable bool; 默认值为 False
在所创建的文件上设置可执行标志,默认为 false。
allow_fail bool; 默认值为 False
如果设置,请在返回值中指明错误,而不是在下载失败时引发错误。
canonical_id string; 默认值为 ''
如果设置了此字段,则将缓存命中限制为符合以下条件的情况:将文件添加到具有相同规范 ID 的缓存中。默认情况下,缓存使用校验和(sha256integrity)。
auth dict; 默认值为 {}
可选字典,用于指定部分网址的身份验证信息。
headers dict; 默认值为 {}
可选字典,用于指定所有网址的 http 标头。
integrity string; 默认值为 ''
预期已下载文件的校验和,采用子资源完整性格式。必须与所下载文件的校验和一致。由于远程文件可能会更改,因此省略校验和会带来安全风险。省略此字段最好会导致您的 build 不封闭。为简化开发工作,您可以视需要进行设置,但应在发布前进行设置。如果提供了校验和,系统会首先检查存储库缓存中是否存在具有给定校验和的文件;仅当未在缓存中找到相应文件时才会尝试下载。下载成功后,系统会将该文件添加到缓存中。
block bool; 默认值为 True
如果设置为 false,该调用会立即返回,而不会返回常规返回值,而是返回一个包含单个方法(即 wait())的令牌,该方法会在下载完成之前阻塞,并返回常规返回值或正常抛出。

download_and_extract

struct repository_ctx.download_and_extract(url, output='', sha256='', type='', stripPrefix='', allow_fail=False, canonical_id='', auth={}, headers={}, *, integrity='', rename_files={})

将文件下载到所提供网址的输出路径,并提取该文件,然后返回一个包含 success 的结构体。如果下载成功完成,该标志为 true;如果下载成功,则会返回一个包含 sha256integrity 字段的文件哈希值。如果用户指定了 sha256integrity,则强烈建议设置明确的 canonical_id。例如get_default_canonical_id

参数

参数 说明
url string;或 string 的 Iterable; 必需
引用同一文件的镜像网址列表。
output string;或标签;或 path; 默认值为 ''
用于解压缩归档文件的目录的路径(相对于代码库目录)。
sha256 string; 默认值为 ''
所下载文件的预期 SHA-256 哈希。此哈希值必须与所下载文件的 SHA-256 哈希值一致。省略 SHA-256 会带来安全风险,因为远程文件可能会发生变化。省略此字段最好会导致您的 build 不封闭。为简化开发工作,您可以视需要进行设置,但应在发布前进行设置。如果提供,系统会首先检查代码库缓存是否存在具有给定哈希的文件;仅当未在缓存中找到相应文件时才会尝试下载。下载成功后,系统会将该文件添加到缓存中。
type string; 默认值为 ''
已下载文件的归档类型。默认情况下,归档类型根据网址的文件扩展名确定。如果文件没有扩展名,您可以明确指定“zip”“jar”“war”“aar”“tar”“tar.gz”“tgz”“tar.xz”“txz”“.tar.zst”“.tzst”“tar.bz2”或“.tbz”此处。
stripPrefix string; 默认值为 ''
要从提取的文件中删除的目录前缀。 许多归档都包含一个顶级目录,其中包含归档中的所有文件。您可以使用此字段从提取的文件中删除此前缀,而无需在 build_file 中反复指定此前缀。
allow_fail bool; 默认值为 False
如果设置,请在返回值中指明错误,而不是在下载失败时引发错误。
canonical_id string; 默认值为 ''
如果设置了此字段,则将缓存命中限制为符合以下条件的情况:将文件添加到具有相同规范 ID 的缓存中。默认情况下,缓存使用校验和 (sha256integrity)。
auth dict; 默认值为 {}
可选字典,用于指定部分网址的身份验证信息。
headers dict; 默认值为 {}
可选字典,用于指定所有网址的 http 标头。
integrity string; 默认值为 ''
预期已下载文件的校验和,采用子资源完整性格式。必须与所下载文件的校验和一致。由于远程文件可能会更改,因此省略校验和会带来安全风险。省略此字段最好会导致您的 build 不封闭。为简化开发工作,您可以视需要进行设置,但应在发布前进行设置。如果提供了校验和,系统会首先检查存储库缓存中是否存在具有给定校验和的文件;仅当未在缓存中找到相应文件时才会尝试下载。下载成功后,系统会将该文件添加到缓存中。
rename_files dict; 默认值为 {}
可选的字典,用于指定在提取过程中要重命名的文件。在对目录前缀进行任何调整之前,系统会将名称完全匹配某个键的归档条目重命名为该值。这可用于提取包含非 Unicode 文件名的归档,或将提取到不区分大小写的文件系统中同一路径的文件的归档。

execute

exec_result repository_ctx.execute(arguments, timeout=600, environment={}, quiet=True, working_directory="")

执行由参数列表指定的命令。该命令的执行时间受 timeout 限制(以秒为单位,默认为 600 秒)。此方法会返回包含命令输出的 exec_result 结构。environment 映射可用于替换某些要传递给进程的环境变量。

参数

参数 说明
arguments sequence; 必需
参数列表,第一个元素应该是要执行的程序的路径。
timeout int; 默认值为 600
命令的时长上限(以秒为单位,默认值为 600 秒)。
environment dict; 默认值为 {}
强制设置将某些环境变量传递给进程。
quiet bool; 默认值为 True
如果应输出 stdout 和 stderr 到终端。
working_directory string; 默认值为 ""
用于执行命令的工作目录。 可以是代码库根目录的相对路径,也可以是绝对路径。 默认值为代码库根目录。

extract

None repository_ctx.extract(archive, output='', stripPrefix='', *, rename_files={}, watch_archive='auto')

将归档解压缩到代码库目录。

参数

参数 说明
archive string;或标签;或 path; 必需
将解压缩的归档文件的路径(相对于代码库目录)。
output string;或标签;或 path; 默认值为 ''
将解压缩到存档的目录的路径(相对于代码库目录)。
stripPrefix string; 默认值为 ''
要从解压缩的文件中删除的目录前缀。 许多归档都包含一个顶级目录,其中包含归档中的所有文件。您可以使用此字段从提取的文件中删除此前缀,而无需在 build_file 中反复指定此前缀。
rename_files dict; 默认值为 {}
可选的字典,用于指定在提取过程中要重命名的文件。在对目录前缀进行任何调整之前,系统会将名称完全匹配某个键的归档条目重命名为该值。这可用于提取包含非 Unicode 文件名的归档,或将提取到不区分大小写的文件系统中同一路径的文件的归档。
watch_archive string; 默认值为 'auto'
是否观看归档文件。可以是字符串“yes”、“no”或“auto”。传递“yes”等同于立即调用 watch() 方法;传递“no”不会尝试观看文件;传递“auto”只会在合法时尝试观看文件(如需了解详情,请参阅 watch() 文档)。

文件

None repository_ctx.file(path, content='', executable=True, legacy_utf8=True)

在代码库目录中生成一个包含提供内容的文件。

参数

参数 说明
path string;或标签;或 path; 必需
要创建的文件的路径(相对于代码库目录)。
content string; 默认值为 ''
要创建的文件的内容,默认情况下为空。
executable bool; 默认值为 True
在所创建的文件上设置可执行标志,默认为 true。
legacy_utf8 bool; 默认值为 True
将文件内容编码为 UTF-8(默认为 true)。未来的版本将更改默认值并移除此参数。

getenv

string repository_ctx.getenv(name, default=None)

如果环境变量 name 存在,则返回字符串值;如果不存在,则返回 default

增量构建时,对由 name 命名的变量值所做的任何更改都会导致系统重新获取此代码库。

参数

参数 说明
name string; 必需
所需环境变量的名称。
default string;或 None; 默认值为 None
找不到 name 时要返回的默认值。
可能会返回 None

name

string repository_ctx.name

此规则创建的外部代码库的名称。

os

repository_os repository_ctx.os

用于访问系统中信息的结构体。

patch

None repository_ctx.patch(patch_file, strip=0, *, watch_patch='auto')

将补丁文件应用于外部代码库的根目录。补丁文件应该是标准的 统一差异格式文件。Bazel 原生补丁实现不支持模糊匹配和二进制补丁(如补丁命令行工具)。

参数

参数 说明
patch_file string;或标签;或 path; 必需
要应用的补丁文件,它可以是标签、相对路径或绝对路径。如果是相对路径,则会解析为代码库目录。
strip int; 默认值为 0
从文件名中删除指定数量的前导部分。
watch_patch string; 默认值为 'auto'
是否监控补丁文件。可以是字符串“yes”、“no”或“auto”。传递“yes”等同于立即调用 watch() 方法;传递“no”不会尝试观看文件;传递“auto”只会在合法时尝试观看文件(如需了解详情,请参阅 watch() 文档)。

路径

path repository_ctx.path(path)

返回字符串、标签或路径中的路径。如果路径是相对路径,则将相对于代码库目录进行解析。如果路径是标签,则将解析为相应文件的路径。请注意,远程仓库在分析阶段执行,因此不能依赖于目标结果(标签应指向非生成的文件)。如果路径是路径,则将按原样返回该路径。

参数

参数 说明
path string;或标签;或 path; 必需
从其创建路径的 stringLabelpath

read

string repository_ctx.read(path, *, watch='auto')

读取文件系统中文件的内容。

参数

参数 说明
path string;或标签;或 path; 必需
要读取的文件的路径。
watch string; 默认值为 'auto'
是否观看文件。可以是字符串“yes”、“no”或“auto”。传递“yes”等同于立即调用 watch() 方法;传递“no”不会尝试观看文件;传递“auto”只会在合法时尝试观看文件(如需了解详情,请参阅 watch() 文档)。

report_progress

None repository_ctx.report_progress(status='')

更新提取此代码库或模块扩展程序的进度状态。

参数

参数 说明
status string; 默认值为 ''
string,用于描述提取进度的当前状态。

None repository_ctx.symlink(target, link_name)

在文件系统上创建符号链接。

参数

参数 说明
target string;或标签;或 path; 必需
符号链接应指向的路径。
string;或标签;或 path; 必需
要创建的符号链接的路径。

模板

None repository_ctx.template(path, template, substitutions={}, executable=True, *, watch_template='auto')

使用 template 生成新文件。substitutions 的键每次出现在 template 中时,都会替换为相应的值。结果采用 path 编写。通过设置可选的 executable 参数(默认为 true),可开启或关闭可执行位。

参数

参数 说明
path string;或标签;或 path; 必需
要创建的文件的路径(相对于代码库目录)。
template string;或标签;或 path; 必需
模板文件的路径。
substitutions dict; 默认值为 {}
展开模板时要执行的替换。
executable bool; 默认值为 True
在所创建的文件上设置可执行标志,默认为 true。
watch_template string; 默认值为 'auto'
是否监控模板文件。可以是字符串“yes”、“no”或“auto”。传递“yes”等同于立即调用 watch() 方法;传递“no”不会尝试观看文件;传递“auto”只会在合法时尝试观看文件(如需了解详情,请参阅 watch() 文档)。

手表

None repository_ctx.watch(path)

指示 Bazel 监控对给定路径所做的更改,无论该路径是否存在,或者它是文件还是目录。对文件或目录所做的任何更改都会使此代码库或模块扩展程序失效,并导致系统下次重新提取或重新评估它。

“更改”包含对文件内容的更改(如果路径是文件);如果路径是文件,但现在是目录,反之亦然;以及路径是开始还是停止存在。请注意,如果路径是目录,则这包括对该目录下的任何文件的更改。为此,请改用 path.readdir()

请注意,如果尝试监视当前正在提取的代码库内部或当前模块扩展的工作目录内部的路径,将会导致错误。模块扩展程序尝试监视当前 Bazel 工作区之外的路径也会导致错误。

参数

参数 说明
path string;或标签;或 path; 必需
要监控的文件的路径。

watch_tree

None repository_ctx.watch_tree(path)

指示 Bazel 监控在指定路径下以传递方式对任何文件或目录进行的更改。对文件内容、文件或目录的存在、文件名或目录名称的任何更改都会导致系统重新提取此代码库。

请注意,尝试监控当前正在提取的代码库内的路径将会导致错误。

参数

参数 说明
path string;或标签;或 path; 必需
要监控的目录树的路径。

哪个

path repository_ctx.which(program)

返回相应程序的 path;如果路径中没有此类程序,则返回 None

参数

参数 说明
program string; 必需
要在路径中查找的程序。
可能会返回 None

workspace_root

path repository_ctx.workspace_root

指向 bazel 调用的根工作区的路径。