Các tiện ích để biên dịch, liên kết và tạo dòng lệnh C++.
Hội viên
- action_is_enabled
- CcToolchainInfo
- biên dịch
- configure_features
- create_cc_toolchain_config_info
- create_compilation_context
- create_compilation_outputs
- create_compile_variables
- create_library_to_link
- create_link_variables
- create_linker_input
- create_linking_context
- create_linking_context_from_compilation_outputs
- create_lto_compilation_context
- do_not_use_tools_cpp_compiler_present
- get_environment_variables
- get_execution_requirements
- get_memory_inefficient_command_line
- get_tool_for_action
- is_enabled
- link
- merge_compilation_contexts
- merge_compilation_outputs
action_is_enabled
bool cc_common.action_is_enabled(feature_configuration, action_name)Trả về True nếu action_config đã cho được bật trong cấu hình tính năng.
Tham số
Thông số | Mô tả |
---|---|
feature_configuration
|
FeatureConfiguration;
bắt buộc Cấu hình tính năng cần được truy vấn. |
action_name
|
string;
bắt buộc Tên của action_config. |
CcToolchainInfo
Provider cc_common.CcToolchainInfoKhoá dùng để truy xuất trình cung cấp chứa thông tin về chuỗi công cụ C++ đang được sử dụng
biên dịch
tuple cc_common.compile(actions, feature_configuration, cc_toolchain, srcs=[], public_hdrs=[], private_hdrs=[], includes=[], quote_includes=[], system_includes=[], framework_includes=[], defines=[], local_defines=[], include_prefix='', strip_include_prefix='', user_compile_flags=[], conly_flags=[], cxx_flags=[], compilation_contexts=[], name, disallow_pic_outputs=False, disallow_nopic_outputs=False, additional_inputs=[], module_interfaces=unbound)Nên dùng để biên dịch C++. Trả về một bộ dữ liệu gồm (
CompilationContext
, CcCompilationOutputs
).
Tham số
Thông số | Mô tả |
---|---|
actions
|
actions; đối tượng actions bắt buộc. |
feature_configuration
|
FeatureConfiguration;
bắt buộcfeature_configuration để được truy vấn.
|
cc_toolchain
|
Thông tin; nhà cung cấp CcToolchainInfo cần thiết để sử dụng.
|
srcs
|
trình tự;
mặc định là [] Danh sách các tệp nguồn cần biên dịch. |
public_hdrs
|
trình tự; giá trị mặc định là [] Danh sách tiêu đề cần thiết để biên dịch các src và có thể được đưa vào theo quy tắc phụ thuộc. |
private_hdrs
|
trình tự; giá trị mặc định là [] Danh sách tiêu đề cần thiết để biên dịch src và KHÔNG được đưa vào các quy tắc phụ thuộc. |
includes
|
sequence; hoặc depset;
mặc định là [] Đường dẫn tìm kiếm cho các tệp tiêu đề được tham chiếu bằng cả dấu ngoặc nhọn và dấu ngoặc kép. Thường được truyền bằng -I. Được truyền đến các phần phụ thuộc một cách bắc cầu. |
quote_includes
|
trình tự; giá trị mặc định là [] Tìm kiếm đường dẫn cho các tệp tiêu đề được tham chiếu bằng dấu ngoặc kép, ví dụ: #include "foo/bar/header.h". Các đường dẫn này có thể tương đối so với thư mục gốc của exec hoặc tuyệt đối. Thường được truyền bằng -iquote. Được truyền đến các phần phụ thuộc một cách bắc cầu. |
system_includes
|
trình tự; giá trị mặc định là [] . Tìm đường dẫn cho các tệp tiêu đề được tham chiếu bằng dấu ngoặc nhọn, ví dụ: #include <foo/bar/header.h>. Các đường dẫn này có thể tương ứng với thư mục gốc của exec hoặc tuyệt đối. Thường được truyền bằng -isystem. Được truyền đến các phần phụ thuộc một cách bắc cầu. |
framework_includes
|
trình tự; giá trị mặc định là [] Tìm kiếm đường dẫn cho các tệp tiêu đề từ khung Apple. Các đường dẫn này có thể tương đối so với thư mục gốc của exec hoặc tuyệt đối. Thường được truyền bằng -F. Được truyền đến các phần phụ thuộc một cách bắc cầu. |
defines
|
trình tự; giá trị mặc định là [] . Tập hợp các định nghĩa cần thiết để biên dịch mục tiêu này. Mỗi định nghĩa là một chuỗi. Được truyền đến các phần phụ thuộc một cách bắc cầu. |
local_defines
|
trình tự; giá trị mặc định là [] . Tập hợp các định nghĩa cần thiết để biên dịch mục tiêu này. Mỗi định nghĩa là một chuỗi. Không được truyền đến các phần phụ thuộc một cách bắc cầu. |
include_prefix
|
chuỗi; giá trị mặc định là '' Tiền tố cần thêm vào đường dẫn của tiêu đề của quy tắc này. Khi được đặt, bạn có thể truy cập vào các tiêu đề trong thuộc tính hdrs của quy tắc này tại là giá trị của thuộc tính này được thêm vào đầu đường dẫn tương đối của kho lưu trữ. Tiền tố trong thuộc tính strip_include_prefix sẽ bị xoá trước khi tiền tố này được thêm vào. |
strip_include_prefix
|
chuỗi; giá trị mặc định là '' Tiền tố cần xoá khỏi đường dẫn của tiêu đề của quy tắc này. Khi được đặt, bạn có thể truy cập vào các tiêu đề trong thuộc tính hdrs của quy tắc này tại đường dẫn của các tiêu đề đó mà không cần tiền tố này. Nếu đó là đường dẫn tương đối, thì đường dẫn đó sẽ được coi là đường dẫn tương đối với gói. Nếu là đường dẫn tuyệt đối, thì đường dẫn này được hiểu là đường dẫn tương đối đến kho lưu trữ. Tiền tố trong thuộc tính include_prefix được thêm vào sau khi xoá tiền tố này. |
user_compile_flags
|
trình tự; giá trị mặc định là [] Danh sách bổ sung các tuỳ chọn biên dịch. |
conly_flags
|
trình tự;
mặc định là [] Danh sách bổ sung các tuỳ chọn biên dịch cho các bản biên dịch C. |
cxx_flags
|
trình tự; giá trị mặc định là [] Danh sách bổ sung các tuỳ chọn biên dịch cho các bản biên dịch C++. |
compilation_contexts
|
trình tự; giá trị mặc định là [] Tiêu đề của các phần phụ thuộc dùng để biên dịch. |
name
|
string;
bắt buộc Dùng để đặt tên cho cấu phần phần mềm đầu ra của các hành động do phương thức này tạo ra. Xem thêm đối số `main_output`. |
disallow_pic_outputs
|
bool; giá trị mặc định là False . Có tạo đầu ra PIC hay không. |
disallow_nopic_outputs
|
bool; giá trị mặc định là False . Cho biết có tạo đầu ra NOPIC hay không. |
additional_inputs
|
trình tự;
mặc định là [] Danh sách các tệp bổ sung cần thiết để biên dịch src |
module_interfaces
|
trình tự; giá trị mặc định là unbound Danh sách các tệp nguồn giao diện mô-đun cần biên dịch. Lưu ý: đây là tính năng thử nghiệm, chỉ được bật bằng --experimental_cpp_modules |
configure_features
FeatureConfiguration cc_common.configure_features(ctx=None, cc_toolchain, language=None, requested_features=[], unsupported_features=[])Tạo một thực thể feature_configuration. Yêu cầu mảnh cấu hình cpp.
Tham số
Thông số | Mô tả |
---|---|
ctx
|
ctx; hoặc None ;
mặc định là None Ngữ cảnh quy tắc. |
cc_toolchain
|
Thông tin;
bắt buộc cc_toolchain mà chúng ta định cấu hình các tính năng. |
language
|
string; hoặc None ;
mặc định là None Ngôn ngữ cần định cấu hình: c++ hoặc objc (mặc định là c++) |
requested_features
|
trình tự;
mặc định là [] Danh sách các tính năng cần bật. |
unsupported_features
|
trình tự; giá trị mặc định là [] Danh sách các tính năng không được quy tắc hiện tại hỗ trợ. |
create_cc_toolchain_config_info
CcToolchainConfigInfo cc_common.create_cc_toolchain_config_info(ctx, features=[], action_configs=[], artifact_name_patterns=[], cxx_builtin_include_directories=[], toolchain_identifier, host_system_name=None, target_system_name=None, target_cpu=None, target_libc=None, compiler, abi_version=None, abi_libc_version=None, tool_paths=[], make_variables=[], builtin_sysroot=None)Tạo trình cung cấp
CcToolchainConfigInfo
Tham số
Thông số | Mô tả |
---|---|
ctx
|
ctx;
bắt buộc Ngữ cảnh quy tắc. |
features
|
trình tự; giá trị mặc định là [] Chứa tất cả thông số kỹ thuật của cờ cho một tính năng. Đối số:
- provides chứa tên của một tính năng hoặc cấu hình hành động khác mà chúng ta muốn bật.- provides chứa cùng một giá trị với "cung cấp" trong một tính năng hoặc cấu hình hành động khác mà chúng ta muốn bật. Sử dụng tính năng này để đảm bảo rằng các tính năng không tương thích không thể vô tình được kích hoạt cùng một lúc, dẫn đến việc khó chẩn đoán lỗi trình biên dịch.
|
action_configs
|
trình tự; giá trị mặc định là [] . Cấu hình hành động tương ứng với một hành động Bazel và cho phép chọn một công cụ dựa trên các tính năng đã kích hoạt. Việc kích hoạt cấu hình hành động diễn ra theo cùng một ngữ nghĩa như các tính năng: một tính năng có thể "yêu cầu" hoặc "ngụ ý" một cấu hình hành động giống như cách một tính năng khác sẽ làm. Đối số:
|
artifact_name_patterns
|
trình tự; giá trị mặc định là [] Tên của một cấu phần phần mềm thuộc một danh mục nhất định của cấu phần phần mềm đầu vào hoặc đầu ra cho một hành động. Đối số:
|
cxx_builtin_include_directories
|
trình tự; giá trị mặc định là [] Thư mục bao gồm tích hợp sẵn để biên dịch C++. Đây phải là các đường dẫn chính xác mà trình biên dịch sử dụng và thường tương ứng với thư mục gốc của exec. Bạn có thể xác định các đường dẫn mà trình biên dịch sử dụng bằng 'gcc -E -xc++ - -v'. Chúng tôi hiện cũng sử dụng các đường dẫn C++ để biên dịch C. Việc này là an toàn miễn là không có xung đột tên giữa các tệp tiêu đề C++ và C. Đường dẫn tương đối được phân giải tương ứng với thư mục tệp cấu hình. Nếu trình biên dịch có hỗ trợ --sysroot, thì các đường dẫn này phải sử dụng %sysroot% thay vì đường dẫn bao gồm và chỉ định thuộc tính sysroot để cung cấp cho blaze thông tin cần thiết để thay thế chính xác. |
toolchain_identifier
|
string;
bắt buộc Giá trị nhận dạng duy nhất của chuỗi công cụ trong bản phát hành crosstool. Bạn phải có thể sử dụng tên này làm tên thư mục trong một đường dẫn. Tên phải khớp với biểu thức chính quy sau: [a-zA-Z_][\.\- \w]* |
host_system_name
|
chuỗi; hoặc None ;
mặc định là None Bị bỏ qua. |
target_system_name
|
chuỗi; hoặc None ;
mặc định là None Không dùng nữa. Tên hệ thống GNU. Chuỗi này được hiển thị cho CcToolchainInfo.target_gnu_system_name. |
target_cpu
|
chuỗi; hoặc None ; giá trị mặc định là None Không dùng nữa: Hãy sử dụng các quy tắc ràng buộc dựa trên CPU. Nếu chuỗi là "k8", thì "target_cpu" sẽ bị bỏ qua khỏi tên tệp của dữ liệu hồ sơ FDO thô. |
target_libc
|
chuỗi; hoặc None ;
mặc định là None Không dùng nữa: Hãy sử dụng các quy tắc ràng buộc dựa trên hệ điều hành. Chuỗi phiên bản libc (ví dụ: "glibc-2.2.2"). Nếu chuỗi là "macosx", nền tảng được giả định là MacOS. Nếu không, hãy chọn Linux. Chuỗi này được hiển thị cho CcToolchainInfo.libc. |
compiler
|
string;
bắt buộc Chuỗi trình biên dịch (ví dụ: "gcc"). Trình biên dịch của chuỗi công cụ hiện tại được hiển thị dưới dạng giá trị cờ `@bazel_tools//tools/cpp:compiler (compiler_flag)`. Các mục tiêu yêu cầu cờ dành riêng cho trình biên dịch có thể sử dụng config_settings trong https://github.com/bazelbuild/rules_cc/blob/main/cc/compiler/BUILD trong câu lệnh select() hoặc tạo config_setting tuỳ chỉnh nếu các chế độ cài đặt hiện có không đủ. |
abi_version
|
string; hoặc None ;
mặc định là None ABI đang sử dụng, là phiên bản gcc. Ví dụ: "gcc-3.4". Chuỗi này được đặt thành ABI biến chuỗi công cụ C++. |
abi_libc_version
|
string; hoặc None ;
mặc định là None Phiên bản glibc mà abi chúng ta đang sử dụng. Chuỗi này được đặt thành biến chuỗi công cụ C++ ABI_LIBC_VERSION. |
tool_paths
|
trình tự; giá trị mặc định là [] vị trí công cụ. Đối số:
|
make_variables
|
trình tự; giá trị mặc định là [] Một biến tạo được cung cấp quyền truy cập cho các quy tắc. |
builtin_sysroot
|
string; hoặc None ;
mặc định là None sysroot tích hợp. Nếu không có thuộc tính này, Bazel sẽ không cho phép sử dụng một sysroot khác, tức là thông qua tuỳ chọn --grte_top. |
create_compilation_context
CompilationContext cc_common.create_compilation_context(headers=unbound, system_includes=unbound, includes=unbound, quote_includes=unbound, framework_includes=unbound, defines=unbound, local_defines=unbound)Tạo
CompilationContext
.
Tham số
Thông số | Mô tả |
---|---|
headers
|
mặc định là unbound Tập hợp tiêu đề cần thiết để biên dịch mục tiêu này |
system_includes
|
mặc định là unbound Tập hợp các đường dẫn tìm kiếm cho các tệp tiêu đề được tham chiếu bằng dấu nhọn, tức là #include <foo/bar/header.h>. Các đường dẫn này có thể tương ứng với thư mục gốc của exec hoặc tuyệt đối. Thường được truyền bằng -isystem |
includes
|
mặc định là unbound Tập hợp các đường dẫn tìm kiếm cho các tệp tiêu đề được tham chiếu bằng cả dấu ngoặc nhọn và dấu ngoặc kép.Thường được truyền bằng -I |
quote_includes
|
mặc định là unbound Tập hợp các đường dẫn tìm kiếm cho các tệp tiêu đề được tham chiếu bằng dấu ngoặc kép, tức là #include "foo/bar/header.h". Các đường dẫn này có thể tương đối so với thư mục gốc của exec hoặc tuyệt đối. Thường được truyền bằng -iquote |
framework_includes
|
mặc định là unbound Tập hợp các đường dẫn tìm kiếm khung cho tệp tiêu đề (chỉ dành cho nền tảng Apple) |
defines
|
mặc định là unbound Tập hợp các định nghĩa cần thiết để biên dịch mục tiêu này. Mỗi định nghĩa là một chuỗi. Truyền tải bắc cầu đến các phần phụ thuộc. |
local_defines
|
mặc định là unbound Tập hợp các định nghĩa cần thiết để biên dịch mục tiêu này. Mỗi định nghĩa là một chuỗi. Không được truyền tải cho các phần phụ thuộc. |
create_compilation_outputs
CcCompilationOutputs cc_common.create_compilation_outputs(objects=None, pic_objects=None)Tạo đối tượng đầu ra biên dịch.
Tham số
Thông số | Mô tả |
---|---|
objects
|
depset; hoặc None ;
mặc định là None Danh sách tệp đối tượng. |
pic_objects
|
depset; hoặc None ;
mặc định là None Danh sách tệp đối tượng pic. |
create_compile_variables
Variables cc_common.create_compile_variables(cc_toolchain, feature_configuration, source_file=None, output_file=None, user_compile_flags=None, include_directories=None, quote_include_directories=None, system_include_directories=None, framework_include_directories=None, preprocessor_defines=None, thinlto_index=None, thinlto_input_bitcode_file=None, thinlto_output_object_file=None, use_pic=False, add_legacy_cxx_options=False, variables_extension=unbound)Trả về các biến dùng cho các thao tác biên dịch.
Tham số
Thông số | Mô tả |
---|---|
cc_toolchain
|
Thông tin;
bắt buộc cc_toolchain mà chúng ta đang tạo biến bản dựng. |
feature_configuration
|
FeatureConfiguration;
bắt buộc Cấu hình tính năng cần được truy vấn. |
source_file
|
mặc định là None Tệp nguồn không bắt buộc để biên dịch. Vui lòng ưu tiên truyền source_file tại đây thay vì thêm vào cuối dòng lệnh được tạo từ cc_common.get_memory_inefficient_command_line, vì sau đó, tác giả chuỗi công cụ có thể chỉ định và định vị cờ trình biên dịch đúng cách. |
output_file
|
mặc định là None Tệp đầu ra không bắt buộc của quá trình biên dịch. Vui lòng ưu tiên truyền output_file tại đây thay vì thêm tệp này vào cuối dòng lệnh được tạo từ cc_common.get_memory_inefficient_command_line, vì sau đó, tác giả chuỗi công cụ có thể chỉ định và định vị chính xác các cờ trình biên dịch. |
user_compile_flags
|
trình tự của chuỗi; hoặc None ; giá trị mặc định là None Danh sách các cờ biên dịch bổ sung (copts). |
include_directories
|
depset; hoặc None ;
mặc định là None Depset của các thư mục bao gồm. |
quote_include_directories
|
depset; hoặc None ;
mặc định là None Depset của trích dẫn bao gồm các thư mục. |
system_include_directories
|
depset; hoặc None ;
mặc định là None Depset của hệ thống bao gồm các thư mục. |
framework_include_directories
|
depset; hoặc None ;
mặc định là None Depset của khung bao gồm các thư mục. |
preprocessor_defines
|
depset; hoặc None ;
mặc định là None Depset của các định nghĩa của bộ xử lý trước. |
thinlto_index
|
chuỗi; hoặc None ; giá trị mặc định là None đường dẫn tệp chỉ mục LTO. |
thinlto_input_bitcode_file
|
string; hoặc None ;
mặc định là None Tệp bitcode được nhập vào phần phụ trợ LTO. |
thinlto_output_object_file
|
chuỗi; hoặc None ; giá trị mặc định là None Tệp đối tượng do phần phụ trợ LTO xuất ra. |
use_pic
|
bool;
mặc định là False Khi đúng, quá trình biên dịch sẽ tạo mã độc lập với vị trí. |
add_legacy_cxx_options
|
bool;
mặc định là False Không dùng. |
variables_extension
|
dict; giá trị mặc định là unbound Một từ điển gồm các biến bổ sung mà các thao tác biên dịch sử dụng. |
create_library_to_link
LibraryToLink cc_common.create_library_to_link(actions, feature_configuration=None, cc_toolchain=None, static_library=None, pic_static_library=None, dynamic_library=None, interface_library=None, pic_objects=unbound, objects=unbound, alwayslink=False, dynamic_library_symlink_path='', interface_library_symlink_path='')Tạo
LibraryToLink
Tham số
Thông số | Mô tả |
---|---|
actions
|
đối tượng actions bắt buộc. |
feature_configuration
|
mặc định là None feature_configuration để được truy vấn.
|
cc_toolchain
|
mặc định là nhà cung cấp None CcToolchainInfo sẽ được sử dụng.
|
static_library
|
Tệp; hoặc None ; giá trị mặc định là None File của thư viện tĩnh cần liên kết.
|
pic_static_library
|
Tệp; hoặc None ; giá trị mặc định là None File của thư viện tĩnh pic cần liên kết.
|
dynamic_library
|
Tệp; hoặc None ; giá trị mặc định là None File của thư viện động cần liên kết. Luôn được dùng cho thời gian chạy và dùng để liên kết nếu không truyền interface_library .
|
interface_library
|
Tệp; hoặc None ; giá trị mặc định là None File của thư viện giao diện cần liên kết.
|
pic_objects
|
trình tự của Tệp;
mặc định là unbound Thử nghiệm, không sử dụng |
objects
|
trình tự của Tệp;
mặc định là unbound Thử nghiệm, không sử dụng |
alwayslink
|
bool; giá trị mặc định là False . Có liên kết thư viện/đối tượng tĩnh trong khối --whole_archive hay không. |
dynamic_library_symlink_path
|
string;
mặc định là '' Ghi đè đường dẫn mặc định của đường liên kết thư viện động trong thư mục solib. Chuỗi trống để sử dụng giá trị mặc định. |
interface_library_symlink_path
|
string;
mặc định là '' Ghi đè đường dẫn mặc định của đường liên kết thư viện giao diện trong thư mục solib. Chuỗi trống để sử dụng giá trị mặc định. |
create_link_variables
Variables cc_common.create_link_variables(cc_toolchain, feature_configuration, library_search_directories=[], runtime_library_search_directories=[], user_link_flags=[], output_file=None, param_file=None, is_using_linker=True, is_linking_dynamic_library=False, must_keep_debug=True, use_test_only_flags=False, is_static_linking_mode=True)Trả về các biến liên kết dùng để liên kết các hành động.
Tham số
Thông số | Mô tả |
---|---|
cc_toolchain
|
Thông tin;
bắt buộc cc_toolchain mà chúng ta đang tạo biến bản dựng. |
feature_configuration
|
FeatureConfiguration;
bắt buộc Cấu hình tính năng cần được truy vấn. |
library_search_directories
|
depset;
mặc định là [] Depset của các thư mục mà trình liên kết sẽ tìm thư viện tại thời điểm liên kết. |
runtime_library_search_directories
|
depset; giá trị mặc định là [] Depset của các thư mục mà trình tải sẽ tìm kiếm thư viện trong thời gian chạy. |
user_link_flags
|
trình tự; giá trị mặc định là [] Danh sách cờ liên kết bổ sung (linkopts). |
output_file
|
mặc định là None Đường dẫn tệp đầu ra không bắt buộc. |
param_file
|
mặc định là None Đường dẫn tệp tham số không bắt buộc. |
is_using_linker
|
bool;
mặc định là True Đúng khi sử dụng trình liên kết, Sai khi lưu trữ. Phương thức gọi chịu trách nhiệm đồng bộ hoá thông tin này với tên thao tác được sử dụng (is_using_linker = True để liên kết thư viện thực thi hoặc thư viện động, is_using_linker = False để lưu trữ thư viện tĩnh). |
is_linking_dynamic_library
|
bool; giá trị mặc định là False Đúng khi tạo thư viện động, Sai khi tạo thư viện thực thi hoặc thư viện tĩnh. Phương thức gọi chịu trách nhiệm đồng bộ hoá tên này với tên hành động được sử dụng. Trường này sẽ bị xoá sau khi lỗi b/65151735 được khắc phục. |
must_keep_debug
|
bool;
mặc định là True Khi được đặt thành False, bazel sẽ hiển thị biến "strip_debug_symbols", thường được dùng để sử dụng trình liên kết nhằm loại bỏ các biểu tượng gỡ lỗi khỏi tệp đầu ra. |
use_test_only_flags
|
bool; giá trị mặc định là False Khi được đặt thành true, biến "is_cc_test" sẽ được đặt. |
is_static_linking_mode
|
bool;
mặc định là True Không dùng. |
create_linker_input
LinkerInput cc_common.create_linker_input(owner, libraries=None, user_link_flags=None, additional_inputs=None)Tạo
LinkerInput
.
Tham số
Thông số | Mô tả |
---|---|
owner
|
Nhãn;
bắt buộc Nhãn của mục tiêu đã tạo tất cả tệp được dùng trong dữ liệu đầu vào này. |
libraries
|
None ; hoặc depset;
mặc định là None Danh sách LibraryToLink .
|
user_link_flags
|
None ; hoặc depset của chuỗi; hoặc trình tự của chuỗi;
mặc định là None Cờ liên kết người dùng được truyền dưới dạng chuỗi. Chấp nhận [String], [[String]] hoặc depset(String). Bạn không nên sử dụng cách thứ hai vì cách này chỉ được giữ lại cho mục đích tương thích, nhóm phần phụ thuộc sẽ được làm phẳng. Nếu bạn muốn truyền user_link_flags thông qua depsets() chưa được làm phẳng, hãy gói các cờ này trong LinkerInput để chúng không bị làm phẳng cho đến cuối cùng. |
additional_inputs
|
None ; hoặc depset;
mặc định là None Đối với các dữ liệu đầu vào bổ sung cho thao tác liên kết, ví dụ: liên kết tập lệnh. |
create_linking_context
LinkingContext cc_common.create_linking_context(linker_inputs=None, libraries_to_link=None, user_link_flags=None, additional_inputs=None)Tạo
LinkingContext
.
Tham số
Thông số | Mô tả |
---|---|
linker_inputs
|
None ; hoặc depset;
mặc định là None Depset của LinkerInput .
|
libraries_to_link
|
None ; hoặc trình tự; giá trị mặc định là None Không dùng nữa. Thông số này không còn được dùng nữa và sẽ sớm bị loại bỏ. Vui lòng không phụ thuộc vào tính năng này. Tính năng này bị tắt bằng --incompatible_require_linker_input_cc_api . Sử dụng cờ này để xác minh rằng mã của bạn tương thích với việc sắp bị xoá. Danh sách LibraryToLink .
|
user_link_flags
|
None ; hoặc trình tự; giá trị mặc định là None Không dùng nữa. Thông số này không còn được dùng nữa và sẽ sớm bị loại bỏ. Vui lòng không phụ thuộc vào tính năng này. Tính năng này bị tắt bằng --incompatible_require_linker_input_cc_api . Sử dụng cờ này để xác minh rằng mã của bạn tương thích với việc sắp bị xoá. Danh sách cờ liên kết người dùng được truyền dưới dạng chuỗi. |
additional_inputs
|
None ; hoặc trình tự; giá trị mặc định là None Không dùng nữa. Thông số này không còn được dùng nữa và sẽ sớm bị loại bỏ. Vui lòng không phụ thuộc vào tính năng này. Tính năng này bị tắt bằng --incompatible_require_linker_input_cc_api . Sử dụng cờ này để xác minh rằng mã của bạn tương thích với việc sắp bị xoá. Để thêm dữ liệu đầu vào cho thao tác liên kết, ví dụ: liên kết tập lệnh. |
create_linking_context_from_compilation_outputs
tuple cc_common.create_linking_context_from_compilation_outputs(actions, name, feature_configuration, cc_toolchain, language='c++', disallow_static_libraries=False, disallow_dynamic_library=False, compilation_outputs, linking_contexts=[], user_link_flags=[], alwayslink=False, additional_inputs=[], variables_extension=unbound)Nên dùng để tạo các quy tắc thư viện có thể truyền thông tin xuống dưới để sau này được liên kết bằng một quy tắc cấp cao nhất thực hiện liên kết bắc cầu nhằm tạo một tệp thực thi hoặc thư viện động. Trả về một bộ dữ liệu gồm (
CcLinkingContext
, CcLinkingOutputs
).
Tham số
Thông số | Mô tả |
---|---|
actions
|
actions; đối tượng actions bắt buộc. |
name
|
string;
bắt buộc Dùng để đặt tên cho cấu phần phần mềm đầu ra của các hành động do phương thức này tạo. |
feature_configuration
|
FeatureConfiguration;
bắt buộcfeature_configuration để được truy vấn.
|
cc_toolchain
|
Thông tin; nhà cung cấp CcToolchainInfo cần thiết để sử dụng.
|
language
|
string;
mặc định là 'c++' Hiện chỉ hỗ trợ C++. Không sử dụng thông số này. |
disallow_static_libraries
|
bool;
mặc định là False Liệu có nên tạo thư viện tĩnh hay không. |
disallow_dynamic_library
|
bool;
mặc định là False Liệu có nên tạo thư viện động hay không. |
compilation_outputs
|
CcCompilationOutputs; bắt buộc Đầu ra biên dịch chứa các tệp đối tượng để liên kết. |
linking_contexts
|
trình tự; giá trị mặc định là [] Thư viện từ phần phụ thuộc. Các thư viện này sẽ được liên kết vào cấu phần phần mềm đầu ra của lệnh gọi link(), cho dù đó là tệp nhị phân hay thư viện. |
user_link_flags
|
trình tự; giá trị mặc định là [] Danh sách bổ sung các tuỳ chọn liên kết. |
alwayslink
|
bool;
mặc định là False Liệu thư viện này có phải luôn được liên kết hay không. |
additional_inputs
|
trình tự;
mặc định là [] Để nhập thêm thông tin vào hành động liên kết, ví dụ: liên kết tập lệnh. |
variables_extension
|
dict;
mặc định là unbound Các biến bổ sung để truyền vào cấu hình chuỗi công cụ khi tạo dòng lệnh liên kết. |
create_lto_compilation_context
LtoCompilationContext cc_common.create_lto_compilation_context(objects={})Tạo ngữ cảnh biên dịch LTO
Tham số
Thông số | Mô tả |
---|---|
objects
|
dict; giá trị mặc định là {} ánh xạ đối tượng đầy đủ đến đối tượng chỉ mục |
do_not_use_tools_cpp_compiler_present
None
cc_common.do_not_use_tools_cpp_compiler_present
Không sử dụng trường này, mục đích duy nhất của trường này là giúp di chuyển từ config_setting.values{'compiler') sang config_settings.flag_values{'@bazel_tools//tools/cpp:compiler'}
get_environment_variables
dict cc_common.get_environment_variables(feature_configuration, action_name, variables)Trả về các biến môi trường cần đặt cho hành động đã cho.
Tham số
Thông số | Mô tả |
---|---|
feature_configuration
|
FeatureConfiguration;
bắt buộc Cấu hình tính năng cần được truy vấn. |
action_name
|
string;
bắt buộc Tên của thao tác. Phải là một trong các tên trong @bazel_tools//tools/build_defs/cc:action_names.bzl (https://github.com/bazelbuild/bazel/blob/master/tools/build_defs/cc/action_names.bzl) |
variables
|
Biến;
bắt buộc Biến bản dựng sẽ được dùng để mở rộng mẫu. |
get_execution_requirements
sequence cc_common.get_execution_requirements(feature_configuration, action_name)Trả về các yêu cầu thực thi cho hành động đã cho.
Tham số
Thông số | Mô tả |
---|---|
feature_configuration
|
FeatureConfiguration;
bắt buộc Cấu hình tính năng cần được truy vấn. |
action_name
|
string;
bắt buộc Tên của hành động. Phải là một trong các tên trong @bazel_tools//tools/build_defs/cc:action_names.bzl (https://github.com/bazelbuild/bazel/blob/master/tools/build_defs/cc/action_names.bzl) |
get_memory_inefficient_command_line
sequence cc_common.get_memory_inefficient_command_line(feature_configuration, action_name, variables)Trả về cờ dòng lệnh được làm phẳng cho một hành động nhất định, sử dụng các biến đã cho để mở rộng. Làm phẳng các tập hợp lồng nhau và tốt nhất là không nên sử dụng hoặc ít nhất là không nên sử dụng sau khi phân tích. Chúng tôi đang tiếp tục nghiên cứu về hàm tiết kiệm bộ nhớ trả về Args.
Tham số
Thông số | Mô tả |
---|---|
feature_configuration
|
FeatureConfiguration;
bắt buộc Cấu hình tính năng cần được truy vấn. |
action_name
|
string;
bắt buộc Tên của hành động. Phải là một trong các tên trong @bazel_tools//tools/build_defs/cc:action_names.bzl (https://github.com/bazelbuild/bazel/blob/master/tools/build_defs/cc/action_names.bzl) |
variables
|
Biến;
bắt buộc Biến bản dựng sẽ được dùng để mở rộng mẫu. |
get_tool_for_action
string cc_common.get_tool_for_action(feature_configuration, action_name)Trả về đường dẫn công cụ cho thao tác đã cho.
Tham số
Thông số | Mô tả |
---|---|
feature_configuration
|
FeatureConfiguration;
bắt buộc Cấu hình tính năng cần được truy vấn. |
action_name
|
string;
bắt buộc Tên của hành động. Phải là một trong các tên trong @bazel_tools//tools/build_defs/cc:action_names.bzl (https://github.com/bazelbuild/bazel/blob/master/tools/build_defs/cc/action_names.bzl) |
is_enabled
bool cc_common.is_enabled(feature_configuration, feature_name)Trả về True nếu tính năng đã cho được bật trong cấu hình tính năng.
Tham số
Thông số | Mô tả |
---|---|
feature_configuration
|
FeatureConfiguration;
bắt buộc Cấu hình tính năng cần được truy vấn. |
feature_name
|
string;
bắt buộc Tên của tính năng. |
liên kết
CcLinkingOutputs cc_common.link(actions, name, feature_configuration, cc_toolchain, language='c++', output_type='executable', link_deps_statically=True, compilation_outputs=None, linking_contexts=[], user_link_flags=[], stamp=0, additional_inputs=[], additional_outputs=[], variables_extension={})Nên dùng cho việc liên kết bắc cầu C++.
Tham số
Thông số | Mô tả |
---|---|
actions
|
actions; đối tượng actions bắt buộc. |
name
|
string;
bắt buộc Dùng để đặt tên cho cấu phần phần mềm đầu ra của các hành động do phương thức này tạo ra. |
feature_configuration
|
FeatureConfiguration;
bắt buộcfeature_configuration để được truy vấn.
|
cc_toolchain
|
Thông tin; nhà cung cấp CcToolchainInfo cần thiết để sử dụng.
|
language
|
string;
mặc định là 'c++' Hiện chỉ hỗ trợ C++. Không sử dụng thông số này. |
output_type
|
string;
mặc định là 'executable' Có thể là "executable" hoặc "dynamic_library". |
link_deps_statically
|
bool;
mặc định là True True để liên kết các phần phụ thuộc một cách tĩnh, False để liên kết động. |
compilation_outputs
|
CcCompilationOutputs; hoặc None ; giá trị mặc định là None Đầu ra biên dịch chứa các tệp đối tượng để liên kết. |
linking_contexts
|
trình tự;
mặc định là [] Liên kết ngữ cảnh từ các phần phụ thuộc sẽ được liên kết vào ngữ cảnh liên kết do quy tắc này tạo. |
user_link_flags
|
trình tự;
mặc định là [] Danh sách bổ sung các tuỳ chọn trình liên kết. |
stamp
|
int;
mặc định là 0 Liệu có đưa thông tin bản dựng vào tệp thực thi được liên kết hay không, nếu output_type là "executable". Nếu là 1, thông tin bản dựng luôn được đưa vào. Nếu là 0 (thông tin bản dựng mặc định luôn bị loại trừ. Nếu là -1, hãy sử dụng hành vi mặc định. Hành vi này có thể bị ghi đè bằng cờ --[no]stamp. Bạn không nên đặt giá trị này (hoặc đặt thành 0) khi tạo đầu ra có thể thực thi cho các quy tắc kiểm thử. |
additional_inputs
|
sequence; hoặc depset;
mặc định là [] Đối với các dữ liệu đầu vào bổ sung cho thao tác liên kết, ví dụ: liên kết tập lệnh. |
additional_outputs
|
trình tự; giá trị mặc định là [] Để có thêm đầu ra cho thao tác liên kết, ví dụ: tệp bản đồ. |
variables_extension
|
dict; giá trị mặc định là {} Các biến bổ sung để truyền vào cấu hình chuỗi công cụ khi tạo dòng lệnh liên kết. |
merge_compilation_contexts
CompilationContext cc_common.merge_compilation_contexts(compilation_contexts=[])Hợp nhất nhiều
CompilationContexts
thành một.
Tham số
Thông số | Mô tả |
---|---|
compilation_contexts
|
trình tự;
mặc định là [] Danh sách CompilationContexts cần hợp nhất. Tiêu đề của mỗi ngữ cảnh sẽ được xuất bằng các trường trực tiếp trong trình cung cấp được trả về.
|
merge_compilation_outputs
CcCompilationOutputs cc_common.merge_compilation_outputs(compilation_outputs=[])Hợp nhất các kết quả biên dịch.
Tham số
Thông số | Mô tả |
---|---|
compilation_outputs
|
trình tự; giá trị mặc định là [] |