规则
action_listener
查看规则源代码action_listener(name, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, extra_actions, features, licenses, mnemonics, restricted_to, tags, target_compatible_with, testonly, visibility)
警告:额外操作已废弃。请改用方面。
action_listener
规则本身不会产生任何输出。
而是允许工具开发者通过提供从操作到 extra_action
的映射,将 extra_action
插入构建系统。
此规则的参数会将操作助记符映射到 extra_action
规则。
通过指定选项
--experimental_action_listener=<label>
,build 将使用指定的 action_listener
将 extra_action
插入 build 图中。
示例
action_listener( name = "index_all_languages", mnemonics = [ "Javac", "CppCompile", "Python", ], extra_actions = [":indexer"], ) action_listener( name = "index_java", mnemonics = ["Javac"], extra_actions = [":indexer"], ) extra_action( name = "indexer", tools = ["//my/tools:indexer"], cmd = "$(location //my/tools:indexer)" + "--extra_action_file=$(EXTRA_ACTION_FILE)", )
参数
属性 | |
---|---|
name |
名称;必需 此目标的唯一名称。 |
extra_actions
|
标签列表;必需 此action_listener 应添加到 build 图中的 extra_action 目标列表。
例如 [ "//my/tools:analyzer" ] 。
|
mnemonics
|
字符串列表;必需 此action_listener 应监听的操作助记符列表,例如 [ "Javac" ] 。
助记符不是公共接口。 我们无法保证这些助记符及其操作不会发生变化。 |
extra_action
查看规则源代码extra_action(name, data, cmd, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, features, licenses, out_templates, requires_action_output, restricted_to, tags, target_compatible_with, testonly, toolchains, tools, visibility)
警告:额外操作已废弃。请改用方面。
如果将 extra_action
规则指定为常规 build 目标,则不会生成任何有意义的输出。相反,它允许工具开发者将其他操作插入到构建图中,以替换现有操作。
如需详细了解如何启用 extra_action
,请参阅 action_listener
。
extra_action
以命令行形式运行。命令行工具会获得对包含协议缓冲区的文件的访问权限,该文件的名称为 $(EXTRA_ACTION_FILE),其中包含有关它所替换的原始操作的详细信息。它还可以访问原始操作可以访问的所有输入文件。
如需详细了解协议缓冲区中存储的数据,请参阅 extra_actions_base.proto。每个 proto 文件都包含一个 ExtraActionInfo 消息。
与所有其他操作一样,额外操作会被沙盒化,并且应针对此进行设计。
参数
属性 | |
---|---|
name |
名称;必需 此目标的唯一名称。 您可以在 action_listener 规则的 extra_actions 参数中通过 label 引用此规则。
|
cmd
|
字符串;必需 要运行的命令。与 genrule cmd 属性类似,但存在以下差异:
|
out_templates
|
字符串列表;默认值为 extra_action 命令生成的文件的模板列表。
模板可以使用以下变量:
|
requires_action_output
|
布尔值;默认值为 extra_action 要求将原始操作的输出作为此 extra_action 的输入。
如果为 true(默认为 false),extra_action 可以假定原始操作输出可用作其输入的一部分。 |
tools
|
标签列表;默认值为 tool 依赖项列表。
如需了解详情,请参阅依赖项的定义。
构建系统会确保在运行 所有工具及其数据依赖项都会合并到一个树中,在该树中,命令可以使用相对路径。工作目录将成为该统一树的根目录。 |