ラベル

BUILD ターゲット識別子。

メンバー

ラベル

Label Label(label_string)

BUILD ターゲットを参照するラベルを作成します。この関数は、ルールのラベル属性のデフォルト値を指定する場合、またはマクロから絶対ラベルを介してターゲットを参照する場合に使用します。引数は絶対ラベルを参照する必要があります。ラベルのリポジトリ部分(またはラベルなし)は、この Label() 呼び出しが存在するリポジトリのコンテキストで解釈されます。例:
Label("//tools:default")

パラメータ

パラメータ 説明
label_string required
ラベル文字列。

name

string Label.name

パッケージ内のこのラベルの名前。次に例を示します。
Label("//pkg/foo:abc").name == "abc"

パッケージ

string Label.package

このラベルのパッケージのパーツ。次に例を示します。
Label("//pkg/foo:abc").package == "pkg/foo"

relative

Label Label.relative(relName)

絶対ラベル(// で始まる)または現在のパッケージからの相対ラベルを解決します。このラベルがリモート リポジトリにある場合、引数はそのリポジトリに対して解決されます。引数にリポジトリ名が含まれている場合、現在のラベルは無視され、引数はそのまま返されます。ただし、現在のリポジトリ マッピングに含まれている場合は、リポジトリ名が書き換えられます。予約済みのラベルもそのまま返されます。
例:
Label("//foo/bar:baz").relative(":quux") == Label("//foo/bar:quux")
Label("//foo/bar:baz").relative("//wiz:quux") == Label("//wiz:quux")
Label("@repo//foo/bar:baz").relative("//wiz:quux") == Label("@repo//wiz:quux")
Label("@repo//foo/bar:baz").relative("//visibility:public") == Label("//visibility:public")
Label("@repo//foo/bar:baz").relative("@other//wiz:quux") == Label("@other//wiz:quux")

渡されたリポジトリ マッピングが {'@other' : '@remapped'} の場合、次の再マッピングが行われます。

Label("@repo//foo/bar:baz").relative("@other//wiz:quux") == Label("@remapped//wiz:quux")

パラメータ

パラメータ 説明
relName 必須
このメールとの相対で解決されるラベル。

workspace_name

string Label.workspace_name

このラベルのリポジトリ部分。次に例を示します。
Label("@foo//bar:baz").workspace_name == "foo"

workspace_root

string Label.workspace_root

このラベルのワークスペースの実行ルートを、execroot からの相対ルートで返します。次に例を示します。
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"