सामान्य सिद्धांत के तौर पर, rust_* मॉड्यूल की परिभाषाएं, cc_* इस्तेमाल और उम्मीदों के मुताबिक होती हैं. यहां Rust बाइनरी के लिए मॉड्यूल की परिभाषा का उदाहरण दिया गया है:
rust_binary {
name: "hello_rust",
crate_name: "hello_rust",
srcs: ["src/hello_rust.rs"],
host_supported: true,
}
इस पेज पर, rust_* मॉड्यूल की सबसे सामान्य प्रॉपर्टी के बारे में बताया गया है. मॉड्यूल के टाइप और मॉड्यूल की परिभाषाओं के उदाहरणों के बारे में ज़्यादा जानने के लिए, बाइनरी मॉड्यूल, लाइब्रेरी मॉड्यूल या टेस्ट मॉड्यूल देखें.
बेसिक मॉड्यूल टाइप
| टाइप | परिभाषा | अधिक जानकारी के लिए |
|---|---|---|
rust_binary | Rust बाइनरी | बाइनरी मॉड्यूल page |
rust_library | यह Rust लाइब्रेरी बनाता है. साथ ही, rlib और dylib, दोनों वैरिएंट उपलब्ध कराता है. |
rust_library,
लाइब्रेरी मॉड्यूल पेज. |
rust_ffi | यह cc मॉड्यूल के लिए, इस्तेमाल की जा सकने वाली Rust C लाइब्रेरी बनाता है. साथ ही, स्टैटिक और शेयर किए गए दोनों वैरिएंट उपलब्ध कराता है. | rust_ffi,
लाइब्रेरी मॉड्यूल पेज |
rust_proc_macro | proc-macro Rust लाइब्रेरी बनाता है.
(ये कंपाइलर प्लगिन के जैसे होते हैं.) |
rust_proc_macro,
लाइब्रेरी मॉड्यूल पेज |
rust_test | यह स्टैंडर्ड Rust टेस्ट हार्नेस का इस्तेमाल करने वाला Rust टेस्ट बाइनरी बनाता है. | टेस्ट मॉड्यूल पेज |
rust_fuzz | यह libfuzzer का इस्तेमाल करके, Rust फ़ज़ बाइनरी बनाता है. |
rust_fuzz मॉड्यूल का उदाहरण |
rust_protobuf | सोर्स जनरेट करता है और Rust लाइब्रेरी बनाता है. यह लाइब्रेरी, किसी खास protobuf के लिए इंटरफ़ेस उपलब्ध कराती है. | Protobufs Modules और Source Generators पेज |
rust_bindgen | यह सोर्स जनरेट करता है और Rust लाइब्रेरी बनाता है. इस लाइब्रेरी में, C लाइब्रेरी के लिए Rust बाइंडिंग होती हैं. | Bindgen Bindings Modules और Source Generators पेज |
सामान्य तौर पर इस्तेमाल होने वाली ज़रूरी प्रॉपर्टी
ये प्रॉपर्टी, सभी Android Rust मॉड्यूल में एक जैसी होती हैं. अलग-अलग Rust मॉड्यूल से जुड़ी कोई भी अतिरिक्त (यूनीक) प्रॉपर्टी, उस मॉड्यूल के पेज पर दिखती है.
नाम
name आपके मॉड्यूल का नाम है. अन्य Soong मॉड्यूल की तरह, यह भी ज़्यादातर Android.bp मॉड्यूल टाइप में यूनीक होना चाहिए. डिफ़ॉल्ट रूप से, name का इस्तेमाल आउटपुट फ़ाइल के नाम के तौर पर किया जाता है. अगर आउटपुट फ़ाइल का नाम, मॉड्यूल के नाम से अलग होना चाहिए, तो इसे तय करने के लिए stem प्रॉपर्टी का इस्तेमाल करें.
स्टेम
stem (ज़रूरी नहीं) की मदद से, आउटपुट फ़ाइल के नाम को सीधे तौर पर कंट्रोल किया जा सकता है. इसमें फ़ाइल एक्सटेंशन और अन्य सफ़िक्स शामिल नहीं हैं. उदाहरण के लिए, rust_library_rlib
स्टेम वैल्यू libfoo वाली लाइब्रेरी से libfoo.rlib फ़ाइल जनरेट होती है. अगर आपने stem प्रॉपर्टी के लिए कोई वैल्यू नहीं दी है, तो आउटपुट फ़ाइल का नाम डिफ़ॉल्ट रूप से मॉड्यूल के नाम पर सेट हो जाता है.
अगर आपको मॉड्यूल का नाम, आउटपुट फ़ाइल के नाम के तौर पर सेट करने में समस्या आ रही है, तो stem फ़ंक्शन का इस्तेमाल करें. उदाहरण के लिए, log क्रेट के लिए rust_library का नाम liblog_rust है, क्योंकि liblog cc_library पहले से मौजूद है. इस मामले में, stem प्रॉपर्टी का इस्तेमाल करने से यह पक्का होता है कि आउटपुट फ़ाइल का नाम liblog_rust.* के बजाय liblog.* है.
srcs
srcs में एक सोर्स फ़ाइल होती है, जो आपके मॉड्यूल के एंट्री पॉइंट को दिखाती है. आम तौर पर, यह main.rs या lib.rs होती है. rustc, कंपाइल करने के लिए ज़रूरी अन्य सभी सोर्स फ़ाइलों को रिज़ॉल्व करने और खोजने का काम करता है. ये फ़ाइलें, जनरेट होने वाली deps फ़ाइल में शामिल होती हैं.
जब संभव हो, तो प्लैटफ़ॉर्म कोड के लिए इसका इस्तेमाल न करें. ज़्यादा जानकारी के लिए, सोर्स जनरेटर देखें.
crate_name
crate_name --crate_name फ़्लैग के ज़रिए, क्रेट के नाम का मेटाडेटा सेट करता है.rustc लाइब्रेरी बनाने वाले मॉड्यूल के लिए, यह ज़रूरी है कि यह सोर्स में इस्तेमाल किए गए, अनुमानित क्रेट के नाम से मेल खाए. उदाहरण के लिए, अगर सोर्स में मॉड्यूल libfoo_bar को extern crate foo_bar के तौर पर रेफ़रंस दिया गया है, तो यह ज़रूरी है कि crate_name: "foo_bar" हो.
यह प्रॉपर्टी, सभी rust_* मॉड्यूल के लिए सामान्य है. हालांकि, Rust लाइब्रेरी बनाने वाले मॉड्यूल के लिए, यह ज़रूरी है. जैसे, rust_library
rust_ffi, rust_bindgen, rust_protobuf, और rust_proc_macro. ये मॉड्यूल, crate_name और आउटपुट फ़ाइल के नाम के बीच के संबंध पर rustc की ज़रूरी शर्तें लागू करते हैं. ज़्यादा जानकारी के लिए, लाइब्रेरी मॉड्यूल सेक्शन देखें.
लिंट
rustc linter, सोर्स जनरेटर को छोड़कर सभी मॉड्यूल टाइप के लिए डिफ़ॉल्ट रूप से चलता है. कुछ लिंट सेट तय किए जाते हैं और इनका इस्तेमाल, मॉड्यूल सोर्स की पुष्टि करने के लिए किया जाता है. इस तरह के लिंट सेट के लिए, ये वैल्यू हो सकती हैं:
defaultमॉड्यूल की जगह के हिसाब से, डिफ़ॉल्ट रूप से सेट किए गए लिंटandroidसबसे सख्त लिंट सेट, जो सभी Android प्लैटफ़ॉर्म कोड पर लागू होता हैvendorवेंडर कोड पर लागू किए गए लिंट का एक आसान सेटnoneका इस्तेमाल करके, लिंट की सभी चेतावनियों और गड़बड़ियों को अनदेखा करें
clippy_lints
clippy linter को भी डिफ़ॉल्ट रूप से सभी मॉड्यूल टाइप के लिए चलाया जाता है. हालांकि, सोर्स जनरेटर के लिए इसे नहीं चलाया जाता. कुछ लिंट सेट तय किए गए हैं. इनका इस्तेमाल, मॉड्यूल सोर्स की पुष्टि करने के लिए किया जाता है. यहां कुछ संभावित वैल्यू दी गई हैं:
defaultमॉड्यूल की जगह के हिसाब से, डिफ़ॉल्ट रूप से सेट किए गए लिंटandroidसबसे सख्त लिंट सेट, जो सभी Android प्लैटफ़ॉर्म कोड पर लागू होता हैvendorवेंडर कोड पर लागू किए गए लिंट का एक आसान सेटnoneका इस्तेमाल करके, लिंट की सभी चेतावनियों और गड़बड़ियों को अनदेखा करें
वर्शन
edition इस कोड को कंपाइल करने के लिए, इस्तेमाल किए जाने वाले Rust वर्शन को तय करता है. यह C और C++ के std वर्शन जैसा ही है. मान्य वैल्यू 2015, 2018, और 2021 (डिफ़ॉल्ट) हैं.
फ़्लैग
flags में, फ़्लैग की स्ट्रिंग सूची होती है. इन्हें कंपाइल करने के दौरान rustc को पास किया जाता है.
ld_flags
ld-flags में, सोर्स को कंपाइल करते समय लिंकर को पास किए जाने वाले फ़्लैग की स्ट्रिंग सूची होती है. इन्हें -C linker-args rustc फ़्लैग से पास किया जाता है. clang का इस्तेमाल लिंकर के फ़्रंट-एंड के तौर पर किया जाता है. यह lld को लिंक करने के लिए शुरू करता है.
सुविधाएं
features, सुविधाओं की एक स्ट्रिंग सूची है. इन्हें कंपाइल करने के दौरान चालू करना ज़रूरी है.
इसे --cfg 'feature="foo"', rustc को पास करता है. ज़्यादातर सुविधाएं ऐड-ऑन होती हैं. इसलिए, कई मामलों में इसमें उन सभी सुविधाओं का पूरा सेट शामिल होता है जिनकी ज़रूरत सभी डिपेंडेंट मॉड्यूल को होती है. हालांकि, अगर कोई सुविधा किसी दूसरी सुविधा से अलग है, तो ऐसी बिल्ड फ़ाइलों में अतिरिक्त मॉड्यूल तय करें जिनमें एक-दूसरे से अलग सुविधाएं दी गई हैं.
cfgs
cfgs में, cfg फ़्लैग की स्ट्रिंग सूची होती है. इन्हें कंपाइल करने के दौरान चालू किया जाता है.
इसे --cfg foo और --cfg "fizz=buzz", rustc को पास करते हैं.
बिल्ड सिस्टम, कुछ खास स्थितियों में अपने-आप cfg फ़्लैग सेट करता है. इन स्थितियों के बारे में यहां बताया गया है:
डाइनैमिक लाइब्रेरी (डिलिब) के तौर पर बनाए गए मॉड्यूल में,
android_dylibcfg सेट होगा.जिन मॉड्यूल को वीएनडीके का इस्तेमाल करना है उनके लिए,
android_vndkcfg सेट किया जाएगा. यह C++ के लिए__ANDROID_VNDK__की परिभाषा के जैसा ही है.
स्ट्रिप
strip यह कंट्रोल करता है कि आउटपुट फ़ाइल को हटाया जाए या नहीं. अगर हटाया जाता है, तो कैसे हटाया जाए.
अगर इस नीति को सेट नहीं किया जाता है, तो डिवाइस मॉड्यूल डिफ़ॉल्ट रूप से मिनी डिबग जानकारी को छोड़कर बाकी सभी जानकारी हटा देते हैं.
होस्ट मॉड्यूल, डिफ़ॉल्ट रूप से किसी भी सिंबल को नहीं हटाते. मान्य वैल्यू में ये शामिल हैं: none, जिससे स्ट्रिपिंग बंद हो जाती है. साथ ही, all, जिससे मिनी डिबग जानकारी के साथ-साथ सब कुछ स्ट्रिप हो जाता है.
अन्य वैल्यू, Soong Modules Reference में देखी जा सकती हैं.
host_supported
डिवाइस मॉड्यूल के लिए, host_supported पैरामीटर यह बताता है कि मॉड्यूल को होस्ट वैरिएंट भी उपलब्ध कराना चाहिए या नहीं.
लाइब्रेरी डिपेंडेंसी तय करना
Rust मॉड्यूल, इन प्रॉपर्टी की मदद से CC और Rust लाइब्रेरी, दोनों पर निर्भर हो सकते हैं:
| प्रॉपर्टी का नाम | ब्यौरा |
|---|---|
rustlibs |
rust_library मॉड्यूल की सूची, जो डिपेंडेंसी भी हैं. डिपेंडेंसी का एलान करने के लिए, इसे अपने पसंदीदा तरीके के तौर पर इस्तेमाल करें. इससे बिल्ड सिस्टम को पसंदीदा लिंकेज चुनने की अनुमति मिलती है. (नीचे Rust लाइब्रेरी से लिंक करने के बारे में जानकारी देखें) |
rlibs |
rust_library के उन मॉड्यूल की सूची जिन्हें rlibs के तौर पर स्टैटिक रूप से लिंक किया जाना चाहिए. (इसका इस्तेमाल सावधानी से करें; नीचे Rust लाइब्रेरी से लिंक करते समय जानकारी देखें.) |
shared_libs |
cc_library मॉड्यूल की सूची, जिन्हें शेयर की गई लाइब्रेरी के तौर पर डाइनैमिक तरीके से लिंक किया जाना चाहिए. |
static_libs |
cc_library मॉड्यूल की सूची, जिन्हें स्टैटिक लाइब्रेरी के तौर पर स्टैटिक रूप से लिंक किया जाना चाहिए. |
whole_static_libs |
cc_library मॉड्यूल की सूची, जिन्हें स्टैटिक लाइब्रेरी के तौर पर स्टैटिक रूप से लिंक किया जाना चाहिए. साथ ही, इन्हें पूरी तरह से नतीजे वाली लाइब्रेरी में शामिल किया जाना चाहिए. rust_ffi_static वैरिएंट के लिए, whole_static_libraries को स्टैटिक लाइब्रेरी के संग्रह में शामिल किया जाएगा. rust_library_rlib के अलग-अलग वर्शन के लिए, whole_static_libraries लाइब्रेरी को rlib लाइब्रेरी में बंडल किया जाएगा.
|
Rust लाइब्रेरी से लिंक करते समय, सबसे सही तरीका यह है कि rlibs या dylibs के बजाय rustlibs प्रॉपर्टी का इस्तेमाल करें. ऐसा तब तक करें, जब तक आपके पास ऐसा करने की कोई खास वजह न हो. इससे बिल्ड सिस्टम, रूट मॉड्यूल की ज़रूरत के हिसाब से सही लिंक चुन पाता है. साथ ही, इससे इस बात की संभावना कम हो जाती है कि डिपेंडेंसी ट्री में किसी लाइब्रेरी के rlib और dylib, दोनों वर्शन शामिल हों. ऐसा होने पर, कंपाइलेशन पूरा नहीं हो पाएगा.
ऐसी सुविधाएं जो बिल्ड के साथ काम नहीं करती हैं और जो सीमित तौर पर काम करती हैं
Soong's Rust, vendor और vendor_ramdisk इमेज और स्नैपशॉट के लिए सीमित सहायता उपलब्ध कराता है. हालांकि, staticlibs, cdylibs, rlibs, और binaries काम करते हैं. वेंडर इमेज बिल्ड टारगेट के लिए, android_vndk cfg प्रॉपर्टी सेट की जाती है. अगर सिस्टम और वेंडर के टारगेट में अंतर है, तो कोड में इसका इस्तेमाल किया जा सकता है. rust_proc_macros वेंडर स्नैपशॉट के हिस्से के तौर पर कैप्चर नहीं किए जाते हैं. अगर ये ज़रूरी हैं, तो पक्का करें कि आपने इन्हें सही तरीके से वर्शन-कंट्रोल किया हो.
प्रॉडक्ट, VNDK, और रिकवरी इमेज के लिए यह सुविधा उपलब्ध नहीं है.
इंक्रीमेंटल बिल्ड
डेवलपर, SOONG_RUSTC_INCREMENTAL एनवायरमेंट वैरिएबल को true पर सेट करके, Rust सोर्स के इंक्रीमेंटल कंपाइलेशन को चालू कर सकते हैं.
चेतावनी: इस बात की कोई गारंटी नहीं है कि इससे जनरेट किए गए बाइनरी, बिल्डबॉट से जनरेट किए गए बाइनरी के जैसे ही होंगे. ऑब्जेक्ट फ़ाइलों में मौजूद फ़ंक्शन या डेटा के पते अलग-अलग हो सकते हैं. यह पक्का करने के लिए कि जनरेट किए गए आर्टफ़ैक्ट, EngProd के इन्फ़्रास्ट्रक्चर से बनाए गए आर्टफ़ैक्ट से 100% मेल खाते हों, इस वैल्यू को सेट न करें.