Halaman ini menjelaskan cara berintegrasi dengan aturan C++ di berbagai level.
Mengakses toolchain C++
Anda harus menggunakan fungsi helper yang tersedia di
@rules_cc//cc:find_cc_toolchain.bzl
untuk bergantung pada toolchain CC dari aturan Starlark.
Untuk bergantung pada toolchain C++ dalam aturan Anda, tetapkan parameter toolchains ke use_cc_toolchain(). Kemudian, dalam penerapan aturan, gunakan
find_cpp_toolchain(ctx) untuk mendapatkan
CcToolchainInfo. Contoh lengkap yang berfungsi
dapat ditemukan di contoh rules_cc
examples.
Membuat command line dan variabel lingkungan menggunakan toolchain C++
Biasanya, Anda akan berintegrasi dengan toolchain C++ untuk memiliki flag command line yang sama seperti aturan C++, tetapi tanpa menggunakan tindakan C++ secara langsung. Hal ini karena saat menulis tindakan kita sendiri, tindakan tersebut harus berperilaku konsisten dengan toolchain C++ - misalnya, meneruskan flag command line C++ ke alat yang memanggil compiler C++ di balik layar.
Aturan C++ menggunakan cara khusus untuk membuat command line berdasarkan konfigurasi fitur. Untuk membuat command line, Anda memerlukan hal berikut:
featuresdanaction_configs- ini berasal dariCcToolchainConfigInfodan dienkapsulasi dalamCcToolchainInfoFeatureConfiguration- ditampilkan oleh cc_common.configure_features- variabel konfigurasi toolchain cc - ditampilkan oleh cc_common.create_compile_variables atau cc_common.create_link_variables.
Masih ada getter khusus alat, seperti
compiler_executable.
Sebaiknya gunakan get_tool_for_action daripada getter khusus alat, karena getter khusus alat pada akhirnya akan dihapus.
Contoh lengkap yang berfungsi dapat ditemukan di contoh rules_cc.
Menerapkan aturan Starlark yang bergantung pada aturan C++ dan/atau aturan C++ yang dapat bergantung pada
Sebagian besar aturan C++ menyediakan
CcInfo,
penyedia yang berisi CompilationContext
dan
LinkingContext.
Melalui aturan ini, Anda dapat mengakses informasi seperti semua header atau library transitif untuk ditautkan. Dari CcInfo dan dari CcToolchainInfo, aturan Starlark kustom harus dapat memperoleh semua informasi yang diperlukan.
Jika aturan Starlark kustom menyediakan CcInfo, aturan tersebut adalah sinyal ke aturan C++ bahwa aturan tersebut juga dapat bergantung padanya. Namun, berhati-hatilah - jika Anda hanya perlu menyebarkan CcInfo melalui grafik ke aturan biner yang kemudian menggunakannya, gabungkan CcInfo dalam penyedia yang berbeda. Misalnya, jika aturan java_library ingin
menyebarkan dependensi native hingga java_binary, aturan tersebut tidak boleh menyediakan
CcInfo secara langsung (cc_binary yang bergantung pada java_library tidak masuk akal),
aturan tersebut harus menggabungkannya, misalnya, JavaCcInfo.
Contoh lengkap yang berfungsi dapat ditemukan di contoh rules_cc.
Menggunakan kembali logika dan tindakan aturan C++
Belum stabil; Bagian ini akan diperbarui setelah API stabil. Ikuti #4570 untuk mendapatkan informasi terbaru.