CcToolchainInfo

Báo cáo sự cố Xem nguồn

Thông tin về trình biên dịch C++ đang được sử dụng.

Hội viên

all_files

depset CcToolchainInfo.all_files

Trả về tất cả tệp chuỗi công cụ (để các tệp này có thể được truyền đến các hành động bằng cách sử dụng chuỗi công cụ này làm dữ liệu đầu vào).

ar_executable

string CcToolchainInfo.ar_executable

Đường dẫn đến tệp nhị phân ar.

built_in_include_directories

list CcToolchainInfo.built_in_include_directories

Trả về danh sách các thư mục tích hợp của trình biên dịch.

trình biên dịch

string CcToolchainInfo.compiler

Trình biên dịch C++. Có thể trả về None.

compiler_executable

string CcToolchainInfo.compiler_executable

Đường dẫn đến tệp nhị phân của trình biên dịch.

cpu

string CcToolchainInfo.cpu

CPU mục tiêu của chuỗi công cụ C++. Có thể trả về None.

dynamic_runtime_lib

depset CcToolchainInfo.dynamic_runtime_lib(feature_configuration)

Trả về các tệp từ thuộc tính `dynamic_runtime_lib` (để có thể truyền các tệp này vào các thao tác bằng chuỗi công cụ này làm dữ liệu đầu vào). Lệnh gọi có thể kiểm tra xem tính năng_cấu hình có bật tính năng `static_link_cpp_runtimes` hay không (nếu không, bạn không cần sử dụng `static_runtime_lib` lẫn `dynamic_runtime_lib`) và sử dụng `static_runtime_lib` nếu chế độ liên kết tĩnh đang hoạt động.

Các tham số

Thông số Nội dung mô tả
feature_configuration bắt buộc
Cấu hình tính năng cần truy vấn.

gcov_executable

string CcToolchainInfo.gcov_executable

Đường dẫn đến tệp nhị phân gcov.

ld_executable

string CcToolchainInfo.ld_executable

Đường dẫn đến tệp nhị phân ld.

libc

string CcToolchainInfo.libc

chuỗi phiên bản libc. Có thể trả về None.

needs_pic_for_dynamic_libraries

bool CcToolchainInfo.needs_pic_for_dynamic_libraries(feature_configuration)

Trả về true nếu tổng hợp của quy tắc này áp dụng -fPIC, nếu không thì trả về false. Xác định xem chúng ta có nên áp dụng -fPIC cho nội dung biên dịch C++ của quy tắc này hay không tuỳ thuộc vào chuỗi công cụ C++ và sự hiện diện của tuỳ chọn "--force_pic" Bazel.

Các tham số

Thông số Nội dung mô tả
feature_configuration bắt buộc
Cấu hình tính năng cần truy vấn.

nm_executable

string CcToolchainInfo.nm_executable

Đường dẫn đến tệp nhị phân nm.

objcopy_executable

string CcToolchainInfo.objcopy_executable

Đường dẫn đến tệp nhị phân objcopy.

objdump_executable

string CcToolchainInfo.objdump_executable

Đường dẫn đến tệp nhị phân objdump.

preprocessor_executable

string CcToolchainInfo.preprocessor_executable

Đường dẫn đến tệp nhị phân của bộ tiền xử lý.

static_runtime_lib

depset CcToolchainInfo.static_runtime_lib(feature_configuration)

Trả về các tệp từ thuộc tính `static_runtime_lib` (để có thể truyền các tệp này vào các thao tác bằng chuỗi công cụ này làm dữ liệu đầu vào). Lệnh gọi nên kiểm tra xem Feature_Configuration có bật tính năng `static_link_cpp_runtimes` hay không (nếu không, đừng dùng `static_runtime_lib` lẫn `dynamic_runtime_lib`) và sử dụng `dynamic_runtime_lib` nếu chế độ liên kết động đang hoạt động.

Các tham số

Thông số Nội dung mô tả
feature_configuration bắt buộc
Cấu hình tính năng cần truy vấn.

strip_executable

string CcToolchainInfo.strip_executable

Đường dẫn đến tệp nhị phân dải.

sysroot

string CcToolchainInfo.sysroot

Trả về sysroot sẽ được sử dụng. Nếu trình biên dịch chuỗi công cụ không hỗ trợ sysroot khác nhau hoặc sysroot giống với sysroot mặc định, thì phương thức này sẽ trả về None. Có thể trả về None.

target_gnu_system_name

string CcToolchainInfo.target_gnu_system_name

Tên hệ thống GNU. Có thể trả về None.

to_json

string CcToolchainInfo.to_json()

Không dùng nữa. API này không được dùng nữa và sẽ sớm bị xoá. Vui lòng không phụ thuộc vào công cụ này. Tính năng này bị tắt bằng ---incompatible_struct_has_no_methods. Sử dụng cờ này để xác minh rằng mã của bạn tương thích với việc mã sắp bị xoá.
Tạo một chuỗi JSON từ tham số cấu trúc. Phương thức này chỉ hoạt động nếu tất cả phần tử cấu trúc (theo quy tắc đệ quy) là chuỗi, số nguyên, boolean, các cấu trúc khác, danh sách các loại này hoặc từ điển có khoá chuỗi và giá trị thuộc các kiểu này. Dấu ngoặc kép và các dòng mới trong chuỗi sẽ được thoát. Ví dụ:
struct(key=123).to_json()
# {"key":123}

struct(key=True).to_json()
# {"key":true}

struct(key=[1, 2, 3]).to_json()
# {"key":[1,2,3]}

struct(key='text').to_json()
# {"key":"text"}

struct(key=struct(inner_key='text')).to_json()
# {"key":{"inner_key":"text"}}

struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_json()
# {"key":[{"inner_key":1},{"inner_key":2}]}

struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_json()
# {"key":{"inner_key":{"inner_inner_key":"text"}}}
.

Không dùng nữa: thay vào đó, hãy dùng json.encode(x) hoặc json.encode_indent(x). Các hàm này hoạt động với các giá trị không phải là cấu trúc và không làm ô nhiễm không gian tên của trường cấu trúc.

to_proto

string CcToolchainInfo.to_proto()

Không dùng nữa. API này không được dùng nữa và sẽ sớm bị xoá. Vui lòng không phụ thuộc vào công cụ này. Tính năng này bị tắt bằng ---incompatible_struct_has_no_methods. Sử dụng cờ này để xác minh rằng mã của bạn tương thích với việc mã sắp bị xoá.
Tạo một tin nhắn văn bản từ tham số cấu trúc. Phương thức này chỉ hoạt động nếu tất cả các phần tử cấu trúc (theo quy tắc đệ quy) là chuỗi, số nguyên, boolean, các cấu trúc hay lệnh chính tả khác hoặc danh sách thuộc những loại này. Dấu ngoặc kép và các dòng mới trong chuỗi sẽ được thoát. Các khoá cấu trúc được lặp lại theo thứ tự được sắp xếp. Ví dụ:
struct(key=123).to_proto()
# key: 123

struct(key=True).to_proto()
# key: true

struct(key=[1, 2, 3]).to_proto()
# key: 1
# key: 2
# key: 3

struct(key='text').to_proto()
# key: "text"

struct(key=struct(inner_key='text')).to_proto()
# key {
#   inner_key: "text"
# }

struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_proto()
# key {
#   inner_key: 1
# }
# key {
#   inner_key: 2
# }

struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_proto()
# key {
#    inner_key {
#     inner_inner_key: "text"
#   }
# }

struct(foo={4: 3, 2: 1}).to_proto()
# foo: {
#   key: 4
#   value: 3
# }
# foo: {
#   key: 2
#   value: 1
# }

Không dùng nữa: thay vào đó, hãy dùng proto.encode_text(x).