अपना बिल्ड कॉन्फ़िगर करें

Android बिल्ड सिस्टम, ऐप्लिकेशन के संसाधनों और सोर्स कोड को संकलित करता है और उन्हें APK या Android ऐप्लिकेशन बंडल में पैकेज करता है. इनका इस्तेमाल, टेस्ट करने, डिप्लॉय करने, साइन करने, और डिस्ट्रिब्यूट करने के लिए किया जा सकता है.

Gradle बिल्ड की खास जानकारी और Android बिल्ड का स्ट्रक्चर में, हमने बिल्ड के कॉन्सेप्ट और Android ऐप्लिकेशन के स्ट्रक्चर के बारे में बात की थी. अब बिल्ड को कॉन्फ़िगर करने का समय आ गया है.

Android बिल्ड से जुड़ी शब्दावली

Gradle और Android Gradle प्लग इन की मदद से, अपने बिल्ड के इन पहलुओं को कॉन्फ़िगर किया जा सकता है:

बिल्ड टाइप

बिल्ड टाइप से कुछ ऐसी प्रॉपर्टी के बारे में पता चलता है जिनका इस्तेमाल Gradle, आपका ऐप्लिकेशन बनाते और उसकी पैकेजिंग करते समय करता है. आम तौर पर, बिल्ड टाइप आपके डेवलपमेंट लाइफ़साइकल के अलग-अलग चरणों के लिए कॉन्फ़िगर किए जाते हैं.

उदाहरण के लिए, डीबग बिल्ड टाइप, डीबग के विकल्पों को चालू करता है और डीबग पासकोड से ऐप्लिकेशन को साइन करता है. वहीं, रिलीज़ बिल्ड टाइप छोटा हो सकता है, अस्पष्ट हो सकता है, और आपके ऐप्लिकेशन को डिस्ट्रिब्यूशन के लिए रिलीज़ पासकोड से साइन कर सकता है.

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

प्रॉडक्ट के फ़्लेवर
प्रॉडक्ट फ़्लेवर, आपके ऐप्लिकेशन के उन अलग-अलग वर्शन के बारे में बताते हैं जिन्हें उपयोगकर्ताओं के लिए रिलीज़ किया जा सकता है. जैसे, मुफ़्त और पैसे चुकाकर डाउनलोड किए जाने वाले वर्शन. आपके पास प्रॉडक्ट के अलग-अलग वर्शन को पसंद के मुताबिक बनाने का विकल्प होता है. इससे, ऐप्लिकेशन के सभी वर्शन में मौजूद कॉड और संसाधनों को शेयर करने और फिर से इस्तेमाल करने के साथ-साथ, अलग-अलग कोड और संसाधनों का इस्तेमाल किया जा सकता है. प्रॉडक्ट के अलग-अलग वर्शन बनाना ज़रूरी नहीं है. इन्हें मैन्युअल तरीके से बनाया जाना चाहिए. अपने ऐप्लिकेशन के अलग-अलग वर्शन बनाने के लिए, प्रॉडक्ट के फ़्लेवर को कॉन्फ़िगर करने का तरीका जानें.
वैरिएंट बनाना
बिल्ड वैरिएंट, बिल्ड टाइप और प्रॉडक्ट फ़्लेवर का क्रॉस-प्रॉडक्ट होता है. साथ ही, यह वह कॉन्फ़िगरेशन होता है जिसका इस्तेमाल Gradle आपके ऐप्लिकेशन को बनाने के लिए करता है. बिल्ड वैरिएंट का इस्तेमाल करके, डेवलपमेंट के दौरान अपने प्रॉडक्ट फ़्लेवर का डीबग वर्शन और डिस्ट्रिब्यूशन के लिए, अपने प्रॉडक्ट फ़्लेवर के साइन किए गए रिलीज़ वर्शन बनाए जा सकते हैं. हालांकि, सीधे तौर पर बिल्ड वैरिएंट को कॉन्फ़िगर नहीं किया जाता, लेकिन उनसे बने बिल्ड टाइप और प्रॉडक्ट फ़्लेवर को कॉन्फ़िगर किया जाता है. अन्य बिल्ड टाइप या प्रॉडक्ट के फ़्लेवर तय करने से, बिल्ड के अन्य वैरिएंट भी बन जाते हैं. बिल्ड वैरिएंट बनाने और मैनेज करने का तरीका जानने के लिए, बिल्ड वैरिएंट कॉन्फ़िगर करें से जुड़ी खास जानकारी पढ़ें.
मेनिफ़ेस्ट एंट्री
बिल्ड के वैरिएंट कॉन्फ़िगरेशन में, मेनिफ़ेस्ट फ़ाइल की कुछ प्रॉपर्टी के लिए वैल्यू तय की जा सकती है. ये बिल्ड वैल्यू, मेनिफ़ेस्ट फ़ाइल में मौजूद वैल्यू को बदल देती हैं. यह तब फ़ायदेमंद होता है, जब आपको अपने ऐप्लिकेशन के कई वैरिएंट जनरेट करने हों. इसके लिए, ऐप्लिकेशन का कोई दूसरा नाम, SDK टूल का कम से कम वर्शन या SDK टूल का टारगेट वर्शन इस्तेमाल किया जा सकता है. एक से ज़्यादा मेनिफ़ेस्ट मौजूद होने पर, मेनिफ़ेस्ट मर्जर टूल, मेनिफ़ेस्ट सेटिंग को मर्ज करता है.
डिपेंडेंसी
बिल्ड सिस्टम, आपके लोकल फ़ाइल सिस्टम और रिमोट रिपॉज़िटरी से प्रोजेक्ट की डिपेंडेंसी मैनेज करता है. इसका मतलब है कि आपको अपनी प्रोजेक्ट डायरेक्ट्री में, अपनी डिपेंडेंसी के बाइनरी पैकेज को मैन्युअल तरीके से खोजने, डाउनलोड करने, और कॉपी करने की ज़रूरत नहीं है. ज़्यादा जानने के लिए, बिल्ड के लिए ज़रूरी लाइब्रेरी जोड़ना लेख पढ़ें.
साइन इन करना
बिल्ड सिस्टम आपको बिल्ड कॉन्फ़िगरेशन में साइनिंग सेटिंग तय करने की सुविधा देता है. इससे, बिल्ड प्रोसेस के दौरान आपके ऐप्लिकेशन को अपने-आप साइन कर दिया जाता है. बिल्ड सिस्टम, डिबग वर्शन को डिफ़ॉल्ट कुंजी और सर्टिफ़िकेट के साथ साइन करता है. इसके लिए, वह पहले से मौजूद क्रेडेंशियल का इस्तेमाल करता है, ताकि बिल्ड के समय पासवर्ड डालने के लिए कहा न जाए. बिल्ड सिस्टम तब तक रिलीज़ वर्शन पर साइन नहीं करता, जब तक कि इस बिल्ड के लिए साइनिंग कॉन्फ़िगरेशन के बारे में साफ़ तौर पर नहीं बताया जाता. अगर आपके पास रिलीज़ पासकोड नहीं है, तो अपने ऐप्लिकेशन पर हस्ताक्षर करें में बताए गए तरीके से एक पासकोड जनरेट किया जा सकता है. ज़्यादातर ऐप्लिकेशन स्टोर पर ऐप्लिकेशन उपलब्ध कराने के लिए, हस्ताक्षर किए गए रिलीज़ बिल्ड ज़रूरी होते हैं.
कोड और रिसॉर्स को छोटा करना
बिल्ड सिस्टम की मदद से, हर बिल्ड वैरिएंट के लिए ProGuard के नियमों की अलग-अलग फ़ाइल तय की जा सकती है. आपका ऐप्लिकेशन बनाते समय, बिल्ड सिस्टम नियमों के सही सेट को लागू करता है, ताकि R8 जैसे पहले से मौजूद, छोटा करने वाले टूल का इस्तेमाल करके आपके कोड और संसाधनों को छोटा किया जा सके. अपने कोड और संसाधनों को छोटा करने से, APK या एएबी का साइज़ कम करने में मदद मिल सकती है.
एक से ज़्यादा APK काम करते हैं
बिल्ड सिस्टम की मदद से, अलग-अलग APK अपने-आप बन जाते हैं. इनमें से हर APK में, सिर्फ़ किसी खास स्क्रीन डेंसिटी या ऐप्लिकेशन बाइनरी इंटरफ़ेस (एबीआई) के लिए ज़रूरी कोड और संसाधन होते हैं. ज़्यादा जानकारी के लिए, एक से ज़्यादा APK बनाना लेख पढ़ें. हालांकि, एक एएबी रिलीज़ करने का सुझाव दिया जाता है. ऐसा इसलिए, क्योंकि यह स्क्रीन की सघनता और एबीआई के साथ-साथ, भाषा के हिसाब से बांटने की सुविधा देता है. साथ ही, Google Play पर कई आर्टफ़ैक्ट अपलोड करने की ज़रूरत नहीं पड़ती. अगस्त 2021 के बाद सबमिट किए गए सभी नए ऐप्लिकेशन के लिए, AAB का इस्तेमाल करना ज़रूरी है.

Android बिल्ड में Java वर्शन

भले ही, आपका सोर्स कोड Java, Kotlin या दोनों में लिखा गया हो, फिर भी आपको अपने बिल्ड के लिए JDK या Java भाषा का वर्शन चुनना होगा. ज़्यादा जानकारी के लिए, Android बिल्ड में Java के वर्शन देखें.

कॉन्फ़िगरेशन फ़ाइलें बनाना

कस्टम बिल्ड कॉन्फ़िगरेशन बनाने के लिए, आपको एक या उससे ज़्यादा बिल्ड कॉन्फ़िगरेशन फ़ाइलों में बदलाव करने होंगे. सादे टेक्स्ट वाली ये फ़ाइलें, डोमेन के हिसाब से खास भाषा (डीएसएल) का इस्तेमाल करती हैं. इसकी मदद से, Kotlin स्क्रिप्ट का इस्तेमाल करके बिल्ड लॉजिक के बारे में जानकारी दी जाती है और उसमें बदलाव किया जाता है. यह Kotlin लैंग्वेज का एक बेहतरीन वर्शन है. अपने बिल्ड कॉन्फ़िगर करने के लिए, Groovy का भी इस्तेमाल किया जा सकता है. यह Java Virtual Machine (JVM) भाषा के लिए एक डाइनैमिक भाषा है.

अपने बिल्ड को कॉन्फ़िगर करना शुरू करने के लिए, आपको Kotlin स्क्रिप्ट या ग्रूवी के बारे में जानने की ज़रूरत नहीं है, क्योंकि 'Android Gradle प्लग इन' में आपकी ज़रूरत के ज़्यादातर डीएसएल एलिमेंट मौजूद होते हैं. Android Gradle प्लग-इन DSL के बारे में ज़्यादा जानने के लिए, DSL के रेफ़रंस दस्तावेज़ पढ़ें. Kotlin स्क्रिप्ट, Gradle Kotlin डीएसएल पर भी निर्भर करती है

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

Gradle Wrapper फ़ाइल

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

gradle/wrapper/gradle-wrapper.properties फ़ाइल में एक प्रॉपर्टी, distributionUrl होती है. इससे पता चलता है कि आपके बिल्ड को चलाने के लिए, Gradle के किस वर्शन का इस्तेमाल किया जाता है.

distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.0-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists

Gradle की सेटिंग फ़ाइल

settings.gradle.kts फ़ाइल (Kotlin DSL के लिए) या settings.gradle फ़ाइल (Groovy DSL के लिए), प्रोजेक्ट की रूट डायरेक्ट्री में होती है. यह सेटिंग फ़ाइल, प्रोजेक्ट-लेवल की रिपॉज़िटरी सेटिंग तय करती है और Gradle को बताती है कि आपके ऐप्लिकेशन को बिल्ड करते समय किन मॉड्यूल को शामिल करना चाहिए. कई मॉड्यूल वाले प्रोजेक्ट के लिए, हर उस मॉड्यूल की जानकारी देनी ज़रूरी है जिसे फ़ाइनल बिल्ड में शामिल करना है.

ज़्यादातर प्रोजेक्ट के लिए, फ़ाइल डिफ़ॉल्ट रूप से कुछ इस तरह दिखती है:

Kotlin

pluginManagement {

    /**
      * The pluginManagement.repositories block configures the
      * repositories Gradle uses to search or download the Gradle plugins and
      * their transitive dependencies. Gradle pre-configures support for remote
      * repositories such as JCenter, Maven Central, and Ivy. You can also use
      * local repositories or define your own remote repositories. Here we
      * define the Gradle Plugin Portal, Google's Maven repository,
      * and the Maven Central Repository as the repositories Gradle should use to look for its
      * dependencies.
      */

    repositories {
        gradlePluginPortal()
        google()
        mavenCentral()
    }
}
dependencyResolutionManagement {

    /**
      * The dependencyResolutionManagement.repositories
      * block is where you configure the repositories and dependencies used by
      * all modules in your project, such as libraries that you are using to
      * create your application. However, you should configure module-specific
      * dependencies in each module-level build.gradle file. For new projects,
      * Android Studio includes Google's Maven repository and the Maven Central
      * Repository by default, but it does not configure any dependencies (unless
      * you select a template that requires some).
      */

  repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
  repositories {
      google()
      mavenCentral()
  }
}
rootProject.name = "My Application"
include(":app")

ग्रूवी

pluginManagement {

    /**
      * The pluginManagement.repositories block configures the
      * repositories Gradle uses to search or download the Gradle plugins and
      * their transitive dependencies. Gradle pre-configures support for remote
      * repositories such as JCenter, Maven Central, and Ivy. You can also use
      * local repositories or define your own remote repositories. Here we
      * define the Gradle Plugin Portal, Google's Maven repository,
      * and the Maven Central Repository as the repositories Gradle should use to look for its
      * dependencies.
      */

    repositories {
        gradlePluginPortal()
        google()
        mavenCentral()
    }
}
dependencyResolutionManagement {

    /**
      * The dependencyResolutionManagement.repositories
      * block is where you configure the repositories and dependencies used by
      * all modules in your project, such as libraries that you are using to
      * create your application. However, you should configure module-specific
      * dependencies in each module-level build.gradle file. For new projects,
      * Android Studio includes Google's Maven repository and the Maven Central
      * Repository by default, but it does not configure any dependencies (unless
      * you select a template that requires some).
      */

    repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
    repositories {
        google()
        mavenCentral()
    }
}
rootProject.name = "My Application"
include ':app'

टॉप-लेवल की बिल्ड फ़ाइल

Kotlin DSL के लिए टॉप-लेवल build.gradle.kts फ़ाइल या Groovy DSL के लिए build.gradle फ़ाइल, प्रोजेक्ट की रूट डायरेक्ट्री में होती है. आम तौर पर, यह आपके प्रोजेक्ट में मॉड्यूल के इस्तेमाल किए जाने वाले प्लग इन के सामान्य वर्शन तय करता है.

यहां दिए गए कोड सैंपल में, नया प्रोजेक्ट बनाने के बाद, टॉप-लेवल वाली बिल्ड स्क्रिप्ट में मौजूद डिफ़ॉल्ट सेटिंग और डीएसएल एलिमेंट के बारे में बताया गया है:

Kotlin

plugins {

    /**
     * Use `apply false` in the top-level build.gradle file to add a Gradle
     * plugin as a build dependency but not apply it to the current (root)
     * project. Don't use `apply false` in sub-projects. For more information,
     * see Applying external plugins with same version to subprojects.
     */

    id("com.android.application") version "8.7.0" apply false
    id("com.android.library") version "8.7.0" apply false
    id("org.jetbrains.kotlin.android") version "2.0.20" apply false
}

Groovy

plugins {

    /**
     * Use `apply false` in the top-level build.gradle file to add a Gradle
     * plugin as a build dependency but not apply it to the current (root)
     * project. Don't use `apply false` in sub-projects. For more information,
     * see Applying external plugins with same version to subprojects.
     */

    id 'com.android.application' version '8.7.0' apply false
    id 'com.android.library' version '8.7.0' apply false
    id 'org.jetbrains.kotlin.android' version '2.0.20' apply false
}