Thường xảy ra trường hợp một hành động yêu cầu một dòng lệnh lớn chứa các giá trị được tích luỹ từ các phần phụ thuộc bắc cầu. Ví dụ: một dòng lệnh của trình liên kết có thể liệt kê mọi tệp đối tượng mà tất cả thư viện đang được liên kết cần. Phương pháp hay nhất là lưu trữ dữ liệu bắc cầu như vậy trong depset
để chúng có thể được nhiều mục tiêu chia sẻ. Tuy nhiên, nếu tác giả quy tắc phải chuyển đổi các phần sắp xếp lại này thành danh sách chuỗi để tạo một dòng lệnh hành động, thì việc tối ưu hoá chia sẻ bộ nhớ sẽ không cho phép tác giả.
Vì lý do này, các hàm xây dựng hành động chấp nhận cả đối tượng Args
ngoài chuỗi. Mỗi đối tượng Args
đại diện cho một chuỗi và phần tách, với các phép biến đổi tuỳ chọn để thao tác với dữ liệu. Các đối tượng Args
không xử lý phần mô tả mà chúng đóng gói cho đến giai đoạn thực thi, khi đến thời điểm tính toán dòng lệnh. Cách này giúp trì hoãn mọi hoạt động sao chép tốn kém cho đến khi giai đoạn phân tích hoàn tất. Hãy xem trang Tối ưu hoá hiệu suất để biết thêm thông tin.
Args
được tạo bằng cách gọi ctx.actions.args()
. Các sự kiện này có thể được truyền dưới dạng tham số arguments
của ctx.actions.run()
hoặc ctx.actions.run_shell()
. Mỗi lần đột biến của một đối tượng Args
sẽ thêm các giá trị vào dòng lệnh cuối cùng.
Tính năng map_each
hỗ trợ bạn tuỳ chỉnh cách các mục được chuyển đổi thành chuỗi. Nếu bạn không cung cấp hàm map_each
, thì lượt chuyển đổi chuẩn như sau:
- Các giá trị đã là chuỗi vẫn được giữ nguyên.
- Các đối tượng
File
được chuyển thành giá trịFile.path
. - Tất cả các loại khác được chuyển thành chuỗi theo cách không được chỉ định. Vì lý do này, bạn nên tránh truyền các giá trị không phải là chuỗi hoặc loại
File
vàoadd()
, và nếu truyền các giá trị đó đếnadd_all()
hoặcadd_joined()
thì bạn nên cung cấp hàmmap_each
.
Khi sử dụng định dạng chuỗi (tham số format
, format_each
và format_joined
của phương thức add*()
), mẫu định dạng được diễn giải theo cách tương tự như phép thay thế %
trên chuỗi, ngoại trừ việc mẫu phải có đúng một phần giữ chỗ thay thế và phải là %s
. Tỷ lệ phần trăm cố định có thể được thoát dưới dạng %%
. Định dạng được áp dụng sau khi giá trị được chuyển đổi thành chuỗi theo cách trên.
Mỗi phương thức add*()
đều có một biểu mẫu thay thế chấp nhận một thông số vị trí bổ sung là "tên đối số" cần chèn trước phần còn lại của đối số. Đối với add_all
và add_joined
, chuỗi bổ sung sẽ không được thêm vào nếu chuỗi đó trống. Ví dụ: cùng một cách sử dụng có thể thêm --foo val1 val2 val3 --bar
hoặc chỉ --bar
vào dòng lệnh, tuỳ thuộc vào việc trình tự đã cho có chứa val1..val3
hay trống.
Nếu kích thước của dòng lệnh có thể dài hơn kích thước tối đa mà hệ thống cho phép, các đối số có thể bị tràn vào các tệp tham số. Hãy xem use_param_file()
và set_param_file_format()
.
Ví dụ: Giả sử chúng ta muốn tạo dòng lệnh:
--foo foo1.txt foo2.txt ... fooN.txt --bar bar1.txt,bar2.txt,...,barM.txt --baz
Args
sau: # foo_deps and bar_deps are depsets containing # File objects for the foo and bar .txt files. args = ctx.actions.args() args.add_all("--foo", foo_deps) args.add_joined("--bar", bar_deps, join_with=",") args.add("--baz") ctx.actions.run( ... arguments = [args], ... )
Hội viên
thêm
Args Args.add(arg_name_or_value, value=unbound, *, format=None)
Tham số
Thông số | Mô tả |
---|---|
arg_name_or_value
|
bắt buộc Nếu 2 tham số vị trí được truyền, thì đây được hiểu là tên đối số. Tên đối số được thêm vào trước giá trị mà không cần xử lý. Nếu chỉ truyền một tham số vị trí, thì tham số đó sẽ được hiểu là value (xem bên dưới).
|
value
|
mặc định = không liên kết Đối tượng cần thêm. Lượt chuyển đổi đó sẽ được chuyển đổi thành một chuỗi bằng cách sử dụng lượt chuyển đổi chuẩn nêu trên. Vì không có tham số map_each cho hàm này, nên value phải là một chuỗi hoặc File . Một danh sách, bộ dữ liệu, bộ dữ liệu hoặc thư mục File phải được chuyển cho add_all() hoặc add_joined() thay vì phương thức này.
|
format
|
string; or None ;
mặc định = Không cóMẫu chuỗi định dạng, sẽ được áp dụng cho phiên bản xâu chuỗi của value .
|
add_all
Args Args.add_all(arg_name_or_values, values=unbound, *, map_each=None, format_each=None, before_each=None, omit_if_empty=True, uniquify=False, expand_directories=True, terminate_with=None, allow_closure=False)
Hầu hết quá trình xử lý diễn ra đối với một danh sách các đối số cần được thêm vào, theo các bước sau:
- Mỗi mục trong thư mục
File
sẽ được thay thế bằng tất cả cácFile
có trong thư mục đó theo quy tắc đệ quy. - Nếu cung cấp
map_each
, đối số này sẽ được áp dụng cho từng mục và danh sách các chuỗi thu được sẽ được nối với nhau để tạo thành danh sách đối số ban đầu. Nếu không, danh sách đối số ban đầu là kết quả của việc áp dụng lượt chuyển đổi chuẩn cho mỗi mục. - Mỗi đối số trong danh sách được định dạng bằng
format_each
nếu có. - Nếu
uniquify
là đúng, các đối số trùng lặp sẽ bị xoá. Lần xuất hiện đầu tiên là sự kiện còn lại. - Nếu đã cung cấp một chuỗi
before_each
, chuỗi đó sẽ được chèn dưới dạng một đối số mới trước mỗi đối số hiện có trong danh sách. Thao tác này sẽ tăng gấp đôi số lượng đối số cần thêm vào điểm này một cách hiệu quả. - Ngoại trừ trường hợp danh sách trống và
omit_if_empty
là true (mặc định), tên đối số vàterminate_with
sẽ được chèn lần lượt làm đối số đầu và đối số cuối, nếu có.
Tham số
Thông số | Mô tả |
---|---|
arg_name_or_values
|
bắt buộc Nếu 2 tham số vị trí được truyền, thì đây được hiểu là tên đối số. Tên đối số được thêm vào trước values mà không cần xử lý. Tên đối số này sẽ không được thêm nếu omit_if_empty là true (mặc định) và không có mục nào khác được thêm vào (như sẽ xảy ra nếu values trống hoặc tất cả các mục của đối số này được lọc). Nếu chỉ truyền một tham số vị trí, thì tham số đó sẽ được hiểu là values (xem bên dưới).
|
values
|
sequence; or depset ;
mặc định = không liên kếtDanh sách, bộ dữ liệu hoặc tập hợp có các mục sẽ được thêm vào. |
map_each
|
callable; or None ;
mặc định = Không cóMột hàm chuyển đổi từng mục thành 0 hoặc nhiều chuỗi khác, có thể được xử lý thêm trước khi thêm. Nếu thông số này không được cung cấp, thì lượt chuyển đổi chuẩn sẽ được sử dụng. Hàm được truyền một hoặc hai đối số vị trí: mục cần chuyển đổi, theo sau là Loại giá trị trả về phụ thuộc vào số lượng đối số cần tạo cho mục:
None có tác dụng tương tự như việc trả về danh sách có độ dài 1 hoặc độ dài 0 tương ứng. Tuy nhiên, cách này hiệu quả và dễ đọc hơn là tránh tạo danh sách khi không cần thiết.Thông thường, các mục là thư mục sẽ tự động mở rộng nội dung của chúng khi bạn đặt Để tránh việc giữ lại ngoài ý muốn các cấu trúc dữ liệu lớn trong giai đoạn phân tích vào giai đoạn thực thi, bạn phải khai báo hàm Cảnh báo: Các câu lệnh |
format_each
|
string; or None ;
mặc định = Không cóMột mẫu chuỗi định dạng không bắt buộc, áp dụng cho mỗi chuỗi do hàm map_each trả về. Chuỗi định dạng phải có đúng một "%s" phần giữ chỗ.
|
before_each
|
string; or None ;
mặc định = Không cóMột chuỗi không bắt buộc cần nối trước khi thêm mỗi đối số bắt nguồn từ values .
|
omit_if_empty
|
mặc định = Đúng Nếu đúng, nếu không có đối số nào bắt nguồn từ values để được thêm vào, thì tất cả các quá trình xử lý tiếp theo sẽ bị chặn và dòng lệnh sẽ không thay đổi. Nếu giá trị là false, tên đối số và terminate_with (nếu được cung cấp) sẽ vẫn được thêm vào bất kể có đối số khác hay không.
|
uniquify
|
mặc định = Sai Nếu đúng, các đối số trùng lặp bắt nguồn từ values sẽ bị loại bỏ. Chỉ còn lần xuất hiện đầu tiên của mỗi đối số. Thông thường, tính năng này không cần thiết vì phần phụ thuộc đã bỏ qua các phần trùng lặp, nhưng có thể hữu ích nếu map_each trả về cùng một chuỗi cho nhiều mục.
|
expand_directories
|
mặc định = Đúng Nếu đúng, mọi thư mục trong values sẽ được mở rộng thành danh sách tệp phẳng. Quá trình này xảy ra trước khi áp dụng map_each .
|
terminate_with
|
string; or None ;
mặc định = Không cóChuỗi tuỳ chọn để nối sau tất cả các đối số khác. Chuỗi này sẽ không được thêm nếu omit_if_empty là true (mặc định) và không có mục nào khác được thêm vào (như sẽ xảy ra nếu values trống hoặc tất cả các mục của thuộc tính này đều được lọc).
|
allow_closure
|
mặc định = Sai Nếu đúng, cho phép sử dụng tính năng đóng trong các tham số hàm như map_each . Thông thường, điều này không cần thiết và có nguy cơ giữ lại các cấu trúc dữ liệu lớn trong giai đoạn phân tích vào giai đoạn thực thi.
|
add_joined
Args Args.add_joined(arg_name_or_values, values=unbound, *, join_with, map_each=None, format_each=None, format_joined=None, omit_if_empty=True, uniquify=False, expand_directories=True, allow_closure=False)
Quá trình xử lý tương tự như add_all()
, nhưng danh sách các đối số bắt nguồn từ values
được kết hợp thành một đối số duy nhất như thể bằng join_with.join(...)
, sau đó được định dạng bằng mẫu chuỗi format_joined
đã cho. Không giống như add_all()
, không có tham số before_each
hoặc terminate_with
vì các tham số này thường không hữu ích khi các mục được kết hợp thành một đối số duy nhất.
Nếu sau khi lọc không có chuỗi nào để kết hợp vào một đối số và nếu omit_if_empty
là true (giá trị mặc định), thì quá trình xử lý sẽ không được hoàn tất. Ngược lại, nếu không có chuỗi nào để kết hợp nhưng omit_if_empty
là false, thì chuỗi đã kết hợp sẽ là một chuỗi trống.
Tham số
Thông số | Mô tả |
---|---|
arg_name_or_values
|
bắt buộc Nếu 2 tham số vị trí được truyền, thì đây được hiểu là tên đối số. Tên đối số được thêm trước values mà không cần xử lý. Đối số này sẽ không được thêm nếu omit_if_empty là đúng (mặc định) và không có chuỗi nào bắt nguồn từ values để kết hợp với nhau (điều này có thể xảy ra nếu values trống hoặc tất cả các mục của đối số này được lọc). Nếu chỉ truyền một tham số vị trí, thì tham số đó sẽ được hiểu là values (xem bên dưới).
|
values
|
sequence; or depset ;
mặc định = không liên kếtDanh sách, bộ dữ liệu hoặc tập hợp có các mục sẽ được kết hợp. |
join_with
|
bắt buộc Chuỗi phân tách dùng để kết hợp các chuỗi có được bằng cách áp dụng map_each và format_each , theo cách tương tự như string.join() .
|
map_each
|
callable; or None ;
mặc định = Không cóTương tự như đối với add_all .
|
format_each
|
string; or None ;
mặc định = Không cóTương tự như đối với add_all .
|
format_joined
|
string; or None ;
mặc định = Không cóMột mẫu chuỗi định dạng không bắt buộc được áp dụng cho chuỗi đã kết hợp. Chuỗi định dạng phải có đúng một "%s" phần giữ chỗ. |
omit_if_empty
|
mặc định = Đúng Nếu là true, nếu không có chuỗi nào để kết hợp với nhau (do values trống hoặc tất cả các mục đã được lọc) thì tất cả các quá trình xử lý tiếp theo sẽ bị chặn và dòng lệnh sẽ không thay đổi. Nếu là false, thì ngay cả khi không có chuỗi nào để kết hợp với nhau, 2 đối số sẽ được nối thêm: tên đối số, theo sau là một chuỗi trống (là kết hợp logic của các chuỗi 0).
|
uniquify
|
mặc định = Sai Tương tự như đối với add_all .
|
expand_directories
|
mặc định = Đúng Tương tự như đối với add_all .
|
allow_closure
|
mặc định = Sai Tương tự như đối với add_all .
|
set_param_file_format
Args Args.set_param_file_format(format)
Tham số
Thông số | Mô tả |
---|---|
format
|
bắt buộc Phải là một trong các giá trị:
Định dạng mặc định là "shell" nếu không được gọi. |
use_param_file
Args Args.use_param_file(param_file_arg, *, use_always=False)
Bazel có thể chọn elide ghi tệp tham số vào cây đầu ra trong quá trình thực thi để đảm bảo hiệu quả. Nếu bạn đang gỡ lỗi hành động và muốn kiểm tra tệp thông số, hãy truyền --materialize_param_files
vào bản dựng.
Tham số
Thông số | Mô tả |
---|---|
param_file_arg
|
bắt buộc Một chuỗi định dạng với một "%s". Nếu đối số bị tràn sang tệp thông số, thì chúng sẽ được thay thế bằng một đối số bao gồm chuỗi này được định dạng bằng đường dẫn của tệp thông số. Ví dụ: nếu đối số bị tràn sang tệp thông số "params.txt", hãy chỉ định "--file=%s" sẽ khiến dòng lệnh hành động chứa "--file=params.txt". |
use_always
|
mặc định = Sai Liệu có luôn tràn đối số vào tệp thông số hay không. Nếu sai, bazel sẽ quyết định xem có cần đổ đối số hay không dựa trên hệ thống và độ dài đối số của bạn. |