पब्लिकेशन के वैरिएंट की मदद से, उपयोगकर्ताओं को उनकी पसंद के मुताबिक अनुभव दिया जा सकता है. पब्लिकेशन के वैरिएंट कॉन्फ़िगर करके, बिल्ड के अलग-अलग वैरिएंट पब्लिश किए जा सकते हैं. और हर एक एट्रिब्यूट की वैल्यू शामिल करें.
अपनी लाइब्रेरी के कई बिल्ड वैरिएंट पब्लिश करने से, उपयोगकर्ता उनकी ज़रूरतों के हिसाब से सही सुविधाएं चुन सकें. उदाहरण के लिए, आप अलग-अलग आर्टफ़ैक्ट डीबग बनाम रिलीज़ बिल्ड टाइप. डीबग पब्लिकेशन आर्टफ़ैक्ट में अतिरिक्त लॉगिंग कोड हो सकता है और अलग-अलग डिपेंडेंसी का इस्तेमाल करके इस अतिरिक्त लॉगिंग को चालू किया जा सकता है.
आगे बढ़ने से पहले, पक्का करें कि रिलीज़ के लिए अपनी लाइब्रेरी तैयार करना.
Gradle मॉड्यूल मेटाडेटा इस्तेमाल करना
अपनी लाइब्रेरी के वैरिएंट पब्लिश करने के लिए, Gradle मॉड्यूल मेटाडेटा (GMM). GMM आपके पब्लिकेशन के बारे में बताता है और उसका रखरखाव करता है वैरिएंट-अवेयर डिपेंडेंसी मैनेजमेंट. GMM, डिफ़ॉल्ट रूप से आपकी लाइब्रेरी के साथ प्रकाशित होता है.
GMM के इस्तेमाल के फ़ायदे:
- अगर Gradle 6.0 या इसके बाद के वर्शन के साथ GMM का इस्तेमाल किया जा रहा है, तो आपके पास एक से ज़्यादा पब्लिकेशन पब्लिश करने का विकल्प है वैरिएंट या कई आर्टफ़ैक्ट शामिल हों—हर एक एट्रिब्यूट की अपनी-अपनी विशेषताएं और डिपेंडेंसी हो. अगर Maven की पीओएम फ़ाइल का इस्तेमाल किया जाता है GMM की जगह पर, सिर्फ़ एक आर्टफ़ैक्ट पब्लिश किया जा सकता है. पीओएम फ़ाइल का इस्तेमाल करने पर, की कैटगरी तय करने वाले टूल का इस्तेमाल करके, अतिरिक्त आर्टफ़ैक्ट पब्लिश किए जा सकते हैं. हालांकि, अतिरिक्त आर्टफ़ैक्ट अपनी डिपेंडेंसी नहीं हो सकती.
- Gradle अपने-आप, कंपाइलेशन के लिए एक और रनटाइम के लिए एक वैरिएंट बना देता है.
पर निर्भर करता है. कंपाइलेशन के लिए एक वैरिएंट पब्लिश किया जा सकता है
और एक रनटाइम के लिए, ताकि उपभोक्ता अपने हिसाब से चुन सकें कि वे कब इस्तेमाल कर रहे हैं
आपकी लाइब्रेरी पर टैप करें. जीएमएम की मदद से उपभोक्ता, कंपाइल और टोन के लिए अलग-अलग डिपेंडेंसी देख सकते हैं
रनटाइम, जो कि पब्लिश की गई लाइब्रेरी के इस्तेमाल के आधार पर तय होता है
api
,implementation
याcompileOnly
/runtimeOnly
. यहां जाएं: डिपेंडेंसी कॉन्फ़िगरेशन देखें. यह तब भी उपलब्ध रहता है, जब पब्लिकेशन का वैरिएंट. - टेस्ट फ़िक्स्चर का इस्तेमाल करते समय, एक खास मेटाडेटा या क्षमताएं ताकि उपभोक्ता उसे चुन सके. यह तब भी उपलब्ध रहता है, जब पब्लिकेशन का एक वैरिएंट.
पब्लिकेशन के वैरिएंट को समझना
पब्लिकेशन के वैरिएंट कैसे काम करते हैं, यह समझने के लिए ज़रूरी है कि ग्रेडल पब्लिश करने के बुनियादी तरीके देखें. प्रकाशन से जुड़े कुछ मुख्य सिद्धांत यहां दिए गए हैं:
- वैरिएंट बनाना: कॉन्फ़िगरेशन Gradle आपकी लाइब्रेरी बनाने के लिए इस्तेमाल करता है, जो बिल्ड टाइप और प्रॉडक्ट फ़्लेवर का क्रॉस प्रॉडक्ट है. ज़्यादा जानने के लिए, यह देखें Android बिल्ड ग्लॉसरी.
- आर्टफ़ैक्ट: बिल्ड के ज़रिए बनाई जाने वाली फ़ाइल या डायरेक्ट्री. लाइब्रेरी पब्लिश करने के संदर्भ में, आर्टफ़ैक्ट आम तौर पर एक JAR या AAR फ़ाइल होती है.
- पब्लिकेशन का वैरिएंट: एक आर्टफ़ैक्ट, जो इससे जुड़े एट्रिब्यूट, फ़ीचर, और डिपेंडेंसी है. नोट जोड़ें जिसे Gradle, पब्लिकेशन के वैरिएंट के वैरिएंट को कॉल करता है. हालांकि, उन्हें पब्लिकेशन के वैरिएंट: बिल्ड वैरिएंट के साथ भी काम कर सकते हैं.
- एट्रिब्यूट:
पब्लिकेशन के वैरिएंट की पहचान करने और उन्हें चुनने के लिए, Gradle, एट्रिब्यूट का इस्तेमाल करता है
कई विकल्प हैं. उदाहरण के लिए,
org.gradle.usage=java-api
औरorg.gradle.jvm.version=11
, वैरिएंट के एट्रिब्यूट हैं. - सॉफ़्टवेयर का कॉम्पोनेंट:
ऐसा Gradle ऑब्जेक्ट जो पब्लिश होने के बाद, पब्लिकेशन के एक या उससे ज़्यादा वैरिएंट को होल्ड कर सकता है
Maven कोऑर्डिनेट के एक सेट (
groupdId:artifactId:version
) का इस्तेमाल करता है. हां के ज़रिए Gradle के DSL से जुड़ेProject.getComponents()
. - पब्लिकेशन:
डेटा स्टोर करने की जगह और उपभोक्ता इस्तेमाल करने के लिए पब्लिश किया जाता है. पब्लिकेशन में ये शामिल हैं
सॉफ़्टवेयर के किसी एक कॉम्पोनेंट और उसके मेटाडेटा के बारे में बताना चाहिए. उदाहरण के लिए, उसकी पहचान
(
groupId:artifactId:version
).
Android Gradle प्लग इन (AGP) 7.1
किसी खास डोमेन के लिए भाषा (DSL) की मदद से यह कंट्रोल किया जा सकता है कि
पब्लिकेशन और जिन्हें अनदेखा किया जाता है. DSL से आपको
SoftwareComponent
, जिसमें इनमें से कोई एक शामिल हो:
- बिल्ड के एक वैरिएंट से पब्लिकेशन का एक वैरिएंट
- बिल्ड के अलग-अलग वैरिएंट में से, पब्लिकेशन के कई वैरिएंट
पब्लिकेशन के कई वैरिएंट वाला सॉफ़्टवेयर कॉम्पोनेंट बनाते समय, एजीपी सेट हर वैरिएंट के लिए एट्रिब्यूट चुनें, ताकि उपयोगकर्ता उनकी ज़रूरत के मुताबिक वैरिएंट चुनना. ये एट्रिब्यूट सीधे बिल्ड से मिलते हैं बिल्ड वैरिएंट बनाने के लिए इस्तेमाल किए गए टाइप और फ़्लेवर की जानकारी. किसी सिंगल पब्लिकेशन वैरिएंट वाले कॉम्पोनेंट के लिए एट्रिब्यूट की ज़रूरत नहीं है, क्योंकि फ़र्क़ करने की कोई ज़रूरत नहीं है.
पब्लिकेशन के एक वैरिएंट वाला सॉफ़्टवेयर कॉम्पोनेंट बनाना
नीचे दिया गया स्निपेट एक सॉफ़्टवेयर कॉम्पोनेंट को एक पब्लिकेशन के साथ कॉन्फ़िगर करता है
release
बिल्ड वैरिएंट से बनाया गया वैरिएंट और सोर्स JAR को
सेकंडरी आर्टफ़ैक्ट:
Kotlin
android { publishing { singleVariant("release") { withSourcesJar() } } }
ग्रूवी
android { publishing { singleVariant('release') { withSourcesJar() } } }
कई कॉम्पोनेंट बनाए जा सकते हैं, जिनमें से हर एक कॉम्पोनेंट को एक पब्लिकेशन वैरिएंट के साथ बनाया जा सकता है और
उन्हें अलग-अलग Maven कोऑर्डिनेट के तहत डिस्ट्रिब्यूट किया जा सकता है. इस मामले में, एट्रिब्यूट
पब्लिकेशन के वैरिएंट पर सेट नहीं किए जाते. यह नहीं बताया जा सकता कि यह पब्लिकेशन
यह वैरिएंट, release
बिल्ड वैरिएंट से है. इसके लिए, पब्लिकेशन पेज को देखें
मेटाडेटा. पब्लिकेशन का सिर्फ़ एक वैरिएंट शामिल है. इसलिए, इसकी ज़रूरत नहीं है
ताकि साफ़ तौर पर समझ सकें.
पब्लिकेशन के कई वैरिएंट वाला सॉफ़्टवेयर कॉम्पोनेंट बनाएं
किसी सॉफ़्टवेयर को इंस्टॉल करने के लिए, सभी बिल्ड वैरिएंट या उनके कुछ वैरिएंट को एक साथ चुना जा सकता है कॉम्पोनेंट. AGP में, बिल्ड टाइप के नाम और प्रॉडक्ट के फ़्लेवर का इस्तेमाल अपने-आप किया जाता है नाम और प्रॉडक्ट फ़्लेवर वाले डाइमेंशन का नाम शामिल करें, ताकि एट्रिब्यूट इस्तेमाल करने वाले प्रोजेक्ट से इनके बीच अंतर किया जा सकता है.
बिल्ड के सभी वैरिएंट को एक ही कॉम्पोनेंट में पब्लिश करने के लिए, allVariants()
तय करें
मॉड्यूल-लेवल की build.gradle
फ़ाइल में, multipleVariants{}
ब्लॉक में:
Kotlin
android { publishing { multipleVariants { allVariants() withJavadocJar() } } }
ग्रूवी
android { publishing { multipleVariants { allVariants() withJavadocJar() } } }
इससे default
नाम का एक कॉम्पोनेंट बनता है. अपने कॉम्पोनेंट को नाम देने के लिए
कुछ और, multipleVariants({name})
का इस्तेमाल करें.
इस मामले में, बिल्ड टाइप और प्रॉडक्ट के फ़्लेवर वाले सभी डाइमेंशन का इस्तेमाल इस तरह किया जाता है
एट्रिब्यूट.
यह भी चुना जा सकता है कि कौनसे वैरिएंट पब्लिश किए जाएं. इसके लिए,
includeBuildTypeValues()
और includeFlavorDimensionAndValues()
:
Kotlin
android { publishing { multipleVariants("custom") { includeBuildTypeValues("debug", "release") includeFlavorDimensionAndValues( dimension = "color", values = arrayOf("blue", "pink") ) includeFlavorDimensionAndValues( dimension = "shape", values = arrayOf("square") ) } } }
ग्रूवी
android { publishing { multipleVariants('custom') { includeBuildTypeValues('debug', 'release') includeFlavorDimensionAndValues( /*dimension =*/ 'color', /*values =*/ 'blue', 'pink' ) includeFlavorDimensionAndValues( /*dimension =*/ 'shape', /*values =*/ 'square' ) } } }
इस उदाहरण में, कस्टम घटक में
बिल्ड टाइप के लिए (debug
, release
), डाइमेंशन color
के लिए (blue
, pink
),
और (square
) आयाम shape
के लिए .
सभी फ़्लेवर डाइमेंशन को सूची में डालना ज़रूरी है, भले ही आप सिर्फ़ एक वैल्यू पब्लिश कर रहे हों किया जाता है, ताकि AGP को हर डाइमेंशन के लिए इस्तेमाल की जाने वाली वैल्यू पता चल सके.
नीचे दी गई टेबल में, पब्लिकेशन के वैरिएंट और उनके एट्रिब्यूट की वैल्यू सबमिट करें.
वैरिएंट | विशेषताएं |
---|---|
blueSquareDebug | com.android.build.api.attributes.BuildTypeAttr ="debug"
com.android.build.api.attributes.ProductFlavorAttr:color ="blue" |
blueSquareRelease |
com.android.build.api.attributes.BuildTypeAttr="release"
|
pinkSquareDebug |
com.android.build.api.attributes.BuildTypeAttr="debug"
|
pinkSquareRelease |
com.android.build.api.attributes.BuildTypeAttr="release"
|
व्यावहारिक तौर पर, ज़्यादा वैरिएंट पब्लिश किए जाते हैं. उदाहरण के लिए,
ऊपर दिए गए हर वैरिएंट को दो बार पब्लिश किया जाता है. एक बार कंपाइलेशन के लिए और एक बार पब्लिश करने के लिए
रनटाइम, जिसमें अलग-अलग डिपेंडेंसी के साथ-साथ, एलान की गई डिपेंडेंसी के आधार पर
implementation
या api
का इस्तेमाल करें) और एट्रिब्यूट के लिए किसी दूसरी वैल्यू का इस्तेमाल करें
org.gradle.Usage
. हालांकि, इन दोनों वैरिएंट के लिए आर्टफ़ैक्ट (एएआर फ़ाइल)
एक जैसा.
ज़्यादा जानकारी के लिए, देखें
publishing
एपीआई दस्तावेज़.
अलग-अलग तरह की लाइब्रेरी पब्लिश करने पर काम करने से जुड़ी समस्या
एजीपी 7.0 या इससे पहले के वर्शन का इस्तेमाल करने वाले प्रोजेक्ट में, पब्लिश की गई अलग-अलग तरह की लाइब्रेरी का इस्तेमाल नहीं किया जा सकता
AGP 7.1 या इससे ऊपर के वर्शन के साथ. यह एक आम समस्या है, जो एट्रिब्यूट में बदलाव करने की वजह से हुई है
प्रॉडक्ट फ़्लेवर वाले डाइमेंशन का नाम, dimensionName
से बदलकर
एजीपी 7.1 में com.android.build.api.attributes.ProductFlavor:dimensionName
.
अपने प्रोजेक्ट सेटअप के आधार पर, missingDimensionStrategy
का इस्तेमाल इसमें किया जा सकता है
काम करने के लिए, एपीआई का पुराना वर्शन इस्तेमाल करें
समस्या को हल करने में मदद मिलेगी.
उदाहरण के लिए, मान लें कि आपके ऐप्लिकेशन प्रोजेक्ट का केवल एक वर्शन प्रॉडक्ट है फ़्लेवर डाइमेंशन:
Kotlin
android {
applicationVariants.forEach { variant ->
val flavor = variant.productFlavors[0].name
val attributePrefix = "com.android.build.api.attributes.ProductFlavor"
val dimensionName = "version"
variant.missingDimensionStrategy("$attributePrefix:$dimensionName", flavor)
}
}
ग्रूवी
android {
applicationVariants.forEach { variant ->
def flavor = variant.getProductFlavors()[0].name
def attributePrefix = "com.android.build.api.attributes.ProductFlavor"
def dimensionName = "version"
variant.missingDimensionStrategy("$attributePrefix:$dimensionName", flavor)
}
}