इस पेज पर, Bazel की मदद से Xcode प्रोजेक्ट बनाने या उसे टेस्ट करने का तरीका बताया गया है. इसमें Xcode और Bazel के बीच के अंतर के बारे में बताया गया है. साथ ही, Xcode प्रोजेक्ट को Bazel प्रोजेक्ट में बदलने का तरीका बताया गया है. इसमें, आम तौर पर होने वाली गड़बड़ियों को ठीक करने के तरीके भी बताए गए हैं.
Xcode और Bazel के बीच अंतर
Bazel में, आपको हर बिल्ड टारगेट और उसकी डिपेंडेंसी के साथ-साथ, बिल्ड के नियमों के ज़रिए बिल्ड की सेटिंग साफ़ तौर पर तय करनी होती हैं.
Bazel को उन सभी फ़ाइलों की ज़रूरत होती है जिन पर प्रोजेक्ट निर्भर करता है. ये फ़ाइलें, वर्कस्पेस डायरेक्ट्री में मौजूद होनी चाहिए या
MODULE.bazelफ़ाइल में डिपेंडेंसी के तौर पर तय की गई होनी चाहिए.Bazel की मदद से Xcode प्रोजेक्ट बनाते समय,
BUILDफ़ाइलें, सोर्स ऑफ़ ट्रुथ बन जाती हैं. अगर आपको Xcode में प्रोजेक्ट पर काम करना है, तो आपको Xcode प्रोजेक्ट का एक नया वर्शन जनरेट करना होगा. यह वर्शन,BUILDफ़ाइलों से मेल खाना चाहिए. इसके लिए, rules_xcodeproj का इस्तेमाल करें. ऐसा तब करें, जबBUILDफ़ाइलों को अपडेट किया गया हो.BUILDफ़ाइलों में कुछ बदलाव करने पर, प्रोजेक्ट को फिर से जनरेट करने की ज़रूरत नहीं होती. जैसे, किसी टारगेट में डिपेंडेंसी जोड़ना. इससे डेवलपमेंट की प्रोसेस को तेज़ किया जा सकता है. अगर Xcode का इस्तेमाल नहीं किया जा रहा है, तोbazel buildऔरbazel testकमांड से, बिल्ड और टेस्ट करने की सुविधाएं मिलती हैं. हालांकि, इन पर कुछ पाबंदियां लागू होती हैं. इनके बारे में इस गाइड में आगे बताया गया है.
अनचाहे डेटा को फ़िल्टर करने से पहले ज़रूरी जानकारी
शुरू करने से पहले, यह काम करें:
अगर आपने पहले से Bazel इंस्टॉल नहीं किया है, तो Bazel इंस्टॉल करें.
अगर आपको Bazel और इसके कॉन्सेप्ट के बारे में जानकारी नहीं है, तो iOS ऐप्लिकेशन का ट्यूटोरियल पूरा करें. आपको Bazel वर्कस्पेस के बारे में पता होना चाहिए. इसमें
MODULE.bazelऔरBUILDफ़ाइलें शामिल हैं. साथ ही, आपको टारगेट, बिल्ड के नियम, और Bazel पैकेज के बारे में भी पता होना चाहिए.प्रोजेक्ट की डिपेंडेंसी का विश्लेषण करें और उन्हें समझें.
प्रोजेक्ट डिपेंडेंसी का विश्लेषण करना
Xcode के उलट, Bazel में आपको BUILD फ़ाइल में हर टारगेट के लिए सभी डिपेंडेंसी का साफ़ तौर पर एलान करना होता है.
बाहरी डिपेंडेंसी के बारे में ज़्यादा जानने के लिए, बाहरी डिपेंडेंसी के साथ काम करना लेख पढ़ें.
Bazel की मदद से, Xcode प्रोजेक्ट बनाना या उसकी जांच करना
Bazel की मदद से Xcode प्रोजेक्ट बनाने या उसकी जांच करने के लिए, यह तरीका अपनाएं:
(एक्सपेरिमेंट के तौर पर उपलब्ध) SwiftPM डिपेंडेंसी इंटिग्रेट करें
पहला चरण: MODULE.bazel फ़ाइल बनाना
नई डायरेक्ट्री में MODULE.bazel फ़ाइल बनाएं. यह डायरेक्ट्री, Bazel वर्कस्पेस का रूट बन जाती है. अगर प्रोजेक्ट में किसी बाहरी डिपेंडेंसी का इस्तेमाल नहीं किया जाता है, तो यह फ़ाइल खाली हो सकती है. अगर प्रोजेक्ट ऐसी फ़ाइलों या पैकेज पर निर्भर करता है जो प्रोजेक्ट की किसी डायरेक्ट्री में नहीं हैं, तो इन बाहरी डिपेंडेंसी के बारे में MODULE.bazel फ़ाइल में बताएं.
दूसरा चरण: (एक्सपेरिमेंट के तौर पर उपलब्ध) SwiftPM डिपेंडेंसी इंटिग्रेट करना
swift_bazel की मदद से, SwiftPM डिपेंडेंसी को Bazel वर्कस्पेस में इंटिग्रेट करने के लिए, आपको उन्हें Bazel पैकेज में बदलना होगा. इसके बारे में यहां दिए गए ट्यूटोरियल में बताया गया है .
तीसरा चरण: BUILD फ़ाइल बनाना
वर्कस्पेस और बाहरी डिपेंडेंसी तय करने के बाद, आपको एक BUILD फ़ाइल बनानी होगी. इससे Bazel को पता चलेगा कि प्रोजेक्ट का स्ट्रक्चर कैसा है. Bazel वर्कस्पेस के रूट में BUILD फ़ाइल बनाएं. साथ ही, प्रोजेक्ट के शुरुआती बिल्ड के लिए इसे इस तरह कॉन्फ़िगर करें:
- तीसरा चरण: ऐप्लिकेशन टारगेट जोड़ना
- तीसरा चरण बी: (ज़रूरी नहीं) टेस्ट के टारगेट जोड़ना
- तीसरा चरण: लाइब्रेरी के टारगेट जोड़ना
अहम जानकारी: पैकेज और Bazel के अन्य कॉन्सेप्ट के बारे में ज़्यादा जानने के लिए, वर्कस्पेस, पैकेज, और टारगेट लेख पढ़ें.
तीसरा चरण (क): ऐप्लिकेशन टारगेट जोड़ना
macos_application
या
ios_application
नियम टारगेट जोड़ें. यह टारगेट, macOS या iOS ऐप्लिकेशन बंडल बनाता है.
टारगेट में, कम से कम ये जानकारी दें:
bundle_id- बाइनरी का बंडल आईडी (रिवर्स-डीएनएस पाथ के बाद ऐप्लिकेशन का नाम).provisioning_profile- Apple Developer खाते से प्रोविज़निंग प्रोफ़ाइल (अगर iOS डिवाइस के लिए बनाया जा रहा है).families(सिर्फ़ iOS के लिए) - ऐप्लिकेशन को iPhone, iPad या दोनों के लिए बनाना है या नहीं.infoplists- .plist फ़ाइलों की सूची, जिन्हें फ़ाइनल Info.plist फ़ाइल में मर्ज करना है.minimum_os_version- macOS या iOS का वह कम से कम वर्शन जिस पर ऐप्लिकेशन काम करता है. इससे यह पक्का होता है कि Bazel, ऐप्लिकेशन को सही एपीआई लेवल के साथ बनाता है.
तीसरा बी चरण: (ज़रूरी नहीं) टेस्ट के टारगेट जोड़ना
Bazel के Apple बिल्ड के नियमों की मदद से, Apple के सभी प्लैटफ़ॉर्म पर यूनिट और यूज़र इंटरफ़ेस (यूआई) टेस्ट चलाए जा सकते हैं. टेस्ट के लिए टारगेट इस तरह जोड़ें:
macos_unit_testका इस्तेमाल करके, macOS पर लाइब्रेरी और ऐप्लिकेशन पर आधारित यूनिट टेस्ट चलाएं.ios_unit_testका इस्तेमाल करके, iOS पर लाइब्रेरी पर आधारित यूनिट टेस्ट बनाएं और उन्हें चलाएं.ios_ui_testiOS सिम्युलेटर में यूज़र इंटरफ़ेस टेस्ट बनाने और चलाने के लिए.टेस्टिंग के ऐसे ही नियम, tvOS, watchOS, और visionOS के लिए भी लागू होते हैं.
कम से कम, minimum_os_version एट्रिब्यूट के लिए कोई वैल्यू डालें. पैकेजिंग के अन्य एट्रिब्यूट, जैसे कि bundle_identifier और infoplists, डिफ़ॉल्ट रूप से सबसे ज़्यादा इस्तेमाल की जाने वाली वैल्यू पर सेट होते हैं. हालांकि, पक्का करें कि ये डिफ़ॉल्ट वैल्यू, प्रोजेक्ट के साथ काम करती हों. साथ ही, ज़रूरत के मुताबिक इन्हें बदलें. जिन टेस्ट के लिए iOS सिम्युलेटर की ज़रूरत होती है उनके लिए, ios_application टारगेट का नाम भी test_host एट्रिब्यूट की वैल्यू के तौर पर डालें.
तीसरा चरण(ग): लाइब्रेरी के टारगेट जोड़ना
ऐप्लिकेशन और/या टेस्ट के लिए, Objective-C की हर लाइब्रेरी के लिए objc_library टारगेट और Swift की हर लाइब्रेरी के लिए swift_library टारगेट जोड़ें.
लाइब्रेरी के टारगेट इस तरह जोड़ें:
ऐप्लिकेशन लाइब्रेरी के टारगेट को ऐप्लिकेशन के टारगेट के लिए डिपेंडेंसी के तौर पर जोड़ें.
टेस्ट लाइब्रेरी के टारगेट को टेस्ट टारगेट के लिए डिपेंडेंसी के तौर पर जोड़ें.
srcsएट्रिब्यूट में, लागू करने के सोर्स की सूची दें.hdrsएट्रिब्यूट में हेडर की सूची बनाएं.
अलग-अलग तरह के ऐप्लिकेशन के लिए, मौजूदा उदाहरणों को सीधे rules_apple examples डायरेक्ट्री में ब्राउज़ किया जा सकता है. उदाहरण के लिए:
बिल्ड के नियमों के बारे में ज़्यादा जानने के लिए, Bazel के लिए Apple के नियम देखें.
इस चरण में, बिल्ड की जांच करना बेहतर होता है:
bazel build //:<application_target>
चौथा चरण: (ज़रूरी नहीं) बिल्ड को ज़्यादा बेहतर बनाना
अगर प्रोजेक्ट बड़ा है या जैसे-जैसे वह बढ़ता है, वैसे-वैसे उसे कई Bazel पैकेज में बांटने का सुझाव दिया जाता है. ज़्यादा जानकारी देने वाले इस डेटा से ये फ़ायदे मिलते हैं:
बिल्ड की इंक्रीमेंटैलिटी में बढ़ोतरी,
बिल्ड टास्क को एक साथ चलाने की सुविधा बेहतर हुई है,
आने वाले समय में उपयोगकर्ताओं के लिए बेहतर रखरखाव,
टारगेट और पैकेज में सोर्स कोड की विज़िबिलिटी पर बेहतर कंट्रोल. इससे ऐसी समस्याएं नहीं होती हैं जिनमें लाइब्रेरी में मौजूद जानकारी, सार्वजनिक एपीआई में लीक हो जाती है.
प्रोजेक्ट को ज़्यादा बारीकी से समझने के लिए सलाह:
हर लाइब्रेरी को उसके Bazel पैकेज में रखें. उन डिपेंडेंसी से शुरुआत करें जिनके लिए सबसे कम डिपेंडेंसी की ज़रूरत होती है. इसके बाद, डिपेंडेंसी ट्री में ऊपर की ओर बढ़ें.
BUILDफ़ाइलें जोड़ते समय और टारगेट तय करते समय, इन नए टारगेट को उन टारगेट केBUILDएट्रिब्यूट में जोड़ें जो इन पर निर्भर हैं.depsglob()फ़ंक्शन, पैकेज की सीमाओं को पार नहीं करता. इसलिए, पैकेज की संख्या बढ़ने पर,glob()से मैच होने वाली फ़ाइलों की संख्या कम हो जाएगी.किसी
mainडायरेक्ट्री मेंBUILDफ़ाइल जोड़ते समय, उससे जुड़ीtestडायरेक्ट्री में भीBUILDफ़ाइल जोड़ें.सभी पैकेज के लिए, विज्ञापन दिखने से जुड़ी सीमाएं लागू करें.
BUILDफ़ाइलों में हर बड़े बदलाव के बाद, प्रोजेक्ट बनाएं. साथ ही, बिल्ड से जुड़ी गड़बड़ियों को ठीक करें.
पांचवां चरण: बिल्ड चलाना
पूरी तरह से माइग्रेट किए गए बिल्ड को चलाएं, ताकि यह पक्का किया जा सके कि यह बिना किसी गड़बड़ी या चेतावनी के पूरा हो गया है. हर ऐप्लिकेशन और टेस्ट टारगेट को अलग-अलग चलाएं, ताकि आपको होने वाली किसी भी गड़बड़ी के सोर्स आसानी से मिल सकें.
उदाहरण के लिए:
bazel build //:my-targetछठा चरण: rules_xcodeproj की मदद से Xcode प्रोजेक्ट जनरेट करना
Bazel का इस्तेमाल करके बिल्ड करते समय, MODULE.bazel और BUILD फ़ाइलें, बिल्ड के बारे में भरोसेमंद जानकारी का सोर्स बन जाती हैं. Xcode को इसकी जानकारी देने के लिए, आपको rules_xcodeproj का इस्तेमाल करके, Bazel के साथ काम करने वाला Xcode प्रोजेक्ट जनरेट करना होगा.
समस्या का हल
Bazel में गड़बड़ियां तब हो सकती हैं, जब यह चुने गए Xcode वर्शन के साथ सिंक न हो. ऐसा तब होता है, जब कोई अपडेट लागू किया जाता है. अगर आपको Xcode में गड़बड़ियां आ रही हैं, तो यहां दिए गए तरीके आज़माएं. उदाहरण के लिए, "Apple CROSSTOOL का इस्तेमाल करने के लिए, Xcode का वर्शन बताना ज़रूरी है".
Xcode को मैन्युअल तरीके से चलाएं और सभी नियम और शर्तें स्वीकार करें.
सही वर्शन के लिए Xcode select का इस्तेमाल करें, लाइसेंस स्वीकार करें, और Bazel की स्थिति साफ़ करें.
sudo xcode-select -s /Applications/Xcode.app/Contents/Developersudo xcodebuild -licensebazel sync --configure
- अगर इससे काम नहीं बनता है, तो
bazel clean --expungeचलाकर देखें.