Android प्लैटफ़ॉर्म में, शेयर की गई बड़ी संख्या में Java लाइब्रेरी मौजूद होती हैं. इन्हें ऐप्लिकेशन के मेनिफ़ेस्ट में <uses-library> टैग के साथ, ऐप्लिकेशन के क्लासपाथ में शामिल किया जा सकता है. हालांकि, ऐसा करना ज़रूरी नहीं है. ऐप्लिकेशन इन लाइब्रेरी के साथ लिंक होते हैं. इसलिए, इन लाइब्रेरी को काम करने के साथ-साथ, एपीआई की समीक्षा और टूल के लिए सहायता के मामले में, बाकी Android एपीआई की तरह ही माना जाता है. हालांकि, ध्यान दें कि ज़्यादातर लाइब्रेरी में ये सुविधाएं नहीं होती हैं.
java_sdk_library मॉड्यूल टाइप, इस तरह की लाइब्रेरी मैनेज करने में मदद करता है. डिवाइस बनाने वाली कंपनियां, अपने एपीआई के लिए पुराने सिस्टम के साथ काम करने की सुविधा बनाए रखने के लिए, अपनी शेयर की गई Java लाइब्रेरी के लिए इस तरीके का इस्तेमाल कर सकती हैं.
अगर डिवाइस बनाने वाली कंपनियां, बूटक्लास पाथ के बजाय
<uses-library> टैग के ज़रिए अपनी शेयर की गई Java लाइब्रेरी का इस्तेमाल करती हैं, तो
java_sdk_library इस बात की पुष्टि कर सकता है कि वे Java लाइब्रेरी, एपीआई के हिसाब से सही हैं.
java_sdk_library, ऐप्लिकेशन के इस्तेमाल के लिए वैकल्पिक SDK टूल के एपीआई लागू करता है. आपकी बिल्ड फ़ाइल (Android.bp) में java_sdk_library के ज़रिए लागू की गई लाइब्रेरी, ये कार्रवाइयां करती हैं:
- स्टब लाइब्रेरी,
stubs,stubs.system, औरstubs.testको शामिल करने के लिए जनरेट की जाती हैं. ये स्टब लाइब्रेरी,@hide,@SystemApi, और@TestApiएनोटेशन की पहचान करके बनाई जाती हैं. java_sdk_library, एपीआई की सबडायरेक्ट्री में एपीआई स्पेसिफ़िकेशन फ़ाइलों (जैसे,current.txt) को मैनेज करता है. इन फ़ाइलों की जांच, सबसे नए कोड के साथ की जाती है, ताकि यह पक्का किया जा सके कि ये फ़ाइलें सबसे नए वर्शन हैं. अगर ऐसा नहीं होता है, तो आपको गड़बड़ी का एक मैसेज मिलेगा. इसमें, उन्हें अपडेट करने का तरीका बताया जाएगा. अपडेट में किए गए सभी बदलावों की मैन्युअल तौर पर समीक्षा करें, ताकि यह पक्का किया जा सके कि वे आपकी उम्मीदों के मुताबिक हैं.
सभी एपीआई को अपडेट करने के लिए,m update-apiका इस्तेमाल करें. यह पुष्टि करने के लिए कि कोई एपीआई अप-टू-डेट है या नहीं,m checkapiका इस्तेमाल करें.- एपीआई की खास जानकारी वाली फ़ाइलों की जांच, हाल ही में पब्लिश किए गए Android वर्शन के साथ की जाती है. इससे यह पक्का किया जाता है कि एपीआई, पुराने वर्शन के साथ काम करता है. AOSP के हिस्से के तौर पर उपलब्ध
java_sdk_libraryमॉड्यूल, पहले रिलीज़ किए गए अपने वर्शन कोprebuilts/sdk/<latest number>में डालते हैं. - एपीआई स्पेसिफ़िकेशन फ़ाइलों की जांच के लिए, इनमें से किसी एक काम को किया जा सकता है:
- जांच जारी रखने की अनुमति दें. (कुछ न करें.)
java_sdk_libraryमें यह जोड़कर, जांच बंद करें:
unsafe_ignore_missing_latest_api: true,version/scope/apiडायरेक्ट्री मेंmodule_name.txtनाम की खाली टेक्स्ट फ़ाइलें बनाकर, नएjava_sdk_libraryमॉड्यूल के लिए खाली एपीआई उपलब्ध कराएं.- अगर रनटाइम के लिए लागू करने की लाइब्रेरी इंस्टॉल है, तो एक एक्सएमएल फ़ाइल जनरेट और इंस्टॉल हो जाती है.
java_sdk_library कैसे काम करती है
X नाम का java_sdk_library, ये बनाता है:
- लागू करने की लाइब्रेरी की दो कॉपी: एक लाइब्रेरी का नाम
Xऔर दूसरी का नामX.implहै. डिवाइस पर लाइब्रेरीXइंस्टॉल हो. लाइब्रेरीX.implसिर्फ़ तब मौजूद होती है, जब दूसरे मॉड्यूल को लागू करने वाली लाइब्रेरी का ऐक्सेस ज़रूरी हो. जैसे, टेस्टिंग में इस्तेमाल करने के लिए. ध्यान दें कि साफ़ तौर पर ऐक्सेस करने की ज़रूरत बहुत कम होती है. - ऐक्सेस को पसंद के मुताबिक बनाने के लिए, स्कोप को चालू और बंद किया जा सकता है. (Java के कीवर्ड-ऐक्सेस मॉडिफ़ायर की तरह ही, सार्वजनिक दायरा कई तरह का ऐक्सेस देता है; टेस्ट दायरे में सिर्फ़ ऐसे एपीआई होते हैं जिनका इस्तेमाल टेस्टिंग में किया जाता है.) चालू किए गए हर स्कोप के लिए, लाइब्रेरी ये चीज़ें बनाती है:
- स्टब सोर्स मॉड्यूल (
droidstubsमॉड्यूल टाइप का) - लागू करने के सोर्स का इस्तेमाल करता है और एपीआई स्पेसिफ़िकेशन फ़ाइल के साथ-साथ स्टब सोर्स का एक सेट आउटपुट करता है. - स्टब लाइब्रेरी (
java_libraryमॉड्यूल टाइप की) - यह स्टब का संकलित वर्शन है. इसे कंपाइल करने के लिए इस्तेमाल की गई लाइब्रेरी,java_sdk_libraryमें इस्तेमाल की गई लाइब्रेरी से अलग होती हैं. इससे यह पक्का होता है कि एपीआई स्टब में, लागू करने की जानकारी लीक न हो. - अगर आपको स्टब को कंपाइल करने के लिए अन्य लाइब्रेरी की ज़रूरत है, तो उन्हें उपलब्ध कराने के लिए
stub_only_libsऔरstub_only_static_libsप्रॉपर्टी का इस्तेमाल करें.
अगर किसी java_sdk_library को “X” कहा जाता है और उसे “X” के तौर पर संकलित किया जा रहा है, तो हमेशा उसी नाम से रेफ़र करें और उसमें बदलाव न करें. बिल्डर, सही लाइब्रेरी चुन लेगा. यह पक्का करने के लिए कि आपके पास सबसे सही लाइब्रेरी है, अपने स्टब की जांच करें. इससे यह पता चलेगा कि बिल्ड में कोई गड़बड़ी तो नहीं हुई है. इस दिशा-निर्देश का इस्तेमाल करके, ज़रूरी बदलाव करें:
- कमांड-लाइन पर जाकर पुष्टि करें कि आपके पास सही लाइब्रेरी है. साथ ही, अपने दायरे का पता लगाने के लिए, देखें कि वहां कौनसे स्टब मौजूद हैं:
- स्कोप बहुत बड़ा है: जिस लाइब्रेरी पर निर्भर किया जा रहा है उसे एपीआई का एक खास स्कोप चाहिए. हालांकि, आपको लाइब्रेरी में ऐसे एपीआई दिखते हैं जो उस दायरे से बाहर के होते हैं. जैसे, सार्वजनिक एपीआई के साथ शामिल सिस्टम एपीआई.
- स्कोप बहुत छोटा है: डिपेंडेंट लाइब्रेरी के पास सभी ज़रूरी लाइब्रेरी का ऐक्सेस नहीं है. उदाहरण के लिए, डिपेंडेंट लाइब्रेरी को सिस्टम एपीआई का इस्तेमाल करना चाहिए, लेकिन उसे सार्वजनिक एपीआई मिलता है. आम तौर पर, इससे कॉम्पाइल करने से जुड़ी गड़बड़ी होती है, क्योंकि ज़रूरी एपीआई मौजूद नहीं होते.
- लाइब्रेरी को ठीक करने के लिए, इनमें से सिर्फ़ एक तरीका अपनाएं:
- अपनी ज़रूरत के हिसाब से वर्शन चुनने के लिए,
sdk_versionको बदलें. या - सही लाइब्रेरी के बारे में साफ़ तौर पर बताएं, जैसे कि
<X>.stubsया<X>.stubs.system.
java_sdk_library X का इस्तेमाल
लागू करने की लाइब्रेरी X का इस्तेमाल तब किया जाता है, जब उसका रेफ़रंस apex.java_libs से दिया जाता है. हालांकि, Soong की एक सीमा के कारण, जब लाइब्रेरी X का रेफ़रंस, एक ही APEX लाइब्रेरी में मौजूद किसी दूसरे java_sdk_library मॉड्यूल से दिया जाता है, तो लाइब्रेरी X के बजाय X.impl का साफ़ तौर पर इस्तेमाल किया जाना चाहिए.
जब java_sdk_library का रेफ़रंस किसी दूसरी जगह से दिया जाता है, तो स्टब
लाइब्रेरी का इस्तेमाल किया जाता है. स्टब लाइब्रेरी, डिपेंडेंट
मॉड्यूल की sdk_version प्रॉपर्टी सेटिंग के हिसाब से चुनी जाती है. उदाहरण के लिए, sdk_version: "current" का इस्तेमाल करने वाला मॉड्यूल, सार्वजनिक स्टब का इस्तेमाल करता है. वहीं, sdk_version: "system_current" का इस्तेमाल करने वाला मॉड्यूल, सिस्टम स्टब का इस्तेमाल करता है. अगर एग्ज़ैक्ट मैच नहीं मिलता है, तो सबसे मिलती-जुलती स्टब लाइब्रेरी का इस्तेमाल किया जाता है. सिर्फ़ सार्वजनिक एपीआई उपलब्ध कराने वाला java_sdk_library, सभी के लिए सार्वजनिक स्टब उपलब्ध कराएगा.
उदाहरण और सोर्स
srcs और api_packages प्रॉपर्टी, java_sdk_library में मौजूद होनी चाहिए.
java_sdk_library { name: "com.android.future.usb.accessory", srcs: ["src/**/*.java"], api_packages: ["com.android.future.usb"], }
AOSP का सुझाव है कि नए java_sdk_library
इंस्टेंस, उन एपीआई स्कोप को साफ़ तौर पर चालू करें जिनका उन्हें इस्तेमाल करना है. हालांकि, ऐसा करना ज़रूरी नहीं है. आपके पास,
मौजूदा java_sdk_library इंस्टेंस को माइग्रेट करने का विकल्प भी है, ताकि
वे एपीआई स्कोप साफ़ तौर पर चालू कर सकें जिनका इस्तेमाल किया जाएगा:
java_sdk_library { name: "lib", public: { enabled: true, }, system: { enabled: true, }, … }
रनटाइम के लिए इस्तेमाल की जाने वाली impl लाइब्रेरी को कॉन्फ़िगर करने के लिए, hostdex,
compile_dex, और errorprone जैसी सभी सामान्य java_library प्रॉपर्टी का इस्तेमाल करें.
java_sdk_library { name: "android.test.base", srcs: ["src/**/*.java"], errorprone: { javacflags: ["-Xep:DepAnn:ERROR"], }, hostdex: true, api_packages: [ "android.test", "android.test.suitebuilder.annotation", "com.android.internal.util", "junit.framework", ], compile_dex: true, }
स्टब लाइब्रेरी कॉन्फ़िगर करने के लिए, इन प्रॉपर्टी का इस्तेमाल करें:
merge_annotations_dirsऔरmerge_inclusion_annotations_dirs.api_srcs: ज़रूरी नहीं वाली सोर्स फ़ाइलों की सूची, जो एपीआई का हिस्सा हैं, लेकिन रनटाइम लाइब्रेरी का हिस्सा नहीं हैं.stubs_only_libs: स्टब बनाते समय, क्लासपाथ में मौजूद Java लाइब्रेरी की सूची.hidden_api_packages: पैकेज के उन नामों की सूची जिन्हें एपीआई से छिपाना ज़रूरी है.droiddoc_options: metalava के लिए अतिरिक्त आर्ग्युमेंट.droiddoc_option_files: उन फ़ाइलों की सूची दिखाता है जिनका रेफ़रंस,$(location <label>)का इस्तेमाल करकेdroiddoc_optionsमें दिया जा सकता है. यहां<file>, सूची में मौजूद एक एंट्री है.annotations_enabled.
java_sdk_library एक java_library है, लेकिन यह droidstubs मॉड्यूल नहीं है. इसलिए, यह droidstubs की सभी प्रॉपर्टी के साथ काम नहीं करता. यह उदाहरण,
android.test.mock library build
फ़ाइल से लिया गया है.
java_sdk_library { name: "android.test.mock", srcs: [":android-test-mock-sources"], api_srcs: [ // Note: The following aren’t APIs of this library. Only APIs under the // android.test.mock package are taken. These do provide private APIs // to which android.test.mock APIs reference. These classes are present // in source code form to access necessary comments that disappear when // the classes are compiled into a Jar library. ":framework-core-sources-for-test-mock", ":framework_native_aidl", ], libs: [ "framework", "framework-annotations-lib", "app-compat-annotations", "Unsupportedappusage", ], api_packages: [ "android.test.mock", ], permitted_packages: [ "android.test.mock", ], compile_dex: true, default_to_stubs: true, }
पुराने सिस्टम के साथ काम करने की सुविधा बनाए रखना
बिल्ड सिस्टम यह जांच करता है कि एपीआई, बिल्ड के समय जनरेट की गई एपीआई फ़ाइलों के साथ काम करते हैं या नहीं. इसके लिए, वह नई एपीआई फ़ाइलों की तुलना, पुरानी एपीआई फ़ाइलों से करता है. java_sdk_library, prebuilt_apis की दी गई जानकारी का इस्तेमाल करके,
काम करने की जांच करता है.
java_sdk_library की मदद से बनाई गई सभी लाइब्रेरी में, prebuilt_apis में api_dirs के नए वर्शन में एपीआई फ़ाइलें होनी चाहिए.
वर्शन रिलीज़ करने पर, एपीआई की सूची वाली फ़ाइलें और स्टब
लाइब्रेरी, PRODUCT=sdk_phone_armv7-sdk के साथ डिस्ट्रिब्यूशन बिल्ड से मिल सकती हैं.
api_dirs प्रॉपर्टी, prebuilt_apis में एपीआई वर्शन डायरेक्ट्री की सूची है. एपीआई वर्शन डायरेक्ट्री, Android.bp डायरेक्ट्री लेवल पर होनी चाहिए.
prebuilt_apis { name: "foo", api_dirs: [ "1", "2", .... "30", "current", ], }
पहले से बनी डायरेक्ट्री में, version/scope/api/
स्ट्रक्चर वाली डायरेक्ट्री कॉन्फ़िगर करें. version
एपीआई लेवल से जुड़ा होता है और scope से यह तय होता है कि डायरेक्ट्री सार्वजनिक, सिस्टम या टेस्ट है.
version/scopeमें Java लाइब्रेरी शामिल हैं.version/scope/apiमें एपीआई.txtफ़ाइलें मौजूद हैं. यहांmodule_name.txtऔरmodule_name-removed.txtनाम की खाली टेक्स्ट फ़ाइलें बनाएं.├── 30 │ ├── public │ │ ├── api │ │ │ ├── android.test.mock-removed.txt │ │ │ └── android.test.mock.txt │ │ └── android.test.mock.jar │ ├── system │ │ ├── api │ │ │ ├── android.test.mock-removed.txt │ │ │ └── android.test.mock.txt │ │ └── android.test.mock.jar │ └── test │ ├── api │ │ ├── android.test.mock-removed.txt │ │ └── android.test.mock.txt │ └── android.test.mock.jar └── Android.bp