ยูทิลิตีสำหรับการคอมไพล์ การลิงก์ และการสร้างบรรทัดคำสั่ง
สมาชิก
- action_is_enabled
- CcToolchainInfo
- คอมไพล์
- 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)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
feature_configuration
|
FeatureConfiguration
ต้องระบุ การกำหนดค่าฟีเจอร์ที่จะค้นหา |
action_name
|
string;
ต้องระบุ ชื่อของ action_config |
CcToolchainInfo
Provider cc_common.CcToolchainInfo
คอมไพล์
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=[], compilation_contexts=[], name, disallow_pic_outputs=False, disallow_nopic_outputs=False, additional_inputs=[], module_interfaces=unbound)
CompilationContext
, CcCompilationOutputs
)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
actions
|
actions;
ต้องระบุactions ออบเจ็กต์
|
feature_configuration
|
FeatureConfiguration
ต้องระบุfeature_configuration ที่จะค้นหา
|
cc_toolchain
|
ข้อมูล
ต้องระบุ ผู้ให้บริการ CcToolchainInfo ที่จะใช้
|
srcs
|
sequence;
ค่าเริ่มต้นคือ [] รายการไฟล์ต้นฉบับที่จะรวบรวม |
public_hdrs
|
sequence;
ค่าเริ่มต้นคือ [] รายการส่วนหัวที่จำเป็นสำหรับการคอมไพล์ src และอาจรวมโดยกฎที่เกี่ยวข้องแบบทางอ้อม |
private_hdrs
|
sequence;
ค่าเริ่มต้นคือ [] รายการส่วนหัวที่จำเป็นสำหรับการคอมไพล์ srcs และที่จะไม่รวมโดยกฎที่อ้างอิง |
includes
|
sequence; หรือ depset
ค่าเริ่มต้นคือ [] เส้นทางการค้นหาไฟล์ส่วนหัวที่อ้างอิงทั้งวงเล็บมุมและเครื่องหมายคำพูด โดยทั่วไปมักจะส่งด้วย -I เผยแพร่ไปสู่ผู้ที่พึ่งพาอาศัยในทางอ้อม |
quote_includes
|
sequence;
ค่าเริ่มต้นคือ [] เส้นทางการค้นหาไฟล์ส่วนหัวที่อ้างอิงโดยเครื่องหมายคำพูด เช่น #include "foo/bar/header.h" ซึ่งอาจสัมพันธ์กับรูทของการดำเนินการหรือแบบสัมบูรณ์ก็ได้ โดยทั่วไปจะส่งพร้อมกับ -iquote เผยแพร่ไปสู่ผู้ที่พึ่งพาอาศัยในทางอ้อม |
system_includes
|
sequence;
ค่าเริ่มต้นคือ [] เส้นทางการค้นหาไฟล์ส่วนหัวที่อ้างอิงด้วยวงเล็บมุม เช่น #include <foo/bar/header.h> ซึ่งอาจสัมพันธ์กับรูทของการดำเนินการหรือแบบสัมบูรณ์ก็ได้ โดยปกติจะผ่านกับ -isystem เผยแพร่ไปสู่ผู้ที่พึ่งพาอาศัยในทางอ้อม |
framework_includes
|
sequence;
ค่าเริ่มต้นคือ [] เส้นทางการค้นหาไฟล์ส่วนหัวจากเฟรมเวิร์กของ Apple ซึ่งอาจสัมพันธ์กับรูทของการดำเนินการหรือแบบสัมบูรณ์ก็ได้ โดยปกติจะผ่านด้วย -F เผยแพร่ไปสู่ผู้ที่พึ่งพาอาศัยในทางอ้อม |
defines
|
sequence;
ค่าเริ่มต้นคือ [] ต้องใช้ชุดการกำหนดเพื่อคอมไพล์เป้าหมายนี้ แต่ละนิยามคือสตริง เผยแพร่ไปสู่ผู้ที่พึ่งพาอาศัยในทางอ้อม |
local_defines
|
sequence;
ค่าเริ่มต้นคือ [] ต้องใช้ชุดการกำหนดเพื่อคอมไพล์เป้าหมายนี้ แต่ละนิยามคือสตริง ไม่กระจายไปยังการอ้างอิงแบบสลาย |
include_prefix
|
string;
ค่าเริ่มต้นคือ '' คำนำหน้าที่จะเพิ่มลงในเส้นทางของส่วนหัวของกฎนี้ เมื่อตั้งค่าแล้ว ส่วนหัวในแอตทริบิวต์ hdrs ของกฎนี้จะเข้าถึงได้ที่ คือค่าของแอตทริบิวต์นี้ที่เพิ่มไว้ข้างหน้าเส้นทางที่สัมพันธ์กับที่เก็บ ระบบจะนำคำนำหน้าในแอตทริบิวต์ Strip_include_prefix ออกก่อนที่จะเพิ่มคำนำหน้านี้ |
strip_include_prefix
|
string;
ค่าเริ่มต้นคือ '' คำนำหน้าที่จะตัดออกจากเส้นทางของส่วนหัวของกฎนี้ เมื่อตั้งค่าแล้ว ส่วนหัวในแอตทริบิวต์ hdr ของกฎนี้จะเข้าถึงได้จากเส้นทางโดยมีการตัดคำนำหน้านี้ออก หากเป็นเส้นทางแบบสัมพัทธ์ ระบบจะใช้เส้นทางที่สัมพันธ์กับแพ็กเกจ หากเป็นเส้นทางสัมบูรณ์ ระบบเข้าใจว่าเป็นเส้นทางที่สัมพันธ์กับที่เก็บ ระบบจะเพิ่มคำนำหน้าในแอตทริบิวต์ include_prefix ไว้หลังจากที่นำคำนำหน้านี้ออก |
user_compile_flags
|
sequence;
ค่าเริ่มต้นคือ [] รายการตัวเลือกคอมไพล์เพิ่มเติม |
compilation_contexts
|
sequence;
ค่าเริ่มต้นคือ [] ส่วนหัวจากทรัพยากร Dependency ที่ใช้สำหรับการคอมไพล์ |
name
|
string;
ต้องระบุ ซึ่งจะใช้ในการตั้งชื่ออาร์ติแฟกต์เอาต์พุตของการดำเนินการที่สร้างโดยเมธอดนี้ ดูอาร์กิวเมนต์ "main_output" ด้วย |
disallow_pic_outputs
|
bool;
ค่าเริ่มต้นคือ False ควรสร้างเอาต์พุต PIC ไหม |
disallow_nopic_outputs
|
bool;
ค่าเริ่มต้นคือ False ควรสร้างเอาต์พุต NOPIC หรือไม่ |
additional_inputs
|
sequence;
ค่าเริ่มต้นคือ [] รายการไฟล์เพิ่มเติมที่จำเป็นสำหรับการคอมไพล์ src |
module_interfaces
|
sequence;
ค่าเริ่มต้นคือ unbound รายการไฟล์แหล่งที่มาของอินเทอร์เฟซโมดูลที่จะรวบรวม หมายเหตุ: นี่เป็นฟีเจอร์ทดลอง ซึ่งเปิดใช้กับ --experimental_cpp_modules เท่านั้น |
configure_features
FeatureConfiguration cc_common.configure_features(ctx=None, cc_toolchain, language=None, requested_features=[], unsupported_features=[])
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
ctx
|
ctx; หรือ None ;
ค่าเริ่มต้นคือ None บริบทของกฎ |
cc_toolchain
|
ข้อมูล
ต้องระบุ cc_toolchain ที่เรากำหนดค่าฟีเจอร์ |
language
|
string; หรือ None ;
ค่าเริ่มต้นคือ None ภาษาที่จะกำหนดค่าสำหรับ: c++ หรือ objc (ค่าเริ่มต้น c++) |
requested_features
|
sequence;
ค่าเริ่มต้นคือ [] รายการฟีเจอร์ที่จะเปิดใช้ |
unsupported_features
|
sequence;
ค่าเริ่มต้นคือ [] รายการฟีเจอร์ที่กฎปัจจุบันไม่รองรับ |
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)
CcToolchainConfigInfo
วันที่
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
ctx
|
ctx;
ต้องระบุ บริบทของกฎ |
features
|
sequence;
ค่าเริ่มต้นคือ [] มีข้อกำหนด Flag ทั้งหมดสำหรับฟีเจอร์เดียว อาร์กิวเมนต์
- provides มีชื่อของการกำหนดค่าฟีเจอร์หรือการดำเนินการอื่นที่เราต้องการเปิดใช้- provides มีค่าเดียวกับ "การจัดเตรียม" ในฟีเจอร์หรือการกำหนดค่าการดำเนินการต่างๆ ที่เราต้องการเปิดใช้ ใช้ตัวเลือกนี้เพื่อให้มั่นใจว่าไม่สามารถเปิดใช้งานฟีเจอร์ที่ใช้ร่วมกันไม่ได้โดยไม่ได้ตั้งใจพร้อมกันได้ ซึ่งทําให้วินิจฉัยข้อผิดพลาดของคอมไพเลอร์ได้ยาก
|
action_configs
|
sequence;
ค่าเริ่มต้นคือ [] การกำหนดค่าการดำเนินการสอดคล้องกับการทำงานของ Bazel และอนุญาตให้เลือกเครื่องมือตามฟีเจอร์ที่เปิดใช้งาน การเปิดใช้งานการกำหนดค่าการดำเนินการเกิดขึ้นโดยความหมายเดียวกับฟีเจอร์ กล่าวคือ ฟีเจอร์จำเป็นต้องมี หรือ "โดยนัย" การกำหนดค่าการดำเนินการในลักษณะเดียวกันกับฟีเจอร์อื่น อาร์กิวเมนต์
|
artifact_name_patterns
|
sequence;
ค่าเริ่มต้นคือ [] ชื่อของอาร์ติแฟกต์ของอาร์ติแฟกต์อินพุตหรือเอาต์พุตในหมวดหมู่ที่กำหนดสำหรับการดำเนินการ อาร์กิวเมนต์
|
cxx_builtin_include_directories
|
sequence;
ค่าเริ่มต้นคือ [] ในตัวรวมไดเรกทอรีสำหรับการคอมไพล์ C++ เส้นทางเหล่านี้ควรเป็นเส้นทางตรงที่คอมไพเลอร์ใช้ และโดยทั่วไปจะสัมพันธ์กับรูทที่ดำเนินการ เส้นทางที่คอมไพเลอร์ใช้จะกำหนดได้ด้วย "gcc -E -xc++ - -v" ขณะนี้เราใช้เส้นทาง C++ สำหรับการคอมไพล์ C ซึ่งจะปลอดภัยตราบใดที่ไม่มีการปะทะชื่อระหว่างไฟล์ส่วนหัว C++ และ C ระบบจะจับคู่เส้นทางแบบสัมพัทธ์ที่สัมพันธ์กับไดเรกทอรีของไฟล์การกำหนดค่า หากคอมไพเลอร์มีการสนับสนุน --sysroot เส้นทางเหล่านี้ควรใช้ %sysroot% แทนเส้นทางรวม และระบุแอตทริบิวต์ sysroot เพื่อมอบข้อมูลที่จำเป็นสำหรับการแทนที่ที่ถูกต้องทันที |
toolchain_identifier
|
string;
ต้องระบุ ตัวระบุที่ไม่ซ้ำกันของ Toolchain ภายในรุ่น Crosstool ต้องใช้ชื่อนี้เป็นชื่อไดเรกทอรีในเส้นทางได้ ต้องตรงกับนิพจน์ทั่วไปต่อไปนี้: [a-zA-Z_][\.\- \w]* |
host_system_name
|
string; หรือ None ;
ค่าเริ่มต้นคือ None ไม่สนใจ |
target_system_name
|
string; หรือ None ;
ค่าเริ่มต้นคือ None เลิกใช้งานแล้ว ชื่อระบบ GNU สตริงจะแสดงใน CcToolchainInfo.target_gnu_system_name |
target_cpu
|
string; หรือ None ;
ค่าเริ่มต้นคือ None เลิกใช้งานแล้ว: ใช้ข้อจำกัดแบบ CPU แทน หากสตริงคือ "k8" ระบบจะไม่รวม "target_cpu" ไว้ในชื่อไฟล์ของข้อมูลโปรไฟล์ FDO ดิบ |
target_libc
|
string; หรือ None ;
ค่าเริ่มต้นคือ None เลิกใช้งานแล้ว: ใช้ข้อจำกัดที่อิงตามระบบปฏิบัติการแทน สตริงเวอร์ชัน libc (เช่น "glibc-2.2.2") หากสตริงคือ "macosx" ระบบจะถือว่าแพลตฟอร์มเป็น MacOS หรือไม่เช่นนั้น ก็ให้ Linux สตริงจะแสดงใน CcToolchainInfo.libc |
compiler
|
string;
ต้องระบุ สตริงคอมไพเลอร์ (เช่น "gcc") ส่วนคอมไพเลอร์ของ Toolchain ปัจจุบันจะมี "@bazel_tools//tools/cpp:compiler (compiler_flag)" เป็นค่าแฟล็ก เป้าหมายที่ต้องใช้ Flag เฉพาะคอมไพเลอร์จะใช้ config_settings ใน https://github.com/bazelbuild/rules_cc/blob/main/cc/compiler/BUILD ในคำสั่ง select() หรือสร้าง config_setting ที่กำหนดเองหากการตั้งค่าที่มีอยู่ไม่เพียงพอ |
abi_version
|
string; หรือ None ;
ค่าเริ่มต้นคือ None Abi ใช้งานอยู่ ซึ่งเป็นเวอร์ชัน gcc เช่น "gcc-3.4" สตริงตั้งค่าเป็น ABI สำหรับตัวแปรเครื่องมือเชนของ C++ |
abi_libc_version
|
string; หรือ None ;
ค่าเริ่มต้นคือ None เวอร์ชัน glibc ที่ abi ที่เราใช้อยู่ใช้ สตริงถูกตั้งค่าเป็นตัวแปรเครื่องมือเชน C++ ABI_LIBC_VERSION แล้ว |
tool_paths
|
sequence;
ค่าเริ่มต้นคือ [] ตำแหน่งเครื่องมือ อาร์กิวเมนต์
|
make_variables
|
sequence;
ค่าเริ่มต้นคือ [] ตัวแปรสร้างที่กฎเข้าถึงได้ |
builtin_sysroot
|
string; หรือ None ;
ค่าเริ่มต้นคือ None Sysroot ในตัว ถ้าไม่มีแอตทริบิวต์นี้ Bazel จะไม่อนุญาตให้ใช้ sysroot อื่น เช่น ผ่านตัวเลือก --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)
CompilationContext
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
headers
|
ค่าเริ่มต้นคือ unbound ชุดของส่วนหัวที่จำเป็นเพื่อคอมไพล์เป้าหมายนี้ |
system_includes
|
ค่าเริ่มต้นคือ unbound ชุดของเส้นทางการค้นหาสำหรับไฟล์ส่วนหัวที่อ้างอิงด้วยวงเล็บมุม เช่น #include <foo/bar/header.h> ซึ่งอาจสัมพันธ์กับรูทของการดำเนินการหรือแบบสัมบูรณ์ก็ได้ โดยปกติจะส่งผ่านกับ -isystem |
includes
|
ค่าเริ่มต้นคือ unbound ชุดของเส้นทางการค้นหาสำหรับไฟล์ส่วนหัวที่อ้างอิงทั้งด้วยวงเล็บมุมและเครื่องหมายคำพูด ซึ่งมักจะส่งผ่านด้วย -I |
quote_includes
|
ค่าเริ่มต้นคือ unbound ชุดของเส้นทางการค้นหาสำหรับไฟล์ส่วนหัวที่อ้างอิงด้วยเครื่องหมายคำพูด เช่น #include "foo/bar/header.h" ซึ่งอาจสัมพันธ์กับรูทของการดำเนินการหรือแบบสัมบูรณ์ก็ได้ มักจะส่งมาพร้อมกับ -iquote |
framework_includes
|
ค่าเริ่มต้นคือ unbound ชุดเส้นทางการค้นหาเฟรมเวิร์กสำหรับไฟล์ส่วนหัว (แพลตฟอร์ม Apple เท่านั้น) |
defines
|
ค่าเริ่มต้นคือ unbound ต้องใช้ชุดการกำหนดเพื่อคอมไพล์เป้าหมายนี้ แต่ละนิยามคือสตริง เผยแพร่แบบสัญจรให้กับผู้อยู่ในความอุปถัมภ์ |
local_defines
|
ค่าเริ่มต้นคือ unbound ต้องใช้ชุดการกำหนดเพื่อคอมไพล์เป้าหมายนี้ แต่ละนิยามคือสตริง ไม่เผยแพร่แบบสปอตไปยังผู้ที่พึ่งพาอาศัย |
create_compilation_outputs
CcCompilationOutputs cc_common.create_compilation_outputs(objects=None, pic_objects=None)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
objects
|
depset; หรือ None ;
ค่าเริ่มต้นคือ None รายการไฟล์ออบเจ็กต์ |
pic_objects
|
depset; หรือ None ;
ค่าเริ่มต้นคือ None รายการไฟล์ออบเจ็กต์รูปภาพ |
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)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
cc_toolchain
|
ข้อมูล
ต้องระบุ cc_toolchain ที่เรากําลังสร้างตัวแปรบิลด์ |
feature_configuration
|
FeatureConfiguration
ต้องระบุ การกำหนดค่าฟีเจอร์ที่จะค้นหา |
source_file
|
ค่าเริ่มต้นคือ None ไฟล์ต้นฉบับที่ไม่บังคับสำหรับการคอมไพล์ โปรดส่ง source_file ที่นี่ แล้วนำไปต่อท้ายบรรทัดคำสั่งที่สร้างจาก cc_common.get_memory_inefficiency_command_line เพราะจะทำให้ผู้เขียน Toolchain ระบุและจัดตำแหน่งแฟล็กคอมไพเลอร์ได้อย่างเหมาะสม |
output_file
|
ค่าเริ่มต้นคือ None ไฟล์เอาต์พุตที่ไม่บังคับของการคอมไพล์ โปรดส่ง exit_file ที่นี่ แล้วต่อท้ายบรรทัดคำสั่งที่สร้างจาก cc_common.get_memory_inefficiency_command_line เพราะจะทำให้ผู้เขียน Toolchain ระบุและจัดตำแหน่งแฟล็กคอมไพเลอร์ได้อย่างเหมาะสม |
user_compile_flags
|
sequence ของ strings หรือ None ;
ค่าเริ่มต้นคือ None รายการแฟล็กการคอมไพล์เพิ่มเติม (copt) |
include_directories
|
depset; หรือ None ;
ค่าเริ่มต้นคือ None Depset of include ไดเรกทอรี |
quote_include_directories
|
depset; หรือ None ;
ค่าเริ่มต้นคือ None ส่วนของใบเสนอราคารวมถึงไดเรกทอรี |
system_include_directories
|
depset; หรือ None ;
ค่าเริ่มต้นคือ None Depset ของระบบรวมถึงไดเรกทอรี |
framework_include_directories
|
depset; หรือ None ;
ค่าเริ่มต้นคือ None Depset ของเฟรมเวิร์กรวมถึงไดเรกทอรี |
preprocessor_defines
|
depset; หรือ None ;
ค่าเริ่มต้นคือ None Depset of PreProcessor เป็นผู้กำหนด |
thinlto_index
|
string; หรือ None ;
ค่าเริ่มต้นคือ None เส้นทางไฟล์ดัชนี LTO |
thinlto_input_bitcode_file
|
string; หรือ None ;
ค่าเริ่มต้นคือ None ไฟล์บิตโค้ดที่อินพุตไปยังแบ็กเอนด์ LTO |
thinlto_output_object_file
|
string; หรือ None ;
ค่าเริ่มต้นคือ None ไฟล์ออบเจ็กต์ที่แสดงผลโดยแบ็กเอนด์ LTO |
use_pic
|
bool;
ค่าเริ่มต้นคือ False เมื่อเป็นจริง การคอมไพล์จะสร้างโค้ดอิสระสำหรับตำแหน่ง |
add_legacy_cxx_options
|
bool;
ค่าเริ่มต้นคือ False ไม่ได้ใช้งาน |
variables_extension
|
dict;
ค่าเริ่มต้นคือ unbound พจนานุกรมตัวแปรเพิ่มเติมที่ใช้โดยการดำเนินการคอมไพล์ |
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='')
LibraryToLink
วันที่
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
actions
|
ต้องระบุactions ออบเจ็กต์
|
feature_configuration
|
ค่าเริ่มต้นคือ None feature_configuration ที่จะค้นหา
|
cc_toolchain
|
ค่าเริ่มต้นคือ None CcToolchainInfo ของผู้ให้บริการที่จะใช้
|
static_library
|
ไฟล์ หรือ None ;
ค่าเริ่มต้นคือ None File ของไลบรารีแบบคงที่จะลิงก์
|
pic_static_library
|
ไฟล์ หรือ None ;
ค่าเริ่มต้นคือ None คลังภาพภาพนิ่ง File รายการที่จะลิงก์
|
dynamic_library
|
ไฟล์ หรือ None ;
ค่าเริ่มต้นคือ None ไลบรารีแบบไดนามิก File รายการที่จะลิงก์ ใช้สำหรับรันไทม์เสมอและใช้สำหรับการลิงก์หากไม่มีการส่งผ่าน interface_library
|
interface_library
|
ไฟล์ หรือ None ;
ค่าเริ่มต้นคือ None File ของไลบรารีอินเทอร์เฟซที่จะลิงก์
|
pic_objects
|
sequence ของไฟล์
ค่าเริ่มต้นคือ unbound อยู่ระหว่างการทดสอบ อย่าใช้ |
objects
|
sequence ของไฟล์
ค่าเริ่มต้นคือ unbound อยู่ระหว่างการทดสอบ อย่าใช้ |
alwayslink
|
bool;
ค่าเริ่มต้นคือ False กำหนดว่าจะลิงก์ไลบรารี/ออบเจ็กต์แบบคงที่ในบล็อก --whole_archive หรือไม่ |
dynamic_library_symlink_path
|
string;
ค่าเริ่มต้นคือ '' ลบล้างเส้นทางเริ่มต้นของลิงก์ไลบรารีแบบไดนามิกในไดเรกทอรี Solib ล้างสตริงเพื่อใช้ค่าเริ่มต้น |
interface_library_symlink_path
|
string;
ค่าเริ่มต้นคือ '' ลบล้างเส้นทางเริ่มต้นของลิงก์ไลบรารีอินเทอร์เฟซในไดเรกทอรี Solib ล้างสตริงเพื่อใช้ค่าเริ่มต้น |
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)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
cc_toolchain
|
ข้อมูล
ต้องระบุ cc_toolchain ที่เรากําลังสร้างตัวแปรบิลด์ |
feature_configuration
|
FeatureConfiguration
ต้องระบุ การกำหนดค่าฟีเจอร์ที่จะค้นหา |
library_search_directories
|
depset;
ค่าเริ่มต้นคือ [] ส่วนของไดเรกทอรีที่ Linker จะค้นหาไลบรารี ณ เวลาของลิงก์ |
runtime_library_search_directories
|
depset;
ค่าเริ่มต้นคือ [] Depset ของไดเรกทอรีที่ตัวโหลดจะค้นหาไลบรารีขณะรันไทม์ |
user_link_flags
|
sequence;
ค่าเริ่มต้นคือ [] รายการแฟล็กลิงก์เพิ่มเติม (linkopts) |
output_file
|
ค่าเริ่มต้นคือ None เส้นทางของไฟล์เอาต์พุตที่ไม่บังคับ |
param_file
|
ค่าเริ่มต้นคือ None เส้นทางไฟล์พารามิเตอร์ที่ไม่บังคับ |
is_using_linker
|
bool;
ค่าเริ่มต้นคือ True จริงเมื่อใช้ Linker และเป็น "เท็จ" เมื่อเก็บ ผู้โทรมีหน้าที่ซิงค์ข้อมูลนี้ให้ตรงกับชื่อการดำเนินการที่ใช้ (is_using_linker = True สำหรับการลิงก์ไลบรารีที่ดำเนินการได้หรือไลบรารีแบบไดนามิก, is_using_linker = False สำหรับเก็บถาวรไลบรารีแบบคงที่) |
is_linking_dynamic_library
|
bool;
ค่าเริ่มต้นคือ False เป็นจริงเมื่อสร้างไลบรารีแบบไดนามิก เท็จเมื่อไลบรารีที่ดำเนินการได้หรือไลบรารีแบบคงที่ ผู้โทรมีหน้าที่ซิงค์ข้อมูลนี้กับชื่อการทำงานที่ใช้ ระบบจะนำช่องนี้ออกเมื่อแก้ไข b/65151735 แล้ว |
must_keep_debug
|
bool;
ค่าเริ่มต้นคือ True เมื่อตั้งค่าเป็น "เท็จ" bazel จะแสดง "strip_debug_symbols" ที่ปกติแล้วจะใช้ในการใช้ Linker เพื่อตัดสัญลักษณ์สำหรับแก้ไขข้อบกพร่องออกจากไฟล์เอาต์พุต |
use_test_only_flags
|
bool;
ค่าเริ่มต้นคือ False เมื่อตั้งค่าเป็น "จริง" "is_cc_test" จะได้รับการตั้งค่า |
is_static_linking_mode
|
bool;
ค่าเริ่มต้นคือ True ไม่ได้ใช้งาน |
create_linker_input
LinkerInput cc_common.create_linker_input(owner, libraries=None, user_link_flags=None, additional_inputs=None)
LinkerInput
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
owner
|
ป้ายกำกับ
ต้องระบุ ป้ายกำกับของเป้าหมายที่สร้างไฟล์ทั้งหมดที่ใช้ในอินพุตนี้ |
libraries
|
None ; หรือ depset;
ค่าเริ่มต้นคือ None รายชื่อ LibraryToLink
|
user_link_flags
|
None ; หรือ depset ของ สตริง หรือลำดับของสตริง
ค่าเริ่มต้นคือ None มีการส่งการแจ้งลิงก์ของผู้ใช้เป็นสตริง ยอมรับ [String], [[String]] หรือ depset(String) เราไม่แนะนำวิธีนี้เนื่องจากจะเก็บไว้เพื่อจุดประสงค์ด้านความเข้ากันได้เท่านั้น เดปเซ็ตจะถูกปรับให้แบน หากคุณต้องการเผยแพร่ user_link_flags ผ่าน depsets() ที่ไม่แยกเป็นหลายรายการ ให้ใส่ LinkerInput ไว้ใน LinkerInput เพื่อไม่ให้แบนราบจนครบ |
additional_inputs
|
None ; หรือ depset;
ค่าเริ่มต้นคือ None หากต้องการข้อมูลเพิ่มเติมเกี่ยวกับการดําเนินการลิงก์ เช่น การลิงก์สคริปต์ |
create_linking_context
LinkingContext cc_common.create_linking_context(linker_inputs=None, libraries_to_link=None, user_link_flags=None, additional_inputs=None)
LinkingContext
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
linker_inputs
|
None ; หรือ depset;
ค่าเริ่มต้นคือ None Depset ของ LinkerInput
|
libraries_to_link
|
None ; หรือ sequence
ค่าเริ่มต้นคือ None เลิกใช้งาน พารามิเตอร์นี้เลิกใช้งานแล้วและจะนำออกเร็วๆ นี้ โปรดอย่าพึ่งพา ถูกปิดใช้ด้วย --incompatible_require_linker_input_cc_api ใช้ธงนี้เพื่อยืนยันว่าโค้ดของคุณเข้ากันได้กับการนำออกในเร็วๆ นี้ รายชื่อของ LibraryToLink
|
user_link_flags
|
None ; หรือ sequence
ค่าเริ่มต้นคือ None เลิกใช้งาน พารามิเตอร์นี้เลิกใช้งานแล้วและจะนำออกเร็วๆ นี้ โปรดอย่าพึ่งพา ถูกปิดใช้ด้วย --incompatible_require_linker_input_cc_api ใช้ธงนี้เพื่อยืนยันว่าโค้ดของคุณเข้ากันได้กับการนำออกในเร็วๆ นี้ รายการการแจ้งลิงก์ของผู้ใช้ที่ส่งผ่านเป็นสตริง |
additional_inputs
|
None ; หรือ sequence
ค่าเริ่มต้นคือ None เลิกใช้งาน พารามิเตอร์นี้เลิกใช้งานแล้วและจะนำออกเร็วๆ นี้ โปรดอย่าพึ่งพา ถูกปิดใช้ด้วย --incompatible_require_linker_input_cc_api ใช้ธงนี้เพื่อยืนยันว่าโค้ดของคุณเข้ากันได้กับการนำออกในเร็วๆ นี้ สำหรับข้อมูลเพิ่มเติมเกี่ยวกับการดำเนินการลิงก์ เช่น การลิงก์สคริปต์ |
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)
CcLinkingContext
, CcLinkingOutputs
)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
actions
|
actions;
ต้องระบุactions ออบเจ็กต์
|
name
|
string;
ต้องระบุ ซึ่งจะใช้ในการตั้งชื่ออาร์ติแฟกต์เอาต์พุตของการดำเนินการที่สร้างโดยเมธอดนี้ |
feature_configuration
|
FeatureConfiguration
ต้องระบุfeature_configuration ที่จะค้นหา
|
cc_toolchain
|
ข้อมูล
ต้องระบุ ผู้ให้บริการ CcToolchainInfo ที่จะใช้
|
language
|
string;
ค่าเริ่มต้นคือ 'c++' ตอนนี้รองรับเฉพาะ C++ เท่านั้น อย่าใช้พารามิเตอร์นี้ |
disallow_static_libraries
|
bool;
ค่าเริ่มต้นคือ False ควรสร้างไลบรารีแบบคงที่หรือไม่ |
disallow_dynamic_library
|
bool;
ค่าเริ่มต้นคือ False ควรสร้างไลบรารีแบบไดนามิกไหม |
compilation_outputs
|
CcCompilationOutputs;
ต้องระบุ เอาต์พุตการคอมไพล์ที่มีไฟล์ออบเจ็กต์ที่จะลิงก์ |
linking_contexts
|
sequence;
ค่าเริ่มต้นคือ [] ไลบรารีจากทรัพยากร Dependency ไลบรารีเหล่านี้จะเชื่อมโยงกับอาร์ติแฟกต์เอาต์พุตของการเรียก link() ไม่ว่าจะเป็นไบนารีหรือไลบรารี |
user_link_flags
|
sequence;
ค่าเริ่มต้นคือ [] รายการตัวเลือกการลิงก์เพิ่มเติม |
alwayslink
|
bool;
ค่าเริ่มต้นคือ False ควรลิงก์ไลบรารีนี้ตลอดเวลาหรือไม่ |
additional_inputs
|
sequence;
ค่าเริ่มต้นคือ [] หากต้องการข้อมูลเพิ่มเติมเกี่ยวกับการดําเนินการลิงก์ เช่น การลิงก์สคริปต์ |
variables_extension
|
dict;
ค่าเริ่มต้นคือ unbound ตัวแปรเพิ่มเติมที่จะส่งผ่านไปยังการกำหนดค่า Toolchain เมื่อสร้างบรรทัดคำสั่งของลิงก์ |
create_lto_compilation_context
LtoCompilationContext cc_common.create_lto_compilation_context(objects={})
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
objects
|
dict;
ค่าเริ่มต้นคือ {} การแมปออบเจ็กต์แบบเต็มกับออบเจ็กต์ดัชนี |
do_not_use_tools_cpp_compiler_present
None
cc_common.do_not_use_tools_cpp_compiler_present
get_environment_variables
dict cc_common.get_environment_variables(feature_configuration, action_name, variables)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
feature_configuration
|
FeatureConfiguration
ต้องระบุ การกำหนดค่าฟีเจอร์ที่จะค้นหา |
action_name
|
string;
ต้องระบุ ชื่อของการดำเนินการ ต้องเป็นหนึ่งในชื่อใน @bazel_tools//tools/build_defs/cc:action_names.bzl (https://github.com/bazelbuild/bazel/blob/master/tools/build_defs/cc/action_names.bzl) |
variables
|
ตัวแปร;
ต้องระบุ สร้างตัวแปรที่จะใช้สำหรับการขยายเทมเพลต |
get_execution_requirements
sequence cc_common.get_execution_requirements(feature_configuration, action_name)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
feature_configuration
|
FeatureConfiguration
ต้องระบุ การกำหนดค่าฟีเจอร์ที่จะค้นหา |
action_name
|
string;
ต้องระบุ ชื่อของการดำเนินการ ต้องเป็นหนึ่งในชื่อใน @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)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
feature_configuration
|
FeatureConfiguration
ต้องระบุ การกำหนดค่าฟีเจอร์ที่จะค้นหา |
action_name
|
string;
ต้องระบุ ชื่อของการดำเนินการ ต้องเป็นหนึ่งในชื่อใน @bazel_tools//tools/build_defs/cc:action_names.bzl (https://github.com/bazelbuild/bazel/blob/master/tools/build_defs/cc/action_names.bzl) |
variables
|
ตัวแปร;
ต้องระบุ สร้างตัวแปรที่จะใช้สำหรับการขยายเทมเพลต |
get_tool_for_action
string cc_common.get_tool_for_action(feature_configuration, action_name)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
feature_configuration
|
FeatureConfiguration
ต้องระบุ การกำหนดค่าฟีเจอร์ที่จะค้นหา |
action_name
|
string;
ต้องระบุ ชื่อของการดำเนินการ ต้องเป็นหนึ่งในชื่อใน @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)
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
feature_configuration
|
FeatureConfiguration
ต้องระบุ การกำหนดค่าฟีเจอร์ที่จะค้นหา |
feature_name
|
string;
ต้องระบุ ชื่อฟีเจอร์ |
ลิงก์
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={})
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
actions
|
actions;
ต้องระบุactions ออบเจ็กต์
|
name
|
string;
ต้องระบุ ซึ่งจะใช้ในการตั้งชื่ออาร์ติแฟกต์เอาต์พุตของการดำเนินการที่สร้างโดยเมธอดนี้ |
feature_configuration
|
FeatureConfiguration
ต้องระบุfeature_configuration ที่จะค้นหา
|
cc_toolchain
|
ข้อมูล
ต้องระบุ ผู้ให้บริการ CcToolchainInfo ที่จะใช้
|
language
|
string;
ค่าเริ่มต้นคือ 'c++' ตอนนี้รองรับเฉพาะ C++ เท่านั้น อย่าใช้พารามิเตอร์นี้ |
output_type
|
string;
ค่าเริ่มต้นคือ 'executable' สามารถเป็นได้ทั้ง "ปฏิบัติการ" หรือ "dynamic_library" |
link_deps_statically
|
bool;
ค่าเริ่มต้นคือ True "จริง" เพื่อลิงก์การอ้างอิงแบบคงที่ "เท็จ" แบบไดนามิก |
compilation_outputs
|
CcCompilationOutputs; หรือ None ;
ค่าเริ่มต้นคือ None เอาต์พุตการคอมไพล์ที่มีไฟล์ออบเจ็กต์ที่จะลิงก์ |
linking_contexts
|
sequence;
ค่าเริ่มต้นคือ [] การลิงก์บริบทจากทรัพยากร Dependency เพื่อลิงก์กับบริบทการลิงก์ที่สร้างโดยกฎนี้ |
user_link_flags
|
sequence;
ค่าเริ่มต้นคือ [] รายการตัวเลือกตัวลิงก์เพิ่มเติม |
stamp
|
int;
ค่าเริ่มต้นคือ 0 ระบุว่าจะรวมข้อมูลบิลด์ในไฟล์สั่งการที่ลิงก์หรือไม่ หากเอาต์พุต_type เป็น "ปฏิบัติการ" หากเป็น 1 ระบบจะรวมข้อมูลบิลด์เสมอ หาก 0 (ระบบจะยกเว้นข้อมูลบิลด์เริ่มต้นเสมอ หาก -1 จะใช้ลักษณะการทำงานเริ่มต้น ซึ่งอาจถูกลบล้างโดยแฟล็ก --[no]stamp ซึ่งควรไม่ได้ตั้งค่า (หรือตั้งค่าเป็น 0) เมื่อสร้างเอาต์พุตที่เรียกใช้ได้สำหรับกฎการทดสอบ |
additional_inputs
|
sequence; หรือ depset
ค่าเริ่มต้นคือ [] หากต้องการข้อมูลเพิ่มเติมเกี่ยวกับการดําเนินการลิงก์ เช่น การลิงก์สคริปต์ |
additional_outputs
|
sequence;
ค่าเริ่มต้นคือ [] สําหรับผลลัพธ์เพิ่มเติมสําหรับการดําเนินการลิงก์ เช่น ไฟล์แมป |
variables_extension
|
dict;
ค่าเริ่มต้นคือ {} ตัวแปรเพิ่มเติมที่จะส่งผ่านไปยังการกำหนดค่า Toolchain เมื่อสร้างบรรทัดคำสั่งของลิงก์ |
merge_compilation_contexts
CompilationContext cc_common.merge_compilation_contexts(compilation_contexts=[])
CompilationContexts
หลายรายการเป็นรายการเดียว
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
compilation_contexts
|
sequence;
ค่าเริ่มต้นคือ [] รายการ CompilationContexts ที่จะรวม ส่วนหัวของบริบทแต่ละรายการจะส่งออกโดยช่องโดยตรงในผู้ให้บริการที่แสดงผล
|
merge_compilation_outputs
CcCompilationOutputs cc_common.merge_compilation_outputs(compilation_outputs=[])
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
compilation_outputs
|
sequence;
ค่าเริ่มต้นคือ [] |