Android लाइब्रेरी बनाना

Android लाइब्रेरी और Android ऐप्लिकेशन मॉड्यूल, दोनों का स्ट्रक्चर एक जैसा होता है. इसमें ऐप्लिकेशन बनाने के लिए ज़रूरी सभी चीज़ें शामिल होती हैं. जैसे, सोर्स कोड, रिसोर्स फ़ाइलें, और Android मेनिफ़ेस्ट.

हालांकि, Android लाइब्रेरी को डिवाइस पर चलने वाले APK में कंपाइल करने के बजाय, Android संग्रह (AAR) फ़ाइल में कंपाइल किया जाता है. इसका इस्तेमाल, Android ऐप्लिकेशन मॉड्यूल के लिए डिपेंडेंसी के तौर पर किया जा सकता है. JAR फ़ाइलों के मुकाबले, Android ऐप्लिकेशन के लिए AAR फ़ाइलों में ये सुविधाएं मिलती हैं:

  • AAR फ़ाइलों में Android रिसॉर्स और मेनिफ़ेस्ट फ़ाइल शामिल हो सकती है. इससे आपको Kotlin या Java क्लास और तरीकों के साथ-साथ, लेआउट और ड्रॉबल जैसे शेयर किए गए रिसॉर्स को बंडल करने की सुविधा मिलती है.
  • AAR फ़ाइलों में C/C++ लाइब्रेरी हो सकती हैं. इनका इस्तेमाल, ऐप्लिकेशन मॉड्यूल के C/C++ कोड में किया जा सकता है.

लाइब्रेरी मॉड्यूल इन स्थितियों में काम आता है:

  • एक से ज़्यादा ऐसे ऐप्लिकेशन बनाते समय जो कुछ एक जैसे कॉम्पोनेंट का इस्तेमाल करते हैं, जैसे कि ऐक्टिविटी, सेवाएं या यूज़र इंटरफ़ेस (यूआई) लेआउट
  • ऐसा ऐप्लिकेशन बनाते समय जो एक से ज़्यादा APK वैरिएशन में मौजूद हो. जैसे, मुफ़्त और पैसे चुकाकर डाउनलोड किए जाने वाले वर्शन, जो मुख्य कॉम्पोनेंट शेयर करते हैं

दोनों ही मामलों में, उन फ़ाइलों को लाइब्रेरी मॉड्यूल में ले जाएं जिनका आपको फिर से इस्तेमाल करना है. इसके बाद, लाइब्रेरी को हर ऐप्लिकेशन मॉड्यूल के लिए डिपेंडेंसी के तौर पर जोड़ें.

इस पेज पर, Android लाइब्रेरी मॉड्यूल बनाने और उसका इस्तेमाल करने का तरीका बताया गया है. लाइब्रेरी पब्लिश करने का तरीका जानने के लिए, लाइब्रेरी पब्लिश करना लेख पढ़ें

लाइब्रेरी मॉड्यूल बनाना

अपने प्रोजेक्ट में नया लाइब्रेरी मॉड्यूल बनाने के लिए, यह तरीका अपनाएं:

  1. फ़ाइल > नया > नया मॉड्यूल पर क्लिक करें.
  2. नया मॉड्यूल बनाएं डायलॉग बॉक्स में, Android लाइब्रेरी पर क्लिक करें. इसके बाद, आगे बढ़ें पर क्लिक करें.

    Kotlin या Java लाइब्रेरी बनाने का विकल्प भी है. इससे पारंपरिक JAR फ़ाइल बनती है. JAR फ़ाइल कई प्रोजेक्ट के लिए काम की होती है. खास तौर पर, जब आपको दूसरे प्लैटफ़ॉर्म के साथ कोड शेयर करना हो. हालांकि, इसमें Android रिसॉर्स या मेनिफ़ेस्ट फ़ाइलें शामिल नहीं की जा सकतीं. ये फ़ाइलें, Android प्रोजेक्ट में कोड का फिर से इस्तेमाल करने के लिए बहुत काम की होती हैं. इस गाइड में, Android लाइब्रेरी बनाने के बारे में बताया गया है.

  3. अपनी लाइब्रेरी को कोई नाम दें और लाइब्रेरी में मौजूद कोड के लिए, SDK टूल का कम से कम वर्शन चुनें. इसके बाद, पूरा करें पर क्लिक करें.

Gradle प्रोजेक्ट सिंक होने के बाद, लाइब्रेरी मॉड्यूल प्रोजेक्ट पैनल में दिखता है. अगर आपको नया मॉड्यूल फ़ोल्डर नहीं दिखता है, तो पक्का करें कि पैनल में Android व्यू दिख रहा हो.

ऐप्लिकेशन मॉड्यूल को लाइब्रेरी मॉड्यूल में बदलना

अगर आपके पास कोई मौजूदा ऐप्लिकेशन मॉड्यूल है और आपको उसमें मौजूद कोड का फिर से इस्तेमाल करना है, तो इसे लाइब्रेरी मॉड्यूल में बदलने के लिए, यह तरीका अपनाएं:

  1. अगर Groovy का इस्तेमाल किया जा रहा है, तो मॉड्यूल-लेवल की build.gradle फ़ाइल खोलें. अगर Kotlin स्क्रिप्ट का इस्तेमाल किया जा रहा है, तो build.gradle.kts फ़ाइल खोलें.
  2. applicationId की लाइन मिटाएं. सिर्फ़ Android ऐप्लिकेशन मॉड्यूल ही इसे तय कर सकता है.
  3. फ़ाइल में सबसे ऊपर मौजूद, ऐसा `plugins` ब्लॉक ढूंढें जो इस तरह दिखता हो:

    Groovy

      plugins {
          id 'com.android.application'
      }
      

    Kotlin

      plugins {
          id("com.android.application")
      }
      

    इसे इनमें से किसी एक में बदलें:

    Groovy

      plugins {
          id 'com.android.library'
      }
      

    Kotlin

      plugins {
          id("com.android.library")
      }
      
  4. फ़ाइल सेव करें और फ़ाइल > Gradle फ़ाइलों के साथ प्रोजेक्ट सिंक करें पर क्लिक करें.

मॉड्यूल का स्ट्रक्चर पहले जैसा ही है, लेकिन अब यह Android लाइब्रेरी के तौर पर काम करता है. इससे APK के बजाय AAR फ़ाइल बनती है.

AAR फ़ाइल बनाने के लिए, प्रोजेक्ट विंडो में लाइब्रेरी मॉड्यूल चुनें और बिल्ड करें > APK बनाएं पर क्लिक करें.

प्रोजेक्ट के स्ट्रक्चर वाले डायलॉग बॉक्स की मदद से डिपेंडेंसी जोड़ना

अपने प्रोजेक्ट में डिपेंडेंसी जोड़ने के लिए, प्रोजेक्ट स्ट्रक्चर डायलॉग का इस्तेमाल किया जा सकता है. नीचे दिए गए सेक्शन में, डिपेंडेंसी जोड़ने के लिए डायलॉग बॉक्स का इस्तेमाल करने का तरीका बताया गया है.

उसी प्रोजेक्ट में अपनी लाइब्रेरी का इस्तेमाल करना

एक ही प्रोजेक्ट में, किसी दूसरे ऐप्लिकेशन या लाइब्रेरी मॉड्यूल में अपनी नई Android लाइब्रेरी के कोड का इस्तेमाल करने के लिए, प्रोजेक्ट-लेवल की डिपेंडेंसी जोड़ें:

  1. फ़ाइल > प्रोजेक्ट का स्ट्रक्चर > डिपेंडेंसी पर जाएं.
  2. वह मॉड्यूल चुनें जिसमें आपको लाइब्रेरी जोड़नी है.
  3. एलान की गई डिपेंडेंसी टैब में, पर क्लिक करें. इसके बाद, मेन्यू से मॉड्यूल डिपेंडेंसी चुनें.

  4. मॉड्यूल डिपेंडेंसी जोड़ें डायलॉग में, अपना लाइब्रेरी मॉड्यूल चुनें.

    प्रोजेक्ट के स्ट्रक्चर वाले डायलॉग में मॉड्यूल डिपेंडेंसी जोड़ना

  5. वह कॉन्फ़िगरेशन चुनें जिसके लिए इस डिपेंडेंसी की ज़रूरत है या अगर यह सभी कॉन्फ़िगरेशन पर लागू होती है, तो लागू करें को चुनें. इसके बाद, ठीक है पर क्लिक करें.

Android Studio, डिपेंडेंसी जोड़ने के लिए आपके मॉड्यूल की build.gradle या build.gradle.kts फ़ाइल में बदलाव करता है. यह बदलाव इस फ़ॉर्मैट में होता है:

Groovy

  implementation project(path: ":example-library")

Kotlin

  implementation(project(":example-library"))

अपनी लाइब्रेरी का इस्तेमाल दूसरे प्रोजेक्ट में करना

डिपेंडेंसी (JAR और AAR) शेयर करने का सुझाया गया तरीका, Maven रिपॉज़िटरी का इस्तेमाल करना है. इसे किसी सेवा पर होस्ट किया जा सकता है, जैसे कि Maven Central या अपनी लोकल डिस्क पर डायरेक्ट्री स्ट्रक्चर के साथ. Maven रिपॉज़िटरी इस्तेमाल करने के बारे में ज़्यादा जानकारी के लिए, रिमोट रिपॉज़िटरी देखें.

जब किसी Android लाइब्रेरी को मेवन रिपॉज़िटरी में पब्लिश किया जाता है, तो उसमें मेटाडेटा शामिल किया जाता है, ताकि लाइब्रेरी की डिपेंडेंसी, इस्तेमाल किए जा रहे बिल्ड में शामिल की जा सकें. इससे, लाइब्रेरी का इस्तेमाल एक से ज़्यादा जगहों पर करने पर, डुप्लीकेट कॉपी अपने-आप हट जाती हैं.

किसी दूसरे प्रोजेक्ट के किसी दूसरे ऐप्लिकेशन मॉड्यूल में, अपनी Android लाइब्रेरी के कोड का इस्तेमाल करने के लिए, ऐसा करें:

  1. फ़ाइल > प्रोजेक्ट का स्ट्रक्चर > डिपेंडेंसी पर जाएं.
  2. एलान की गई डिपेंडेंसी टैब में, पर क्लिक करें. इसके बाद, मेन्यू में लाइब्रेरी डिपेंडेंसी चुनें.

  3. लाइब्रेरी डिपेंडेंसी जोड़ें डायलॉग में, खोज बॉक्स का इस्तेमाल करके वह लाइब्रेरी ढूंढें जिसे जोड़ना है. यह फ़ॉर्म, settings.gradle या settings.gradle.kts फ़ाइल में dependencyResolutionManagement { repositories {...}} ब्लॉक में बताए गए रिपॉज़िटरी खोजता है.

    प्रोजेक्ट के स्ट्रक्चर वाले डायलॉग में लाइब्रेरी डिपेंडेंसी जोड़ना

  4. वह कॉन्फ़िगरेशन चुनें जिसके लिए इस डिपेंडेंसी की ज़रूरत है या अगर यह सभी कॉन्फ़िगरेशन पर लागू होती है, तो लागू करें चुनें. इसके बाद, ठीक है पर क्लिक करें.

अपने ऐप्लिकेशन की build.gradle या build.gradle.kts फ़ाइल देखें और पुष्टि करें कि यहां दिए गए डिक्लेरेशन जैसा कोई डिक्लेरेशन दिख रहा है या नहीं. यह डिक्लेरेशन, आपके चुने गए बिल्ड कॉन्फ़िगरेशन पर निर्भर करता है:

Groovy

  implementation 'com.example:examplelibrary:1.0.0'

Kotlin

  implementation("com.example:examplelibrary:1.0.0")

अपने AAR या JAR को डिपेंडेंसी के तौर पर जोड़ना

किसी दूसरे ऐप्लिकेशन मॉड्यूल में अपनी Android लाइब्रेरी के कोड का इस्तेमाल करने के लिए, यह तरीका अपनाएं:

  1. फ़ाइल > प्रोजेक्ट का स्ट्रक्चर > डिपेंडेंसी पर जाएं.
  2. एलान की गई डिपेंडेंसी टैब में, पर क्लिक करें. इसके बाद, मेन्यू में Jar डिपेंडेंसी चुनें.

  3. Jar/Aar डिपेंडेंसी जोड़ें डायलॉग में, अपनी AAR या JAR फ़ाइल का पाथ डालें. इसके बाद, वह कॉन्फ़िगरेशन चुनें जिस पर डिपेंडेंसी लागू होती है. अगर लाइब्रेरी सभी कॉन्फ़िगरेशन के लिए उपलब्ध होनी चाहिए, तो लागू करने का कॉन्फ़िगरेशन चुनें.

    प्रोजेक्ट के स्ट्रक्चर वाले डायलॉग में AAR डिपेंडेंसी जोड़ना

    अपने ऐप्लिकेशन की build.gradle या build.gradle.kts फ़ाइल की जांच करके पुष्टि करें कि यहां दिए गए डिक्लेरेशन जैसा कोई डिक्लेरेशन दिख रहा है या नहीं. यह डिक्लेरेशन, आपके चुने गए बिल्ड कॉन्फ़िगरेशन पर निर्भर करता है:

    Groovy

      implementation files('my_path/my_lib.aar')

    Kotlin

      implementation(files("my_path/my_lib.aar"))

Android Studio के बाहर चल रहे Gradle बिल्ड पर डिपेंडेंसी इंपोर्ट करने के लिए, अपने ऐप्लिकेशन की build.gradle या build.gradle.kts फ़ाइल में डिपेंडेंसी का पाथ जोड़ें. उदाहरण के लिए:

Groovy

dependencies {
    implementation fileTree(dir: "libs", include: ["*.jar", "*.aar"])
}

Kotlin

dependencies {
    implementation(fileTree(mapOf("dir" to "libs", "include" to listOf("*.jar", "*.aar"))))
}

Gradle डिपेंडेंसी जोड़ने के बारे में ज़्यादा जानने के लिए, बिल्ड डिपेंडेंसी जोड़ना लेख पढ़ें.

किसी संसाधन को सार्वजनिक के तौर पर एलान करना

संसाधनों में आपके प्रोजेक्ट की res/ डायरेक्ट्री में मौजूद सभी फ़ाइलें शामिल होती हैं. जैसे, इमेज. लाइब्रेरी में मौजूद सभी संसाधन डिफ़ॉल्ट रूप से सार्वजनिक होते हैं. सभी संसाधनों को निजी बनाने के लिए, आपको कम से कम एक विशेष एट्रिब्यूट को सार्वजनिक के तौर पर तय करना होगा.

किसी संसाधन को सार्वजनिक के तौर पर एलान करने के लिए, अपनी लाइब्रेरी की public.xml फ़ाइल में <public> एलान जोड़ें. अगर आपने पहले कभी सार्वजनिक संसाधन नहीं जोड़े हैं, तो आपको अपनी लाइब्रेरी की res/values/ डायरेक्ट्री में public.xml फ़ाइल बनानी होगी.

यहां दिए गए उदाहरण में, mylib_app_name और mylib_public_string नामों के साथ दो सार्वजनिक स्ट्रिंग रिसॉर्स बनाए गए हैं:

<resources>
    <public name="mylib_app_name" type="string"/>
    <public name="mylib_public_string" type="string"/>
</resources>

अपनी लाइब्रेरी के उपयोगकर्ताओं को सिर्फ़ इंटरनल इस्तेमाल के लिए बने संसाधनों को ऐक्सेस करने से रोकने के लिए, एक या उससे ज़्यादा सार्वजनिक संसाधनों का एलान करके, अपने-आप निजी के तौर पर लेबल होने की सुविधा का इस्तेमाल करें. इसके अलावा, खाली <public /> टैग जोड़कर, सभी संसाधनों को निजी बनाया जा सकता है. इससे, किसी भी संसाधन को सार्वजनिक के तौर पर मार्क नहीं किया जाता और सभी संसाधनों को निजी के तौर पर मार्क कर दिया जाता है.

अगर आपको अपनी लाइब्रेरी का इस्तेमाल करने वाले डेवलपर को कोई संसाधन दिखाना है, तो उसे सार्वजनिक करें.

एट्रिब्यूट को निजी तौर पर सेट करने से, आपकी लाइब्रेरी के उपयोगकर्ताओं को लाइब्रेरी के इंटरनल संसाधनों से, कोड पूरा करने के सुझाव नहीं मिलते. साथ ही, उपयोगकर्ता आपकी लाइब्रेरी के क्लाइंट को बंद किए बिना, निजी संसाधनों का नाम बदल सकते हैं या उन्हें हटा सकते हैं. निजी रिसोर्स को कोड पूरा करने की सुविधा से फ़िल्टर किया जाता है. साथ ही, किसी निजी रिसोर्स का रेफ़रंस देने पर, लिंट टूल आपको चेतावनी देता है.

लाइब्रेरी बनाते समय, Android Gradle प्लग इन सार्वजनिक संसाधन की परिभाषाएं पाता है और उन्हें public.txt फ़ाइल में निकालता है. इसके बाद, public.txt फ़ाइल को AAR फ़ाइल में पैकेज किया जाता है.

लाइब्रेरी मॉड्यूल के डेवलपमेंट के बारे में जानकारी

लाइब्रेरी मॉड्यूल और उन पर निर्भर ऐप्लिकेशन डेवलप करते समय, इन व्यवहारों और सीमाओं का ध्यान रखें.

  • लाइब्रेरी को प्राथमिकता के क्रम में मर्ज किया जाता है.

    अपने Android ऐप्लिकेशन मॉड्यूल में लाइब्रेरी मॉड्यूल के रेफ़रंस जोड़ने के बाद, उनकी प्राथमिकता सेट की जा सकती है. बिल्ड के समय, लाइब्रेरी को ऐप्लिकेशन के साथ एक-एक करके मर्ज किया जाता है. यह प्रोसेस, सबसे कम प्राथमिकता से शुरू होकर सबसे ज़्यादा प्राथमिकता तक होती है.

  • रिसॉर्स मर्ज करने से जुड़ी समस्याओं से बचें.

    बिल्ड टूल, लाइब्रेरी मॉड्यूल के रिसॉर्स को, उससे जुड़े ऐप्लिकेशन मॉड्यूल के रिसॉर्स के साथ मर्ज करते हैं. अगर कोई दिया गया संसाधन आईडी, दोनों मॉड्यूल में तय किया गया है, तो ऐप्लिकेशन के संसाधन का इस्तेमाल किया जाता है.

    अगर एक से ज़्यादा AAR लाइब्रेरी के बीच कोई विरोध होता है, तो डिपेंडेंसी की सूची में सबसे पहले सूची में शामिल लाइब्रेरी के रिसॉर्स (dependencies ब्लॉक के सबसे ऊपर) का इस्तेमाल किया जाता है.

    संसाधनों के बीच होने वाली समस्याओं से बचने के लिए, नॉन-ट्रांज़िटिव R क्लास का इस्तेमाल करें. अगर ऐसा नहीं किया जा सकता, तो किसी प्रीफ़िक्स या नाम देने के लिए किसी ऐसी स्कीम का इस्तेमाल करें जो मॉड्यूल के लिए यूनीक हो (या प्रोजेक्ट के सभी मॉड्यूल के लिए यूनीक हो).

  • मल्टी-मॉड्यूल बिल्ड में, JAR डिपेंडेंसी को ट्रांज़िशन डिपेंडेंसी माना जाता है.

    जब किसी लाइब्रेरी प्रोजेक्ट में JAR डिपेंडेंसी जोड़ी जाती है, तो वह AAR आउटपुट करती है. लाइब्रेरी मॉड्यूल, JAR को प्रोसेस करता है और उसे AAR के साथ पैकेज करता है.

    हालांकि, अगर आपके प्रोजेक्ट में कोई लाइब्रेरी मॉड्यूल शामिल है जिसका इस्तेमाल किसी ऐप्लिकेशन मॉड्यूल में किया जाता है, तो ऐप्लिकेशन मॉड्यूल, लाइब्रेरी की लोकल JAR डिपेंडेंसी को ट्रांज़िशन डिपेंडेंसी के तौर पर इस्तेमाल करता है. इस मामले में, लाइब्रेरी मॉड्यूल के बजाय, स्थानीय JAR को उसे इस्तेमाल करने वाले ऐप्लिकेशन मॉड्यूल से प्रोसेस किया जाता है. इससे लाइब्रेरी के कोड में किए गए बदलावों की वजह से, इंक्रीमेंटल बिल्ड की प्रोसेस तेज़ हो जाती है.

    लोकल JAR डिपेंडेंसी की वजह से होने वाले किसी भी Java रिसॉर्स कॉन्फ़्लिक्ट को, लाइब्रेरी का इस्तेमाल करने वाले ऐप्लिकेशन मॉड्यूल में हल करना ज़रूरी है.

  • लाइब्रेरी मॉड्यूल, किसी बाहरी JAR लाइब्रेरी पर निर्भर हो सकता है.

    आपके पास ऐसा लाइब्रेरी मॉड्यूल बनाने का विकल्प है जो किसी बाहरी लाइब्रेरी पर निर्भर हो. इस मामले में, डिपेंडेंट मॉड्यूल को ऐसे टारगेट के लिए बनाना चाहिए जिसमें बाहरी लाइब्रेरी शामिल हो.

    ध्यान दें कि लाइब्रेरी मॉड्यूल और उस पर निर्भर ऐप्लिकेशन, दोनों को अपनी मेनिफ़ेस्ट फ़ाइलों में <uses-library> एलिमेंट में, बाहरी लाइब्रेरी का एलान करना होगा.

  • ऐप्लिकेशन मॉड्यूल का minSdkVersion, लाइब्रेरी के तय किए गए वर्शन के बराबर या उससे ज़्यादा होना चाहिए.

    लाइब्रेरी को, डिपेंडेंट ऐप्लिकेशन मॉड्यूल के हिस्से के तौर पर कॉम्पाइल किया जाता है. इसलिए, लाइब्रेरी मॉड्यूल में इस्तेमाल किए गए एपीआई, उस प्लैटफ़ॉर्म वर्शन के साथ काम करने चाहिए जिस पर ऐप्लिकेशन मॉड्यूल काम करता है.

  • हर लाइब्रेरी मॉड्यूल, अपनी R क्लास बनाता है.

    डिपेंडेंट ऐप्लिकेशन मॉड्यूल बनाने पर, लाइब्रेरी मॉड्यूल को AAR फ़ाइल में कंपाइल किया जाता है. इसके बाद, उन्हें ऐप्लिकेशन मॉड्यूल में जोड़ा जाता है. इसलिए, हर लाइब्रेरी की अपनी R क्लास होती है. इसका नाम, लाइब्रेरी के पैकेज के नाम के हिसाब से रखा जाता है.

    मुख्य मॉड्यूल और लाइब्रेरी मॉड्यूल से जनरेट की गई R क्लास, ज़रूरी सभी पैकेज में बनाई जाती है. इनमें मुख्य मॉड्यूल का पैकेज और लाइब्रेरी के पैकेज भी शामिल हैं.

  • किसी लाइब्रेरी मॉड्यूल में, ProGuard की अपनी कॉन्फ़िगरेशन फ़ाइल शामिल हो सकती है.

    अगर आपके पास कोई लाइब्रेरी प्रोजेक्ट है जिसका इस्तेमाल AAR बनाने और पब्लिश करने के लिए किया जाता है, तो अपनी लाइब्रेरी के बिल्ड कॉन्फ़िगरेशन में ProGuard कॉन्फ़िगरेशन फ़ाइल जोड़ी जा सकती है. ऐसा करने पर, Android Gradle प्लग इन आपके बताए गए ProGuard नियमों को लागू करता है. बिल्ड टूल, लाइब्रेरी मॉड्यूल के लिए जनरेट की गई AAR फ़ाइल में इस फ़ाइल को एम्बेड करते हैं. जब किसी ऐप्लिकेशन मॉड्यूल में लाइब्रेरी जोड़ी जाती है, तो लाइब्रेरी की ProGuard फ़ाइल को ऐप्लिकेशन मॉड्यूल की ProGuard कॉन्फ़िगरेशन फ़ाइल (proguard.txt) में जोड़ दिया जाता है.

    अपनी लाइब्रेरी मॉड्यूल में ProGuard फ़ाइल जोड़कर, यह पक्का किया जा सकता है कि आपकी लाइब्रेरी पर निर्भर ऐप्लिकेशन मॉड्यूल को, आपकी लाइब्रेरी का इस्तेमाल करने के लिए, अपनी ProGuard फ़ाइलों को मैन्युअल तरीके से अपडेट करने की ज़रूरत न पड़े. जब Android Studio का बिल्ड सिस्टम आपका ऐप्लिकेशन बनाता है, तो वह ऐप्लिकेशन मॉड्यूल और लाइब्रेरी, दोनों के निर्देशों का इस्तेमाल करता है. इसलिए, लाइब्रेरी पर कोड छोटा करने वाले टूल को अलग से चलाने की ज़रूरत नहीं है.

    अपने लाइब्रेरी प्रोजेक्ट में ProGuard के नियम जोड़ने के लिए, अपनी लाइब्रेरी की build.gradle या build.gradle.kts फ़ाइल के defaultConfig ब्लॉक में, consumerProguardFiles प्रॉपर्टी के साथ फ़ाइल का नाम बताएं.

    उदाहरण के लिए, यहां दिया गया स्निपेट, lib-proguard-rules.txt को लाइब्रेरी की ProGuard कॉन्फ़िगरेशन फ़ाइल के तौर पर सेट करता है:

    Groovy

    android {
        defaultConfig {
            consumerProguardFiles 'lib-proguard-rules.txt'
        }
        ...
    }

    Kotlin

    android {
        defaultConfig {
            consumerProguardFiles("lib-proguard-rules.txt")
        }
        ...
    }

    हालांकि, अगर आपका लाइब्रेरी मॉड्यूल, कई मॉड्यूल वाले ऐसे बिल्ड का हिस्सा है जो एपीके में कंपाइल होता है और AAR जनरेट नहीं करता, तो सिर्फ़ उस ऐप्लिकेशन मॉड्यूल पर कोड को छोटा करें जो लाइब्रेरी का इस्तेमाल करता है. ProGuard के नियमों और उनके इस्तेमाल के बारे में ज़्यादा जानने के लिए, अपने ऐप्लिकेशन को छोटा करना, उसे समझने में मुश्किल बनाना, और ऑप्टिमाइज़ करना लेख पढ़ें.

  • किसी लाइब्रेरी मॉड्यूल की जांच करना, किसी ऐप्लिकेशन की जांच करने जैसा ही है.

    इनमें मुख्य अंतर यह है कि लाइब्रेरी और उसकी डिपेंडेंसी, जांच के APK की डिपेंडेंसी के तौर पर अपने-आप शामिल हो जाती हैं. इसका मतलब है कि टेस्ट APK में न सिर्फ़ उसका कोड शामिल होता है, बल्कि लाइब्रेरी का AAR और उसकी सभी डिपेंडेंसी भी शामिल होती हैं. टेस्ट में कोई अलग ऐप्लिकेशन नहीं है, इसलिए androidTest टास्क सिर्फ़ टेस्ट APK को इंस्टॉल (और अनइंस्टॉल) करता है.

    एक से ज़्यादा मेनिफ़ेस्ट फ़ाइलों को मर्ज करते समय, Gradle डिफ़ॉल्ट प्राथमिकता क्रम का पालन करता है और लाइब्रेरी के मेनिफ़ेस्ट को टेस्ट APK के मुख्य मेनिफ़ेस्ट में मर्ज करता है.

एएआर फ़ाइल की बनावट

AAR फ़ाइल का फ़ाइल एक्सटेंशन .aar होता है. साथ ही, Maven आर्टफ़ैक्ट का टाइप भी aar होता है. फ़ाइल, खुद एक ZIP फ़ाइल हो. सिर्फ़ /AndroidManifest.xml को भरना ज़रूरी है.

AAR फ़ाइल में, यहां दी गई एक या उससे ज़्यादा वैकल्पिक एंट्री भी शामिल की जा सकती हैं: