native.cc_library. ध्यान दें कि नेटिव मॉड्यूल, सिर्फ़ लोडिंग फ़ेज़ में उपलब्ध होता है. इसका मतलब है कि यह मैक्रो के लिए उपलब्ध है, लेकिन नियम लागू करने के लिए नहीं. एट्रिब्यूट, None वैल्यू को अनदेखा करेंगे और उन्हें ऐसे ट्रीट करेंगे जैसे एट्रिब्यूट सेट न किया गया हो.ये फ़ंक्शन भी उपलब्ध हैं:
सदस्य
- existing_rule
- existing_rules
- exports_files
- glob
- module_name
- module_version
- package_group
- package_name
- package_relative_label
- repo_name
- repository_name
- subpackages
existing_rule
unknown native.existing_rule(name)
None दिखाता है.यहां, डिक्शनरी की तरह दिखने वाले ऐसे ऑब्जेक्ट का मतलब है जिसे बदला नहीं जा सकता. जैसे, x. यह डिक्शनरी की तरह दिखने वाले इटरेशन, len(x), name in x, x[name], x.get(name), x.items(), x.keys(), और x.values() को सपोर्ट करता है.
अगर --noincompatible_existing_rules_immutable_view फ़्लैग सेट किया गया है, तो यह फ़ंक्शन, उसी कॉन्टेंट वाली एक नई डिक्शनरी दिखाता है जिसे बदला जा सकता है.
नतीजे में, हर एट्रिब्यूट के लिए एक एंट्री होती है. हालांकि, इसमें निजी एट्रिब्यूट (जिनके नाम किसी अक्षर से शुरू नहीं होते) और कुछ ऐसे पुराने एट्रिब्यूट टाइप शामिल नहीं होते जिन्हें दिखाया नहीं जा सकता. इसके अलावा, डिक्शनरी में नियम इंस्टैंस के name और kind (उदाहरण के लिए, 'cc_binary') के लिए एंट्री होती हैं.
नतीजे की वैल्यू, एट्रिब्यूट की वैल्यू को इस तरह दिखाती हैं:
- str, int, और bool टाइप के एट्रिब्यूट, जैसे हैं वैसे ही दिखाए जाते हैं.
- एक ही पैकेज में मौजूद टारगेट के लिए, लेबल को
':foo'फ़ॉर्मैट वाली स्ट्रिंग में बदला जाता है. वहीं, किसी दूसरे पैकेज में मौजूद टारगेट के लिए, लेबल को'//pkg:name'फ़ॉर्मैट वाली स्ट्रिंग में बदला जाता है. - सूचियों को टपल के तौर पर दिखाया जाता है. वहीं, डिक्शनरी को नई डिक्शनरी में बदला जाता है जिसे बदला जा सकता है. इनके एलिमेंट को भी इसी तरह बदला जाता है.
selectवैल्यू को, ऊपर बताए गए तरीके से बदलकर दिखाया जाता है.- नतीजे में उन एट्रिब्यूट को शामिल नहीं किया जाता जिनके लिए नियम इंस्टैंशिएट करते समय कोई वैल्यू तय नहीं की गई थी और जिनकी डिफ़ॉल्ट वैल्यू कंप्यूट की गई है. (कंप्यूट की गई डिफ़ॉल्ट वैल्यू, विश्लेषण के फ़ेज़ तक कंप्यूट नहीं की जा सकती.).
अगर हो सके, तो इस फ़ंक्शन का इस्तेमाल न करें. इससे BUILD फ़ाइलें, आसानी से टूट सकती हैं और ऑर्डर पर निर्भर हो सकती हैं. इसके अलावा, ध्यान रखें कि नियम के एट्रिब्यूट की वैल्यू को इंटरनल फ़ॉर्म से Starlark में बदलने के दो अन्य तरीकों से यह थोड़ा अलग है. इनमें से एक तरीका, कंप्यूट की गई डिफ़ॉल्ट वैल्यू के लिए इस्तेमाल किया जाता है. वहीं, दूसरा तरीका ctx.attr.foo के लिए इस्तेमाल किया जाता है.
पैरामीटर
| पैरामीटर | ब्यौरा |
|---|---|
name
|
ज़रूरी है टारगेट का नाम. |
existing_rules
unknown native.existing_rules()
existing_rule(name) से मिलता है.यहां, डिक्शनरी की तरह दिखने वाले ऐसे ऑब्जेक्ट का मतलब है जिसे बदला नहीं जा सकता. जैसे, x. यह डिक्शनरी की तरह दिखने वाले इटरेशन, len(x), name in x, x[name], x.get(name), x.items(), x.keys(), और x.values() को सपोर्ट करता है.
अगर --noincompatible_existing_rules_immutable_view फ़्लैग सेट किया गया है, तो यह फ़ंक्शन, उसी कॉन्टेंट वाली एक नई डिक्शनरी दिखाता है जिसे बदला जा सकता है.
ध्यान दें: अगर हो सके, तो इस फ़ंक्शन का इस्तेमाल न करें. इससे BUILD फ़ाइलें, आसानी से टूट सकती हैं और ऑर्डर पर निर्भर हो सकती हैं. इसके अलावा, अगर --noincompatible_existing_rules_immutable_view फ़्लैग सेट किया गया है, तो यह फ़ंक्शन बहुत महंगा हो सकता है. खास तौर पर, अगर इसे किसी लूप में कॉल किया जाता है.
exports_files
None native.exports_files(srcs, visibility=None, licenses=None)पैरामीटर
| पैरामीटर | ब्यौरा |
|---|---|
srcs
|
स्ट्रिंग का क्रम;
ज़रूरी है एक्सपोर्ट की जाने वाली फ़ाइलों की सूची. |
visibility
|
sequence; या None;
डिफ़ॉल्ट वैल्यू Noneहै विज़िबिलिटी का एलान किया जा सकता है. फ़ाइलें, तय किए गए टारगेट के लिए दिखेंगी. अगर कोई विज़िबिलिटी तय नहीं की जाती है, तो फ़ाइलें हर पैकेज के लिए दिखेंगी. |
licenses
|
स्ट्रिंग का क्रम; या None;
डिफ़ॉल्ट वैल्यू Noneहैलाइसेंस तय किए जाने चाहिए. |
glob
sequence native.glob(include=[], exclude=[], exclude_directories=1, allow_empty=unbound)
- वे फ़ाइलें जो
includeमें मौजूद कम से कम एक पैटर्न से मेल खाती हैं. - वे फ़ाइलें जो
excludeमें मौजूद किसी भी पैटर्न से मेल नहीं खातीं. इसकी डिफ़ॉल्ट वैल्यू[]होती है.
exclude_directories आर्ग्युमेंट चालू है (इसे 1 पर सेट किया गया है), तो नतीजों में डायरेक्ट्री टाइप की फ़ाइलें शामिल नहीं की जाएंगी. इसकी डिफ़ॉल्ट वैल्यू 1 होती है.
पैरामीटर
| पैरामीटर | ब्यौरा |
|---|---|
include
|
स्ट्रिंग का क्रम;
डिफ़ॉल्ट वैल्यू []है शामिल किए जाने वाले ग्लोब पैटर्न की सूची. |
exclude
|
स्ट्रिंग का क्रम;
डिफ़ॉल्ट वैल्यू []है ग्लोब पैटर्न की वह सूची जिसे शामिल नहीं किया जाना है. |
exclude_directories
|
डिफ़ॉल्ट वैल्यू 1है यह फ़्लैग तय करता है कि डायरेक्ट्री को शामिल करना है या नहीं. |
allow_empty
|
डिफ़ॉल्ट वैल्यू unboundहै यह फ़्लैग तय करता है कि ग्लोब पैटर्न से कोई मैच न होने पर, हमें गड़बड़ी दिखानी है या नहीं. अगर `allow_empty` की वैल्यू 'गलत' है, तो शामिल किए जाने वाले हर पैटर्न से कोई न कोई मैच होना चाहिए. साथ ही, फ़ाइनल नतीजे में कुछ न कुछ शामिल होना चाहिए. यह तब तय होता है, जब `exclude` पैटर्न के मैच को शामिल नहीं किया जाता. |
module_name
string native.module_name()
module_ctx.modules में दिखने वाले module.name फ़ील्ड जैसा ही होता है.
यह None दिखा सकता है.
module_version
string native.module_version()
module_ctx.modules में दिखने वाले module.version फ़ील्ड जैसा ही होता है.
यह None दिखा सकता है.
package_group
None native.package_group(name, packages=[], includes=[])visibility एट्रिब्यूट में रेफ़र किया जा सकता है.
पैरामीटर
| पैरामीटर | ब्यौरा |
|---|---|
name
|
ज़रूरी है इस नियम के लिए यूनीक नाम. |
packages
|
स्ट्रिंग का क्रम;
डिफ़ॉल्ट वैल्यू []है इस ग्रुप में शामिल पैकेज की पूरी सूची. |
includes
|
स्ट्रिंग का क्रम;
डिफ़ॉल्ट वैल्यू []है अन्य पैकेज ग्रुप जो इसमें शामिल हैं. |
package_name
string native.package_name()
some/package/BUILD में, इसकी वैल्यू some/package होगी. अगर BUILD फ़ाइल, .bzl फ़ाइल में तय किए गए किसी फ़ंक्शन को कॉल करती है, तो package_name() कॉलर BUILD फ़ाइल के पैकेज से मैच करेगा.
package_relative_label
Label native.package_relative_label(input)
BUILD फ़ाइल के लिए होता है जिसके लिए मौजूदा मैक्रो चल रहा है. अगर इनपुट पहले से ही Label है, तो इसे बिना किसी बदलाव के दिखाया जाता है.इस फ़ंक्शन को सिर्फ़ BUILD फ़ाइल और उसके ज़रिए सीधे या घुमा-फिराकर कॉल किए गए मैक्रो का आकलन करते समय कॉल किया जा सकता है. इसे (उदाहरण के लिए) नियम लागू करने वाले फ़ंक्शन में कॉल नहीं किया जा सकता.
इस फ़ंक्शन का नतीजा, Label की वही वैल्यू होती है जो BUILD फ़ाइल में तय किए गए किसी टारगेट के लेबल वाली वैल्यू के एट्रिब्यूट में दी गई स्ट्रिंग को पास करने पर मिलती है.
इस्तेमाल से जुड़ी ज़रूरी जानकारी: इस फ़ंक्शन और Label() में यह अंतर है कि Label() उस .bzl फ़ाइल के पैकेज के कॉन्टेक्स्ट का इस्तेमाल करता है जिसने इसे कॉल किया है. यह BUILD फ़ाइल के पैकेज के कॉन्टेक्स्ट का इस्तेमाल नहीं करता. Label() का इस्तेमाल तब करें, जब आपको किसी ऐसे तय टारगेट को रेफ़र करना हो जो मैक्रो में हार्डकोड किया गया हो. जैसे, कंपाइलर. package_relative_label() का इस्तेमाल तब करें, जब आपको BUILD फ़ाइल से मिली लेबल स्ट्रिंग को Label ऑब्जेक्ट में बदलना हो. BUILD फ़ाइल या .bzl फ़ाइल को कॉल करने के अलावा, किसी अन्य पैकेज के कॉन्टेक्स्ट में स्ट्रिंग को Label में बदलने का कोई तरीका नहीं है. इसलिए, आउटर मैक्रो को हमेशा लेबल स्ट्रिंग के बजाय, इनर मैक्रो को Label ऑब्जेक्ट पास करने चाहिए.)
पैरामीटर
| पैरामीटर | ब्यौरा |
|---|---|
input
|
स्ट्रिंग; या Label;
ज़रूरी है इनपुट लेबल स्ट्रिंग या Label ऑब्जेक्ट. अगर कोई Label ऑब्जेक्ट पास किया जाता है, तो उसे बिना किसी बदलाव के दिखाया जाता है. |
repo_name
string native.repo_name()
repository_name
string native.repository_name()
--+incompatible_enable_deprecated_label_apis यह सुविधा अब काम नहीं करती है. को सेट करना होगा. इसके बजाय,
repo_name का इस्तेमाल करें. इसमें शुरुआती ऐट-साइन शामिल नहीं होता, लेकिन यह बाकी मामलों में एक जैसा काम करता है.यह उस रेपो का कैननिकल नाम है जिसमें फ़िलहाल आकलन किया जा रहा पैकेज मौजूद है. इसमें शुरुआती ऐट-साइन (@) शामिल होता है. उदाहरण के लिए, WORKSPACE स्टैंज़ा local_repository(name='local', path=...) से बनाए गए पैकेज में, इसे @local पर सेट किया जाएगा. मुख्य रेपो में मौजूद पैकेज में, इसे @ पर सेट किया जाएगा.
subpackages
sequence native.subpackages(include, exclude=[], allow_empty=False)
पैरामीटर
| पैरामीटर | ब्यौरा |
|---|---|
include
|
स्ट्रिंग का क्रम;
ज़रूरी है सब-पैकेज स्कैन में शामिल किए जाने वाले ग्लोब पैटर्न की सूची. |
exclude
|
स्ट्रिंग का क्रम;
डिफ़ॉल्ट वैल्यू []है सब-पैकेज स्कैन से बाहर रखे जाने वाले ग्लोब पैटर्न की सूची. |
allow_empty
|
डिफ़ॉल्ट वैल्यू Falseहै यह फ़्लैग तय करता है कि कॉल से खाली सूची मिलने पर, हमें गड़बड़ी दिखानी है या नहीं. डिफ़ॉल्ट तौर पर, खाली सूची से पता चलता है कि BUILD फ़ाइल में गड़बड़ी हो सकती है. ऐसा तब होता है, जब subpackages() को कॉल करना ज़रूरी नहीं होता. इसे 'सही' पर सेट करने से, इस मामले में यह फ़ंक्शन सही तरीके से काम करता है. |