implementation
函数的参数。
成员
attr
struct repository_ctx.attr
删除
bool repository_ctx.delete(path)
参数
下载
struct repository_ctx.download(url, output='', sha256='', executable=False, allow_fail=False, canonical_id='', auth={}, *, integrity='')
success
的结构体。如果下载成功完成,该标志为 true
;如果下载成功,则会返回一个包含 sha256
和 integrity
字段的文件哈希值。
参数
参数 | 说明 |
---|---|
url
|
string; or Iterable of strings ;
必需引用同一文件的镜像网址列表。 |
output
|
string; or Label; or path ;
默认值 = ''输出文件的路径(相对于代码库目录)。 |
sha256
|
默认值 = '' 所下载文件的预期 SHA-256 哈希。此哈希值必须与所下载文件的 SHA-256 哈希值一致。省略 SHA-256 会带来安全风险,因为远程文件可能会发生变化。省略此字段最好会导致您的 build 变得非封闭。为了简化开发,您可以视需要进行设置,但应在发布前进行设置。 |
executable
|
默认值 = False 在所创建的文件上设置可执行标志,默认为 false。 |
allow_fail
|
默认值 = False 如果设置,请在返回值中指明错误,而不是在下载失败时引发错误 |
canonical_id
|
默认值 = '' 如果设置了此字段,则将缓存命中限制为符合以下条件的情况:将文件添加到具有相同规范 ID 的缓存中 |
auth
|
default = {} 可选字典,用于指定部分网址的身份验证信息。 |
integrity
|
默认值 = '' 预期已下载文件的校验和,采用子资源完整性格式。必须与所下载文件的校验和一致。由于远程文件可能会更改,因此省略校验和会带来安全风险。省略此字段最好会导致您的 build 变得非封闭。为了简化开发,您可以视需要进行设置,但应在发布前进行设置。 |
download_and_extract
struct repository_ctx.download_and_extract(url, output='', sha256='', type='', stripPrefix='', allow_fail=False, canonical_id='', auth={}, *, integrity='', rename_files={})
success
的结构体。如果下载成功完成,该标志为 true
;如果下载成功,则会返回一个包含 sha256
和 integrity
字段的文件哈希值。
参数
参数 | 说明 |
---|---|
url
|
string; or Iterable of strings ;
必需引用同一文件的镜像网址列表。 |
output
|
string; or Label; or path ;
默认值 = ''将解压缩到存档的目录的路径(相对于代码库目录)。 |
sha256
|
默认值 = '' 所下载文件的预期 SHA-256 哈希。此哈希值必须与所下载文件的 SHA-256 哈希值一致。省略 SHA-256 会带来安全风险,因为远程文件可能会发生变化。省略此字段最好会导致您的 build 变得非封闭。为了简化开发,您可以视需要进行设置,但应在发布前进行设置。如果提供,系统会首先检查代码库缓存是否存在具有给定哈希的文件;仅当未在缓存中找到相应文件时才会尝试下载。下载成功后,系统会将该文件添加到缓存中。 |
type
|
默认值 = '' 已下载文件的归档类型。默认情况下,归档类型根据网址的文件扩展名确定。如果文件没有扩展名,您可以明确指定“zip”“jar”“war”“aar”“tar”“tar.gz”“tgz”“tar.xz”“txz”“.tar.zst”“.tzst”“tar.bz2”“.debar”或此处。 |
stripPrefix
|
默认值 = '' 要从解压缩的文件中删除的目录前缀。 许多归档都包含一个顶级目录,其中包含归档中的所有文件。您可以使用此字段从提取的文件中删除此前缀,而无需在 build_file 中反复指定此前缀。
|
allow_fail
|
默认值 = False 如果设置,请在返回值中指明错误,而不是在下载失败时引发错误 |
canonical_id
|
默认值 = '' 如果设置了此字段,则将缓存命中限制为符合以下条件的情况:将文件添加到具有相同规范 ID 的缓存中 |
auth
|
default = {} 可选字典,用于指定部分网址的身份验证信息。 |
integrity
|
默认值 = '' 预期已下载文件的校验和,采用子资源完整性格式。必须与所下载文件的校验和一致。由于远程文件可能会更改,因此省略校验和会带来安全风险。省略此字段最好会导致您的 build 变得非封闭。为了简化开发,您可以视需要进行设置,但应在发布前进行设置。 |
rename_files
|
default = {} 可选的字典,用于指定在提取过程中要重命名的文件。在对目录前缀进行任何调整之前,系统会将名称完全匹配某个键的归档条目重命名为该值。这可用于提取包含非 Unicode 文件名的归档,或将提取到不区分大小写的文件系统中同一路径的文件的归档。 |
execute
exec_result repository_ctx.execute(arguments, timeout=600, environment={}, quiet=True, working_directory="")
timeout
限制(以秒为单位,默认为 600 秒)。此方法会返回包含命令输出的 exec_result
结构。environment
映射可用于替换某些要传递给进程的环境变量。
参数
参数 | 说明 |
---|---|
arguments
|
必需 参数列表,第一个元素应该是要执行的程序的路径。 |
timeout
|
默认值 = 600 命令的最大时长(以秒为单位,默认为 600 秒)。 |
environment
|
default = {} 强制设置一些环境变量以传递给进程。 |
quiet
|
默认值 = True 如果应输出 stdout 和 stderr 到终端。 |
working_directory
|
默认值 = "" 用于执行命令的工作目录。 可以是代码库根目录的相对路径,也可以是绝对路径。 |
extract
None repository_ctx.extract(archive, output='', stripPrefix='', *, rename_files={})
参数
参数 | 说明 |
---|---|
archive
|
string; or Label; or path ;
必需将解压缩的归档文件的路径(相对于代码库目录)。 |
output
|
string; or Label; or path ;
默认值 = ''将解压缩到存档的目录的路径(相对于代码库目录)。 |
stripPrefix
|
默认值 = '' 要从解压缩的文件中删除的目录前缀。 许多归档都包含一个顶级目录,其中包含归档中的所有文件。您可以使用此字段从提取的文件中删除此前缀,而无需在 build_file 中反复指定此前缀。
|
rename_files
|
default = {} 可选的字典,用于指定在提取过程中要重命名的文件。在对目录前缀进行任何调整之前,系统会将名称完全匹配某个键的归档条目重命名为该值。这可用于提取包含非 Unicode 文件名的归档,或将提取到不区分大小写的文件系统中同一路径的文件的归档。 |
文件
None repository_ctx.file(path, content='', executable=True, legacy_utf8=True)
参数
参数 | 说明 |
---|---|
path
|
string; or Label; or path ;
必需要创建的文件的路径(相对于代码库目录)。 |
content
|
默认值 = '' 要创建的文件的内容,默认情况下为空。 |
executable
|
默认值 = True 在所创建的文件上设置可执行标志,默认为 true。 |
legacy_utf8
|
默认值 = True 将文件内容编码为 UTF-8(默认情况下为 true)。未来的版本将更改默认值并移除此参数。 |
name
string repository_ctx.name
os
repository_os repository_ctx.os
patch
None repository_ctx.patch(patch_file, strip=0)
参数
参数 | 说明 |
---|---|
patch_file
|
string; or Label; or path ;
必需要应用的补丁文件,它可以是标签、相对路径或绝对路径。如果是相对路径,则会解析为代码库目录。 |
strip
|
默认值 = 0 从文件名中删除指定数量的前导组件。 |
路径
path repository_ctx.path(path)
参数
read
string repository_ctx.read(path)
参数
report_progress
None repository_ctx.report_progress(status='')
参数
参数 | 说明 |
---|---|
status
|
string ;
默认值 = ''描述提取进度的当前状态的字符串 |
符号链接
None repository_ctx.symlink(target, link_name)
参数
参数 | 说明 |
---|---|
target
|
string; or Label; or path ;
必需符号链接应指向的路径。 |
link_name
|
string; or Label; or path ;
必需要创建的符号链接的路径(相对于代码库目录)。 |
模板
None repository_ctx.template(path, template, substitutions={}, executable=True)
template
生成新文件。substitutions
的键每次出现在 template
中时,都会替换为相应的值。结果使用 path
编写。通过设置可选的 executable
参数(默认为 true),可开启或关闭可执行位。
参数
参数 | 说明 |
---|---|
path
|
string; or Label; or path ;
必需要创建的文件的路径(相对于代码库目录)。 |
template
|
string; or Label; or path ;
必需模板文件的路径。 |
substitutions
|
default = {} 替换模板。 |
executable
|
默认值 = True 在所创建的文件上设置可执行标志,默认为 true。 |
哪个
path repository_ctx.which(program)
参数
参数 | 说明 |
---|---|
program
|
必需 要在路径中查找的程序。 |
None
。
workspace_root
path repository_ctx.workspace_root