สมาชิก
- apple_host_system_env
- apple_toolchain
- AppleDebugOutputs
- AppleDynamicFramework
- AppleExecutableBinary
- dotted_version
- link_multi_arch_binary
- link_multi_arch_static_library
- multi_arch_split
- new_dynamic_framework_provider
- new_executable_binary_provider
- new_objc_provider
- Objc
- platform
- platform_type
- target_apple_env
- XcodeProperties
- XcodeVersionConfig
apple_host_system_env
dict apple_common.apple_host_system_env(xcode_config)แสดงผล dict ของตัวแปรสภาพแวดล้อมที่ควรตั้งค่าสําหรับการดําเนินการที่จําเป็นต้องใช้เครื่องมือสร้างในระบบโฮสต์ของ Apple เช่น เวอร์ชัน Xcode ที่ควรใช้ คีย์คือชื่อตัวแปรและค่าคือค่าที่สอดคล้องกัน
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
xcode_config
|
ต้องระบุ ผู้ให้บริการที่มีข้อมูลเกี่ยวกับการกําหนดค่า xcode |
apple_toolchain
apple_toolchain apple_common.apple_toolchain()ยูทิลิตีสำหรับการแก้ไขรายการจากเครื่องมือต่างๆ ของ Apple
AppleDebugOutputs
Provider apple_common.AppleDebugOutputsตัวสร้าง/คีย์สําหรับผู้ให้บริการ
AppleDebugOutputs
หากเป้าหมายเผยแพร่ผู้ให้บริการ AppleDebugOutputs
ให้ใช้ข้อมูลนี้เป็นตัวคีย์ในการดึงข้อมูล ตัวอย่าง:
dep = ctx.attr.deps[0] p = dep[apple_common.AppleDebugOutputs]
AppleDynamicFramework
Provider apple_common.AppleDynamicFrameworkตัวสร้าง/คีย์สำหรับผู้ให้บริการ
AppleDynamicFramework
หากเป้าหมายเผยแพร่ผู้ให้บริการ AppleDynamicFramework
ให้ใช้ข้อมูลนี้เป็นตัวคีย์ในการดึงข้อมูล ตัวอย่าง:
dep = ctx.attr.deps[0] p = dep[apple_common.AppleDynamicFramework]
AppleExecutableBinary
Provider apple_common.AppleExecutableBinaryตัวสร้าง/คีย์สําหรับผู้ให้บริการ
AppleExecutableBinary
หากเป้าหมายเผยแพร่ผู้ให้บริการ AppleExecutableBinary
ให้ใช้ข้อมูลนี้เป็นตัวคีย์ในการดึงข้อมูล ตัวอย่าง:
dep = ctx.attr.deps[0] p = dep[apple_common.AppleExecutableBinary]
dotted_version
DottedVersion apple_common.dotted_version(version)สร้างอินสแตนซ์ DottedVersion ใหม่
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
version
|
ต้องระบุ การแสดงสตริงของ DottedVersion |
link_multi_arch_binary
struct apple_common.link_multi_arch_binary(ctx, avoid_deps=None, extra_linkopts=[], extra_link_inputs=[], stamp=-1)ลิงก์ไบนารี (อาจมีหลายสถาปัตยกรรม) ที่กําหนดเป้าหมายแพลตฟอร์ม Apple เมธอดนี้ประกอบด้วยตรรกะส่วนใหญ่ของกฎ
apple_binary
ของ Starlark ในโดเมน rules_apple และมีหน้าที่ช่วยในการย้ายข้อมูลตรรกะการลิงก์ไปยัง Starlark ใน rules_apple
API นี้อยู่ในขั้นทดลองขั้นสูงและอาจมีการเปลี่ยนแปลงได้ทุกเมื่อ โปรดอย่าพึ่งพาความเสถียรของฟังก์ชันนี้ในขณะนี้
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
ctx
|
ต้องระบุ บริบทของกฎ Starlark |
avoid_deps
|
sequence of Targets; or None ;
ค่าเริ่มต้น = ไม่มีรายการ Target ที่อยู่ในกราฟทรัพยากร Dependency ของไบนารี แต่ไม่ควรลิงก์ไลบรารีเข้ากับไบนารี กรณีนี้ใช้กับ Dependency ที่พบในรันไทม์ในภาพอื่น เช่น ตัวโหลดแพ็กเกจหรือไลบรารี/เฟรมเวิร์กแบบไดนามิกที่ไบนารีนี้จะโหลด
|
extra_linkopts
|
sequence of strings ;
default = []linkopts เพิ่มเติมที่จะส่งไปยังการดำเนินการ Linker |
extra_link_inputs
|
sequence of Files ;
default = []ไฟล์เพิ่มเติมที่จะส่งไปให้การดำเนินการ Linker |
stamp
|
default = -1 Whether to include build information in the linked binary. หากเป็น 1 ระบบจะรวมข้อมูลบิลด์เสมอ หากเป็น 0 ระบบจะยกเว้นข้อมูลบิลด์เสมอ หากเป็น -1 (ค่าเริ่มต้น) ลักษณะการทำงานจะกำหนดโดยแฟล็ก --[no]stamp ควรตั้งค่านี้เป็น 0 เมื่อสร้างเอาต์พุตที่เรียกใช้งานได้สําหรับกฎทดสอบ |
link_multi_arch_static_library
struct apple_common.link_multi_arch_static_library(ctx)ลิงก์ไลบรารีแบบคงที่ (อาจมีหลายสถาปัตยกรรม) ที่กําหนดเป้าหมายแพลตฟอร์ม Apple วิธีการนี้เป็นส่วนหนึ่งของตรรกะกฎ
apple_static_library
ของ Starlark ในโดเมน rules_apple และมีหน้าที่ช่วยในการย้ายข้อมูลตรรกะการลิงก์ไปยัง Starlark ใน rules_apple
API นี้อยู่ในขั้นทดลองขั้นสูงและอาจมีการเปลี่ยนแปลงได้ทุกเมื่อ อย่าพึ่งพาความเสถียรของฟังก์ชันนี้ในตอนนี้
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
ctx
|
ต้องระบุ บริบทของกฎ Starlark |
multi_arch_split
SplitTransitionProviderApi apple_common.multi_arch_splitการเปลี่ยนการกำหนดค่าแอตทริบิวต์กฎเพื่อสร้างข้อกำหนดในแพลตฟอร์ม Apple อย่างน้อย 1 แพลตฟอร์ม
การใช้การเปลี่ยนนี้กำหนดให้ต้องกำหนดแอตทริบิวต์สตริง "platform_type" และ "minimum_os_version" ในกฎ
ค่าของแอตทริบิวต์ platform_type จะกําหนดสถาปัตยกรรมเป้าหมายที่จะสร้างการพึ่งพาตามการเปลี่ยนการกําหนดค่านี้
ตัวเลือกมีดังนี้
ios
: สถาปัตยกรรมที่รวบรวมจาก--ios_multi_cpus
macos
: สถาปัตยกรรมที่รวบรวมจาก--macos_cpus
tvos
: สถาปัตยกรรมที่รวบรวมจาก--tvos_cpus
watchos
: สถาปัตยกรรมที่รวบรวมจาก--watchos_cpus
min_os_version ควรเป็นสตริงเวอร์ชันที่มีจุด เช่น "7.3" และใช้เพื่อตั้งค่าระบบปฏิบัติการขั้นต่ำในการกำหนดค่าที่คล้ายคลึงกันตามประเภทแพลตฟอร์ม เช่น การระบุ platform_type "ios" และ minimum_os_version "8.0" จะช่วยให้มั่นใจได้ว่าระบบจะสร้างทรัพยากร Dependency ด้วย iOS เวอร์ชันต่ำสุด "8.0"
new_dynamic_framework_provider
AppleDynamicFramework apple_common.new_dynamic_framework_provider(binary=None, cc_info=None, objc, framework_dirs=None, framework_files=None)สร้างอินสแตนซ์ผู้ให้บริการ AppleDynamicFramework ใหม่
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
binary
|
File; or None ;
default = Noneออบเจ็กต์โค้ดไบนารี dylib ของเฟรมเวิร์กแบบไดนามิก |
cc_info
|
default = None CcInfo ซึ่งมีข้อมูลเกี่ยวกับ transitive dependencies ที่ลิงก์กับไบนารี |
objc
|
ต้องระบุ ObjcProvider ที่มีข้อมูลเกี่ยวกับ transitive dependencies ที่ลิงก์กับไบนารี |
framework_dirs
|
depset of strings; or None ;
default = Noneชื่อเส้นทางเฟรมเวิร์กที่ใช้เป็นอินพุตลิงก์เพื่อลิงก์กับเฟรมเวิร์กแบบไดนามิก |
framework_files
|
depset of Files; or None ;
ค่าเริ่มต้น = ไม่มีอาร์ติแฟกต์ชุดเต็มที่ควรรวมไว้เป็นอินพุตเพื่อลิงก์กับเฟรมเวิร์กแบบไดนามิก |
new_executable_binary_provider
AppleExecutableBinary apple_common.new_executable_binary_provider(binary=None, cc_info=None, objc)สร้างอินสแตนซ์ผู้ให้บริการ AppleExecutableBinaryInfo ใหม่
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
binary
|
File; or None ;
default = Noneออบเจ็กต์ไบนารีของไฟล์ปฏิบัติการ |
cc_info
|
ค่าเริ่มต้น = ไม่มี CcInfo ที่มีข้อมูลเกี่ยวกับทรัพยากร Dependency แบบทรานซิทีฟที่ลิงก์กับไบนารี |
objc
|
ต้องระบุ ObjcProvider ที่มีข้อมูลเกี่ยวกับ transitive dependencies ที่ลิงก์กับไบนารี |
new_objc_provider
ObjcProvider apple_common.new_objc_provider(**kwargs)สร้างอินสแตนซ์ ObjcProvider ใหม่
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
kwargs
|
default = {} พจนานุกรมของอาร์กิวเมนต์ |
Objc
Provider apple_common.Objcตัวสร้าง/คีย์สําหรับผู้ให้บริการ
Objc
หากเป้าหมายเผยแพร่ผู้ให้บริการ Objc
ให้ใช้ข้อมูลนี้เป็นตัวคีย์ในการดึงข้อมูล ตัวอย่าง:
dep = ctx.attr.deps[0] p = dep[apple_common.Objc]
platform
struct apple_common.platformโครงสร้างที่คล้ายกับ enum ซึ่งมีฟิลด์ต่อไปนี้ซึ่งสอดคล้องกับแพลตฟอร์มของ Apple
ios_device
ios_simulator
macos
tvos_device
tvos_simulator
watchos_device
watchos_simulator
ค่าเหล่านี้สามารถส่งไปยังเมธอดที่คาดหวังแพลตฟอร์ม เช่น XcodeVersionConfig.sdk_version_for_platform
platform_type
struct apple_common.platform_typeโครงสร้างคล้าย Enum ที่มีช่องต่อไปนี้ซึ่งสอดคล้องกับประเภทแพลตฟอร์มของ Apple
ios
macos
tvos
watchos
ค่าเหล่านี้สามารถส่งไปยังเมธอดที่คาดหวังประเภทแพลตฟอร์ม เช่น เมธอด multi_arch_platform ของข้อมูลโค้ดการกําหนดค่า "apple"
ตัวอย่าง
ctx.fragments.apple.multi_arch_platform(apple_common.platform_type.ios)
target_apple_env
dict apple_common.target_apple_env(xcode_config, platform)แสดงผล
dict
ของตัวแปรสภาพแวดล้อมที่ควรตั้งค่าสําหรับการดําเนินการที่สร้างเป้าหมายของประเภทแพลตฟอร์ม Apple ที่ระบุ เช่น พจนานุกรมนี้มีตัวแปรที่ระบุชื่อแพลตฟอร์มและเวอร์ชัน SDK ที่จะใช้สร้าง คีย์คือชื่อตัวแปรและค่าคือค่าที่สอดคล้องกัน
พารามิเตอร์
พารามิเตอร์ | คำอธิบาย |
---|---|
xcode_config
|
ต้องระบุ ผู้ให้บริการที่มีข้อมูลเกี่ยวกับการกําหนดค่า xcode |
platform
|
required The apple platform. |
XcodeProperties
Provider apple_common.XcodePropertiesตัวสร้าง/คีย์สำหรับผู้ให้บริการ
XcodeVersionProperties
หากเป้าหมายเผยแพร่ผู้ให้บริการ XcodeVersionProperties
ให้ใช้ข้อมูลนี้เป็นตัวคีย์ในการดึงข้อมูล ตัวอย่าง:
dep = ctx.attr.deps[0] p = dep[apple_common.XcodeVersionProperties]
XcodeVersionConfig
Provider apple_common.XcodeVersionConfigตัวสร้าง/คีย์สําหรับผู้ให้บริการ
XcodeVersionConfig