Một mô-đun tích hợp sẵn để hỗ trợ các quy tắc gốc và các hàm trợ giúp gói khác. Tất cả các quy tắc gốc sẽ xuất hiện dưới dạng hàm trong mô-đun này, ví dụ: native.cc_library
. Xin lưu ý rằng mô-đun gốc chỉ có trong giai đoạn tải (tức là cho các macro, chứ không phải để triển khai quy tắc). Các thuộc tính sẽ bỏ qua các giá trị None
và coi như các thuộc tính đó chưa được đặt.
Các hàm sau đây cũng có sẵn:
Hội viên
- existing_rule
- existing_rules
- exports_files
- glob
- module_name
- module_version
- package_group
- package_name
- package_relative_label
- repo_name
- repository_name
- gói con
existing_rule
unknown native.existing_rule(name)
None
nếu không có bản sao quy tắc nào có tên đó.Ở đây, một đối tượng dạng ký tự không thể thay đổi có nghĩa là một đối tượng không thể thay đổi sâu rộng x
hỗ trợ lặp lại theo dạng nhập chính tả, len(x)
, name in x
, x[name]
, x.get(name)
, x.items()
, x.keys()
và x.values()
.
Nếu bạn đặt cờ --noincompatible_existing_rules_immutable_view
, thì hàm này sẽ trả về một tập hợp con mới có thể thay đổi với cùng nội dung.
Kết quả chứa một mục nhập cho mỗi thuộc tính, ngoại trừ các thuộc tính riêng tư (tên không bắt đầu bằng chữ cái) và một số loại thuộc tính cũ không thể biểu thị. Ngoài ra, tập hợp này chứa các mục nhập cho name
và kind
của thực thể quy tắc (ví dụ: 'cc_binary'
).
Các giá trị của kết quả đại diện cho các giá trị thuộc tính như sau:
- Các thuộc tính thuộc loại str, int và bool được biểu thị như hiện có.
- Nhãn được chuyển đổi thành chuỗi có dạng
':foo'
cho các mục tiêu trong cùng một gói hoặc'//pkg:name'
cho các mục tiêu trong một gói khác. - Danh sách được biểu thị dưới dạng các bộ dữ liệu và các từ điển được chuyển đổi thành các từ điển mới, có thể thay đổi. Các phần tử của chúng được chuyển đổi đệ quy theo cùng một cách.
- Các giá trị
select
được trả về với nội dung được chuyển đổi như mô tả ở trên. - Các thuộc tính không có giá trị nào được chỉ định trong quá trình tạo quy tắc và có giá trị mặc định được tính sẽ bị loại trừ khỏi kết quả. (Không thể tính toán giá trị mặc định được tính toán cho đến giai đoạn phân tích).
Nếu có thể, hãy tránh sử dụng hàm này. Điều này khiến các tệp BUILD trở nên dễ hỏng và phụ thuộc vào thứ tự. Ngoài ra, hãy lưu ý rằng biến này khác với hai lượt chuyển đổi khác của các giá trị thuộc tính quy tắc từ dạng nội bộ đến Starlark: một lượt chuyển đổi được sử dụng theo giá trị mặc định đã tính toán và lượt chuyển đổi còn lại được ctx.attr.foo
sử dụng.
Thông số
Thông số | Mô tả |
---|---|
name
|
bắt buộc Tên của mục tiêu. |
existing_rules
unknown native.existing_rules()
existing_rule(name)
sẽ trả về.Ở đây, đối tượng giống như tập hợp không thể thay đổi có nghĩa là một đối tượng x
không thể thay đổi sâu sắc hỗ trợ hoạt động lặp lại giống như tập hợp, len(x)
, name in x
, x[name]
, x.get(name)
, x.items()
, x.keys()
và x.values()
.
Nếu bạn đặt cờ --noincompatible_existing_rules_immutable_view
, thì hàm này sẽ trả về một tập hợp con mới có thể thay đổi với cùng nội dung.
Lưu ý: Nếu có thể, hãy tránh sử dụng hàm này. Điều này khiến các tệp BUILD trở nên dễ hỏng và phụ thuộc vào thứ tự. Hơn nữa, nếu bạn đặt cờ --noincompatible_existing_rules_immutable_view
, hàm này có thể rất tốn kém, đặc biệt là nếu được gọi trong một vòng lặp.
exports_files
None
native.exports_files(srcs, visibility=None, licenses=None)
Thông số
Thông số | Mô tả |
---|---|
srcs
|
trình tự các chuỗi;
bắt buộc Danh sách tệp cần xuất. |
visibility
|
trình tự; hoặc None ;
mặc định là None Bạn có thể chỉ định nội dung khai báo chế độ hiển thị. Tệp sẽ hiển thị cho các mục tiêu được chỉ định. Nếu bạn không chỉ định chế độ hiển thị, thì mọi gói sẽ xem được các tệp này. |
licenses
|
trình tự của chuỗi; hoặc None ; giá trị mặc định là None Giấy phép cần chỉ định. |
glob
sequence native.glob(include=[], exclude=[], exclude_directories=1, allow_empty=unbound)
- Khớp với ít nhất một mẫu trong
include
. - Không khớp với mẫu nào trong
exclude
(mặc định là[]
).
exclude_directories
được bật (đặt thành 1
), thì các tệp thuộc thư mục loại sẽ bị loại khỏi kết quả (1
mặc định).
Thông số
Thông số | Mô tả |
---|---|
include
|
trình tự của chuỗi;
mặc định là [] Danh sách các mẫu glob cần đưa vào. |
exclude
|
trình tự của chuỗi; mặc định là [] Danh sách các mẫu cầu nối cần loại trừ. |
exclude_directories
|
mặc định là 1 Cờ cho biết có loại trừ thư mục hay không. |
allow_empty
|
mặc định là unbound Liệu chúng ta có cho phép các mẫu glob không khớp với bất kỳ giá trị nào hay không. Nếu "allow_empty" là False, thì mỗi mẫu bao gồm riêng lẻ phải khớp với một nội dung nào đó và kết quả cuối cùng cũng phải không rỗng (sau khi loại trừ các kết quả khớp với mẫu "exclude"). |
module_name
string native.module_name()
module.name
mà bạn thấy trong module_ctx.modules
.
Có thể trả về None
.
module_version
string native.module_version()
module.version
mà bạn thấy trong module_ctx.modules
.
Có thể trả về None
.
package_group
None
native.package_group(name, packages=[], includes=[])
visibility
.
Thông số
Thông số | Mô tả |
---|---|
name
|
bắt buộc Tên riêng biệt cho quy tắc này. |
packages
|
trình tự của chuỗi; mặc định là [] Liệt kê đầy đủ các gói trong nhóm này. |
includes
|
trình tự của chuỗi; mặc định là [] Các nhóm gói khác có trong nhóm này. |
package_name
string native.package_name()
some/package/BUILD
, giá trị của tệp này sẽ là some/package
. Nếu tệp BUILD gọi một hàm được xác định trong tệp .bzl, thì package_name()
sẽ khớp với gói tệp BUILD của phương thức gọi.
package_relative_label
Label native.package_relative_label(input)
BUILD
mà macro hiện tại đang thực thi). Nếu giá trị đầu vào đã là Label
, thì giá trị này sẽ được trả về mà không thay đổi.Hàm này chỉ có thể được gọi trong khi đánh giá tệp BUILD và các macro mà tệp này gọi trực tiếp hoặc gián tiếp; không được gọi trong hàm triển khai quy tắc (ví dụ:).
Kết quả của hàm này là giá trị Label
giống như giá trị được tạo bằng cách truyền chuỗi đã cho đến thuộc tính có giá trị nhãn của một mục tiêu được khai báo trong tệp BUILD.
Lưu ý về cách sử dụng: Điểm khác biệt giữa hàm này và Label() là Label()
sử dụng ngữ cảnh của gói tệp .bzl
đã gọi hàm này, chứ không phải gói tệp BUILD
. Sử dụng Label()
khi bạn cần tham chiếu đến một mục tiêu cố định được mã hoá cứng vào macro, chẳng hạn như trình biên dịch. Sử dụng package_relative_label()
khi bạn cần chuẩn hoá chuỗi nhãn do tệp BUILD cung cấp cho đối tượng Label
. (Không có cách nào để chuyển đổi một chuỗi thành Label
trong ngữ cảnh của một gói ngoài tệp BUILD hoặc tệp .bzl gọi. Do đó, các macro bên ngoài phải luôn ưu tiên truyền đối tượng Nhãn đến các macro bên trong thay vì chuỗi nhãn.)
Thông số
Thông số | Mô tả |
---|---|
input
|
string; hoặc Label;
bắt buộc Chuỗi nhãn đầu vào hoặc đối tượng Nhãn. Nếu đối tượng Nhãn được truyền, đối tượng đó sẽ được trả về nguyên trạng. |
repo_name
string native.repo_name()
repository_name
string native.repository_name()
--+incompatible_enable_deprecated_label_apis
Không dùng nữa. Thay vào đó, hãy sử dụng
repo_name
. Kiểu này không chứa dấu @ dẫn đầu giả mạo nhưng hoạt động giống hệt như vậy.Tên chuẩn hoá của kho lưu trữ chứa gói hiện đang được đánh giá, với một ký hiệu @ (@
) được đặt ở đầu. Ví dụ: trong các gói được tạo bởi khổ WORKSPACE local_repository(name='local', path=...)
, giá trị này sẽ được đặt thành @local
. Trong các gói thuộc kho lưu trữ chính, thuộc tính này sẽ được thiết lập thành @
.
gói con
sequence native.subpackages(include, exclude=[], allow_empty=False)
Thông số
Thông số | Mô tả |
---|---|
include
|
trình tự của chuỗi;
bắt buộc Danh sách các mẫu glob để đưa vào quá trình quét gói con. |
exclude
|
trình tự của chuỗi;
mặc định là [] Danh sách các mẫu glob cần loại trừ khỏi quá trình quét gói con. |
allow_empty
|
mặc định là False Liệu chúng ta có gặp lỗi nếu lệnh gọi trả về danh sách trống hay không. Theo mặc định, danh sách trống cho biết lỗi tiềm ẩn trong tệp BUILD, trong đó lệnh gọi đến subpackages() là thừa. Nếu bạn đặt thành true, thì hàm này có thể thành công trong trường hợp đó. |