Một mô-đun tích hợp để 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 đều xuất hiện dưới dạng các 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à đối với macro, chứ không phải đối với việc triển khai quy tắc). Các thuộc tính sẽ bỏ qua giá trị None
và coi các giá trị đó như thể thuộc tính chưa được đặt.
Bạn cũng có thể dùng các hàm sau:
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
- subpackages
existing_rule
unknown native.existing_rule(name)
None
nếu không có thực thể quy tắc nào có tên đó.Ở đây, đối tượng bất biến giống như từ điển có nghĩa là một đối tượng bất biến sâu x
hỗ trợ hoạt động lặp lại giống như từ điển, len(x)
, name in x
, x[name]
, x.get(name)
, x.items()
, x.keys()
và x.values()
.
Kết quả chứa một mục cho từng 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 một chữ cái) và một số loại thuộc tính cũ không thể biểu thị. Ngoài ra, dict này còn chứa các mục cho name
và kind
của phiên bản quy tắc (ví dụ: 'cc_binary'
).
Các giá trị của kết quả biểu thị 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 tại.
- Nhãn được chuyển đổi thành các 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 bộ và từ điển được chuyển đổi thành 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ề cùng với nội dung đã được chuyển đổi như mô tả ở trên. - Những thuộc tính mà bạn không chỉ định giá trị trong quá trình tạo thực thể quy tắc và có giá trị mặc định được tính toán sẽ bị loại trừ khỏi kết quả. (Không thể tính toán các 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 dễ bị lỗi và phụ thuộc vào thứ tự. Ngoài ra, hãy lưu ý rằng quy tắc này khác biệt một chút so với 2 lượt chuyển đổi khác của các giá trị thuộc tính quy tắc từ biểu mẫu nội bộ sang Starlark: một được dùng theo mặc định được tính toán, một được dùng theo ctx.attr.foo
.
Thông số
Thông số | Mô tả |
---|---|
name
|
string;
required Tên của mục tiêu. |
existing_rules
unknown native.existing_rules()
existing_rule(name)
sẽ trả về.Ở đây, đối tượng bất biến giống như từ điển có nghĩa là một đối tượng bất biến sâu x
hỗ trợ hoạt động lặp lại giống như từ điển, len(x)
, name in x
, x[name]
, x.get(name)
, x.items()
, x.keys()
và x.values()
.
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 dễ bị lỗi và phụ thuộc vào thứ tự.
exports_files
None
native.exports_files(srcs, visibility=None, licenses=None)
Thông số
Thông số | Mô tả |
---|---|
srcs
|
sequence của strings;
required Danh sách các tệp cần xuất. |
visibility
|
sequence; hoặc None ; mặc định là None Bạn có thể chỉ định một khai báo về khả năng hiển thị. Các tệp này sẽ hiển thị cho những người nhận được chỉ định. Nếu bạn không chỉ định chế độ hiển thị, thì mọi gói đều có thể nhìn thấy các tệp. |
licenses
|
sequence của string; hoặc None ; mặc định là None . Giấy phép cần được chỉ định. |
glob
sequence native.glob(include=[], exclude=[], exclude_directories=1, allow_empty=unbound)
- Khớp ít nhất một mẫu trong
include
. - Không khớp với bất kỳ mẫu nào trong
exclude
(mặc định là[]
).
exclude_directories
được bật (đặt thành 1
), các tệp thuộc loại thư mục sẽ bị bỏ qua trong kết quả (mặc định là 1
).
Thông số
Thông số | Mô tả |
---|---|
include
|
sequence của strings;
mặc định là [] Danh sách các mẫu glob cần đưa vào. |
exclude
|
sequence của strings;
mặc định là [] Danh sách các mẫu glob cần loại trừ. |
exclude_directories
|
int;
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 nội dung nào hay không. Nếu `allow_empty` là False, thì mỗi mẫu include 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 có nội dung (sau khi các kết quả khớp của mẫu `exclude` bị loại trừ). |
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
|
string;
required Tên riêng biệt cho quy tắc này. |
packages
|
sequence của strings;
default is [] Một danh sách đầy đủ các gói trong nhóm này. |
includes
|
sequence của strings; 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 trình gọi.
package_relative_label
Label native.package_relative_label(input)
BUILD
mà macro hiện tại đang thực thi). Nếu đầu vào đã là một Label
, thì đầu vào đó sẽ được trả về mà không thay đổi.Bạn chỉ có thể gọi hàm này trong khi đánh giá một tệp BUILD và các macro mà tệp đó gọi trực tiếp hoặc gián tiếp; bạn không thể gọi hàm này (ví dụ) trong một hàm triển khai quy tắc.
Kết quả của hàm này là giá trị Label
giống như giá trị được tạo ra bằng cách truyền chuỗi đã cho đến một thuộc tính có giá trị nhãn của 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 trong tệp .bzl
đã gọi hàm này, chứ không phải gói trong 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á một chuỗi nhãn do tệp BUILD cung cấp thành một đố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 khác ngoài tệp BUILD hoặc tệp .bzl gọi. Vì lý do đó, các macro bên ngoài nên luôn ưu tiên truyền các đối tượng Nhãn đến các macro bên trong thay vì các chuỗi nhãn.)
Thông số
Thông số | Mô tả |
---|---|
input
|
string; hoặc Label;
required Chuỗi nhãn đầu vào hoặc đối tượng Nhãn. Nếu một đối tượng Nhãn được truyền, thì đố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. Bạn nên sử dụng
repo_name
thay thế. Phương thức này không chứa dấu @ giả mạo ở đầu, nhưng hoạt động giống hệt như phương thức cũ.Tên chính tắc của kho lưu trữ chứa gói hiện đang được đánh giá, có một ký tự @ (@
) ở phía trước. Ví dụ: trong các gói được gọi theo khổ WORKSPACE local_repository(name='local', path=...)
, giá trị này sẽ được đặt thành @local
. Trong các gói trong kho lưu trữ chính, giá trị này sẽ được đặt thành @
.
gói con
sequence native.subpackages(include, exclude=[], allow_empty=False)
Thông số
Thông số | Mô tả |
---|---|
include
|
sequence của strings;
required Danh sách các mẫu glob để đưa vào quá trình quét gói con. |
exclude
|
sequence của strings;
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
|
bool;
mặc định là False Liệu chúng ta có thất bại nếu lệnh gọi trả về một danh sách trống hay không. Theo mặc định, danh sách trống cho biết có thể có lỗi trong tệp BUILD, trong đó lệnh gọi đến subpackages() là không cần thiết. Nếu bạn đặt thành true, thì hàm này sẽ thành công trong trường hợp đó. |