BUILD hedef tanımlayıcısı.
Her Label
örneği l
için str(l)
dize temsili, Label()
çağrısının nereden yapıldığına bakılmaksızın Label(str(l)) == l
özelliğine sahiptir.
Üyeler
Şirket
Label Label(input)
.bzl
kaynak dosyasının bulunduğu paket bağlamında Label
nesnesine dönüştürür. Belirtilen değer zaten Label
ise değişmeden döndürülür.İlgili bir işlev olan native.package_relative_label()
, makrolarda ise girişi şu anda oluşturulmakta olan paketin bağlamında Label
biçimine dönüştürür. Bu işlevi, etiket değerine sahip kural özellikleri tarafından otomatik olarak yapılan dize-etiket dönüşümünü taklit etmek için kullanın.
Parametreler
Parametre | Açıklama |
---|---|
input
|
dize veya Etiket;
zorunlu Giriş etiketi dizesi veya Etiket nesnesi. Bir Label nesnesi iletilirse olduğu gibi döndürülür. |
ad
string Label.name
Label("@@foo//pkg/foo:abc").name == "abc"
paket
string Label.package
Label("@@repo//pkg/foo:abc").package == "pkg/foo"
ilgili
Label Label.relative(relName)
--+incompatible_enable_deprecated_label_apis
Desteklenmiyor olarak ayarlanarak deneysel olarak etkinleştirilebilir. Bu yöntem, açık bir depo adı içeren bir bağımsız değişkenle kullanıldığında şaşırtıcı bir şekilde davranır. Bunun yerine
Label.same_package_label()
, native.package_relative_label()
veya Label()
seçeneğini tercih edin.Mutlak (//
ile başlayan) veya mevcut paketle göreli bir etiketi çözümler. Bu etiket uzak bir depodaysa bağımsız değişken, o depoya göre çözümlenir. Bağımsız değişken bir depo adı içeriyorsa mevcut etiket göz ardı edilir ve bağımsız değişken olduğu gibi döndürülür. Bununla birlikte, mevcut depo eşlemedeyse depo adı yeniden yazılır. Ayrılmış etiketler de olduğu gibi döndürülür.
Örneğin:
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")
İletilen depo eşleme {'@other' : '@remapped'}
ise aşağıdaki yeniden eşleme gerçekleşir:
Label("@repo//foo/bar:baz").relative("@other//wiz:quux") == Label("@remapped//wiz:quux")
Parametreler
Parametre | Açıklama |
---|---|
relName
|
required Bu etikete göre çözülecek etiket. |
repo_name
string Label.repo_name
@
) olmadan standart adı. Örneğin, Label("@@foo//bar:baz").repo_name == "foo"
same_package_label
Label Label.same_package_label(target_name)
Parametreler
Parametre | Açıklama |
---|---|
target_name
|
required Yeni etiketin hedef adı. |
workspace_name
string Label.workspace_name
--+incompatible_enable_deprecated_label_apis
Desteklenmiyor olarak ayarlanarak deneysel olarak etkinleştirilebilir. "Çalışma alanı adı" alan adı burada yanlış bir adlandırmadır. Bunun yerine aynı işlevi gören
Label.repo_name
değerini kullanın.Bu etiket tarafından başvuruda bulunulan hedefi içeren deponun, başında hiçbir işaret (@
) olmadan standart adı. Örneğin,
Label("@@foo//bar:baz").workspace_name == "foo"
workspace_root
string Label.workspace_root
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"