Fungsi bagi Starlark untuk mengakses internal dari implementasi aturan apple.
Anggota
- apple_host_system_env
- apple_toolchain
- AppleDebugOutputs
- AppleDynamicFramework
- AppleExecutableBinary
- dotted_version
- link_multi_arch_binary
- link_multi_arch_static_library
- 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)Menampilkan dict variabel lingkungan yang harus ditetapkan untuk tindakan yang perlu menjalankan alat build di sistem host Apple, seperti versi Xcode yang harus digunakan. Kunci adalah nama variabel dan nilainya adalah nilai yang sesuai.
Parameter
Parameter | Deskripsi |
---|---|
xcode_config
|
wajib Penyedia yang berisi informasi tentang konfigurasi xcode. |
apple_toolchain
apple_toolchain apple_common.apple_toolchain()Utilitas untuk me-resolve item dari toolchain Apple.
AppleDebugOutputs
Provider apple_common.AppleDebugOutputsKonstruktor/kunci untuk penyedia
AppleDebugOutputs
.Jika target menyebarkan penyedia AppleDebugOutputs
, gunakan ini sebagai kunci untuk mengambilnya. Contoh:
dep = ctx.attr.deps[0] p = dep[apple_common.AppleDebugOutputs]
AppleDynamicFramework
Provider apple_common.AppleDynamicFrameworkKonstruktor/kunci untuk penyedia
AppleDynamicFramework
.Jika target menyebarkan penyedia AppleDynamicFramework
, gunakan ini sebagai kunci yang akan digunakan untuk mengambilnya. Contoh:
dep = ctx.attr.deps[0] p = dep[apple_common.AppleDynamicFramework]
AppleExecutableBinary
Provider apple_common.AppleExecutableBinaryKonstruktor/kunci untuk penyedia
AppleExecutableBinary
.Jika target menyebarkan penyedia AppleExecutableBinary
, gunakan ini sebagai kunci untuk mengambilnya. Contoh:
dep = ctx.attr.deps[0] p = dep[apple_common.AppleExecutableBinary]
dotted_version
DottedVersion apple_common.dotted_version(version)Membuat instance DottedVersion baru.
Parameter
Parameter | Deskripsi |
---|---|
version
|
wajib Representasi string dari DottedVersion. |
link_multi_arch_binary
struct apple_common.link_multi_arch_binary(ctx, avoid_deps=None, extra_linkopts=[], extra_link_inputs=[], extra_requested_features=[], extra_disabled_features=[], stamp=-1)Menautkan biner (yang berpotensi multi-arsitektur) yang menargetkan platform Apple. Metode ini terdiri dari sebagian besar logika aturan
apple_binary
Starlark di domain rules_apple dan ada untuk membantu migrasi logika penautannya ke Starlark di rules_apple.
API ini sangat eksperimental dan dapat berubah sewaktu-waktu. Jangan bergantung pada stabilitas fungsi ini untuk saat ini.
Parameter
Parameter | Deskripsi |
---|---|
ctx
|
required Konteks aturan Starlark. |
avoid_deps
|
Urutan Target; atau None ;
default-nya adalah None Daftar Target yang ada dalam grafik dependensi biner, tetapi library-nya tidak boleh ditautkan ke biner. Hal ini berlaku untuk dependensi yang akan ditemukan saat runtime dalam image lain, seperti loader paket atau library/framework dinamis yang akan dimuat oleh biner ini.
|
extra_linkopts
|
urutan string;
default adalah [] Linkopts tambahan yang akan diteruskan ke tindakan penaut. |
extra_link_inputs
|
urutan File;
default adalah [] File tambahan yang akan diteruskan ke tindakan penaut. |
extra_requested_features
|
urutan string;
default adalah [] Fitur tambahan yang diminta untuk diteruskan ke tindakan penaut. |
extra_disabled_features
|
urutan string;
default adalah [] Fitur tambahan yang dinonaktifkan untuk diteruskan ke tindakan penaut. |
stamp
|
defaultnya adalah -1 Apakah akan menyertakan informasi build dalam biner tertaut. Jika 1, informasi build selalu disertakan. Jika 0, informasi build selalu dikecualikan. Jika -1 (default), perilaku ditentukan oleh flag --[no]stamp. Nilai ini harus ditetapkan ke 0 saat membuat output yang dapat dieksekusi untuk aturan pengujian. |
link_multi_arch_static_library
struct apple_common.link_multi_arch_static_library(ctx)Menautkan library statis (berpotensi multi-arsitektur) yang menargetkan platform Apple. Metode ini terdiri dari bagian dari logika aturan
apple_static_library
Starlark, dalam domain rules_apple dan ada untuk membantu migrasi logika penautannya ke Starlark di rules_apple.
API ini sangat eksperimental dan dapat berubah sewaktu-waktu. Jangan bergantung pada stabilitas fungsi ini untuk saat ini.
Parameter
Parameter | Deskripsi |
---|---|
ctx
|
diperlukan Konteks aturan Starlark. |
new_dynamic_framework_provider
AppleDynamicFramework apple_common.new_dynamic_framework_provider(binary=None, cc_info=None, objc=None, framework_dirs=None, framework_files=None)Membuat instance penyedia AppleDynamicFramework baru.
Parameter
Parameter | Deskripsi |
---|---|
binary
|
File; atau None ;
default-nya adalah None Artefak biner dylib dari framework dinamis. |
cc_info
|
default adalah None CcInfo yang berisi informasi tentang dependensi transitif yang ditautkan ke biner. |
objc
|
defaultnya adalah None ObjcProvider yang berisi informasi tentang dependensi transitif yang ditautkan ke biner. |
framework_dirs
|
depset dari string; atau None ;
default adalah None Nama jalur framework yang digunakan sebagai input link untuk menautkan ke framework dinamis. |
framework_files
|
depset dari File; atau None ;
default adalah None Kumpulan lengkap artefak yang harus disertakan sebagai input untuk ditautkan ke framework dinamis |
new_executable_binary_provider
AppleExecutableBinary apple_common.new_executable_binary_provider(binary=None, cc_info=None, objc=None)Membuat instance penyedia AppleExecutableBinaryInfo baru.
Parameter
Parameter | Deskripsi |
---|---|
binary
|
File; atau None ;
defaultnya adalah None Artefak biner dari file yang dapat dieksekusi. |
cc_info
|
default adalah None CcInfo yang berisi informasi tentang dependensi transitif yang ditautkan ke biner. |
objc
|
defaultnya adalah None ObjcProvider yang berisi informasi tentang dependensi transitif yang ditautkan ke dalam biner. |
new_objc_provider
ObjcProvider apple_common.new_objc_provider(**kwargs)Membuat instance ObjcProvider baru.
Parameter
Parameter | Deskripsi |
---|---|
kwargs
|
defaultnya adalah {} Kamus argumen. |
Objc
Provider apple_common.ObjcKonstruktor/kunci untuk penyedia
Objc
.Jika target menyebarkan penyedia Objc
, gunakan ini sebagai kunci yang akan digunakan untuk mengambilnya. Contoh:
dep = ctx.attr.deps[0] p = dep[apple_common.Objc]
platform
struct apple_common.platformStruktur mirip enum yang berisi kolom berikut yang sesuai dengan platform Apple:
ios_device
ios_simulator
macos
tvos_device
tvos_simulator
visionos_device
visionos_simulator
watchos_device
watchos_simulator
Nilai ini dapat diteruskan ke metode yang mengharapkan platform, seperti XcodeVersionConfig.sdk_version_for_platform.
platform_type
struct apple_common.platform_typeStruktur mirip enum yang berisi kolom berikut yang sesuai dengan jenis platform Apple:
ios
macos
tvos
visionos
watchos
Nilai ini dapat diteruskan ke metode yang mengharapkan jenis platform, seperti metode multi_arch_platform fragmen konfigurasi 'apple'.
Contoh:
ctx.fragments.apple.multi_arch_platform(apple_common.platform_type.ios)
target_apple_env
dict apple_common.target_apple_env(xcode_config, platform)Menampilkan
dict
variabel lingkungan yang harus ditetapkan untuk tindakan yang mem-build target jenis platform Apple tertentu. Misalnya, kamus ini berisi variabel yang menunjukkan nama platform dan versi SDK yang akan digunakan untuk membangun. Kunci adalah nama variabel dan nilainya adalah nilai yang sesuai.
Parameter
Parameter | Deskripsi |
---|---|
xcode_config
|
required Penyedia yang berisi informasi tentang konfigurasi xcode. |
platform
|
required Platform Apple. |
XcodeProperties
Provider apple_common.XcodePropertiesKonstruktor/kunci untuk penyedia
XcodeVersionProperties
.Jika target menyebarkan penyedia XcodeVersionProperties
, gunakan ini sebagai kunci untuk mengambilnya. Contoh:
dep = ctx.attr.deps[0] p = dep[apple_common.XcodeVersionProperties]
XcodeVersionConfig
Provider apple_common.XcodeVersionConfigKonstruktor/kunci untuk penyedia
XcodeVersionConfig
.