स्रोत डाउनलोड कर रहा है

Android स्रोत ट्री Google द्वारा होस्ट किए गए Git रिपॉजिटरी में स्थित है। Git रिपॉजिटरी में Android स्रोत के लिए मेटाडेटा शामिल है, जिसमें स्रोत में परिवर्तन और परिवर्तन कब किए गए थे। यह पृष्ठ बताता है कि किसी विशिष्ट Android कोड लाइन के लिए स्रोत ट्री को कैसे डाउनलोड किया जाए।

स्रोत को डाउनलोड करने के बजाय किसी विशिष्ट डिवाइस के लिए फ़ैक्टरी छवि के साथ प्रारंभ करने के लिए, डिवाइस बिल्ड का चयन करना देखें।

रेपो क्लाइंट को इनिशियलाइज़ करना

रेपो लॉन्चर स्थापित करने के बाद, अपने क्लाइंट को एंड्रॉइड स्रोत रिपॉजिटरी तक पहुंचने के लिए सेट करें:

  1. अपनी कार्यशील फ़ाइलों को रखने के लिए एक खाली निर्देशिका बनाएँ। इसे कोई भी नाम दें जो आपको पसंद हो:

    mkdir WORKING_DIRECTORY
    cd WORKING_DIRECTORY
    
  2. Git को अपने वास्तविक नाम और ईमेल पते से कॉन्फ़िगर करें। जेरिट कोड-रिव्यू टूल का उपयोग करने के लिए, आपको एक ईमेल पते की आवश्यकता है जो एक पंजीकृत Google खाते से जुड़ा हो। सुनिश्चित करें कि यह एक लाइव पता है जहां आप संदेश प्राप्त कर सकते हैं। आपके द्वारा यहां प्रदान किया गया नाम आपके कोड सबमिशन के एट्रिब्यूशन में दिखाई देता है।

    git config --global user.name Your Name
    git config --global user.email you@example.com
    
  3. रेपो का नवीनतम संस्करण इसके नवीनतम बग फिक्स के साथ प्राप्त करने के लिए repo init चलाएं। आपको मेनिफेस्ट के लिए एक URL निर्दिष्ट करना होगा, जो निर्दिष्ट करता है कि Android स्रोत में शामिल विभिन्न रिपॉजिटरी आपकी कार्यशील निर्देशिका में कहाँ रखी गई हैं।

    repo init -u https://android.googlesource.com/platform/manifest
    

    मास्टर शाखा की जाँच करने के लिए:

    repo init -u https://android.googlesource.com/platform/manifest -b master
    

    मास्टर के अलावा किसी अन्य शाखा को देखने के लिए, इसे -b के साथ निर्दिष्ट करें। शाखाओं की सूची के लिए, स्रोत कोड टैग और बिल्ड देखें।

    पायथन 2 के लिए

    पायथन 3 के लिए

    यदि आपको " /usr/bin/env 'python' no such file or directory " त्रुटि संदेश मिलता है, तो निम्न समाधानों में से किसी एक का उपयोग करें:

    यदि आपका Ubuntu 20.04.2 LTS एक नया स्थापित (बनाम उन्नत) Linux संस्करण है:

    sudo ln -s /usr/bin/python3 /usr/bin/python

    यदि गिट संस्करण 2.19 या इससे अधिक का उपयोग कर रहे हैं, तो आप repo init करते समय --partial-clone निर्दिष्ट कर सकते हैं। यह गिट की आंशिक क्लोन क्षमता का उपयोग केवल जरूरत पड़ने पर गिट वस्तुओं को डाउनलोड करने के लिए करता है, सब कुछ डाउनलोड करने के बजाय। क्योंकि आंशिक क्लोन का उपयोग करने का अर्थ है कि कई कार्यों को सर्वर के साथ संवाद करना चाहिए, यदि आप एक डेवलपर हैं और आप कम विलंबता वाले नेटवर्क का उपयोग कर रहे हैं तो निम्न का उपयोग करें:

    repo init -u https://android.googlesource.com/platform/manifest -b master --partial-clone --clone-filter=blob:limit=10M
    

    केवल Windows OS के लिए: यदि आपको यह बताते हुए एक त्रुटि संदेश मिलता है कि सांकेतिक लिंक नहीं बनाए जा सकते हैं, जिससे repo init विफल हो जाता है, तो इन्हें बनाने के लिए, या उनके समर्थन को सक्षम करने के लिए GitHub प्रतीकात्मक लिंक दस्तावेज़ देखें। गैर-व्यवस्थापकों के लिए, प्रतीकात्मक लिंक बनाने के लिए गैर-व्यवस्थापकों को अनुमति देना अनुभाग देखें।

एक सफल आरंभीकरण एक संदेश के साथ समाप्त होता है जिसमें कहा गया है कि रेपो को आपकी कार्यशील निर्देशिका में आरंभीकृत किया गया है। आपकी ग्राहक निर्देशिका में अब एक .repo निर्देशिका शामिल है जहाँ मेनिफेस्ट जैसी फ़ाइलें रखी जाती हैं।

Android स्रोत ट्री डाउनलोड करना

डिफॉल्ट मेनिफेस्ट में निर्दिष्ट रिपॉजिटरी से एंड्रॉइड सोर्स ट्री को अपनी वर्किंग डायरेक्टरी में डाउनलोड करने के लिए, रन करें:

repo sync

सिंक को गति देने के लिए, -c (वर्तमान शाखा) और -j threadcount फ़्लैग पास करें:

repo sync -c -j8

Android स्रोत फ़ाइलें आपकी कार्यशील निर्देशिका में उनके प्रोजेक्ट नामों के तहत डाउनलोड की जाती हैं।

आउटपुट को दबाने के लिए, -q (शांत) फ़्लैग पास करें। सभी विकल्पों के लिए रेपो कमांड संदर्भ देखें।

प्रमाणीकरण का उपयोग करना

डिफ़ॉल्ट रूप से, Android स्रोत कोड तक पहुंच गुमनाम होती है। अत्यधिक उपयोग से सर्वर की सुरक्षा के लिए, प्रत्येक IP पता एक कोटा से जुड़ा होता है।

अन्य उपयोगकर्ताओं के साथ एक आईपी पता साझा करते समय (उदाहरण के लिए, एनएटी फ़ायरवॉल से परे स्रोत रिपॉजिटरी तक पहुंचने पर), कोटा नियमित उपयोग पैटर्न के लिए भी ट्रिगर कर सकता है (उदाहरण के लिए, यदि कई उपयोगकर्ता एक ही आईपी पते से नए क्लाइंट को सिंक करते हैं। एक छोटी सी अवधि में)।

उस स्थिति में, आप प्रमाणीकृत पहुंच का उपयोग कर सकते हैं, जो आईपी पते पर ध्यान दिए बिना प्रत्येक उपयोगकर्ता के लिए एक अलग कोटा का उपयोग करता है।

सबसे पहले, पासवर्ड जनरेटर के साथ एक पासवर्ड बनाएं और पासवर्ड जनरेटर पेज पर दिए गए निर्देशों का पालन करें।

इसके बाद, मैनिफेस्ट यूआरआई https://android.googlesource.com/a/platform/manifest का उपयोग करके प्रमाणित पहुंच को बाध्य करें। ध्यान दें कि कैसे /a/ निर्देशिका उपसर्ग अनिवार्य प्रमाणीकरण को ट्रिगर करता है। आप निम्न आदेश के साथ अनिवार्य प्रमाणीकरण का उपयोग करने के लिए मौजूदा क्लाइंट को परिवर्तित कर सकते हैं:

repo init -u https://android.googlesource.com/a/platform/manifest

नेटवर्क समस्याओं का निवारण

प्रॉक्सी के पीछे से डाउनलोड करते समय (जो कुछ कॉर्पोरेट वातावरण में सामान्य है), आपको रेपो के उपयोग के लिए प्रॉक्सी को स्पष्ट रूप से निर्दिष्ट करने की आवश्यकता हो सकती है:

export HTTP_PROXY=http://<proxy_user_id>:<proxy_password>@<proxy_server>:<proxy_port>
export HTTPS_PROXY=http://<proxy_user_id>:<proxy_password>@<proxy_server>:<proxy_port>

अधिक दुर्लभ रूप से, लिनक्स क्लाइंट कनेक्टिविटी समस्याओं का अनुभव करते हैं, डाउनलोड के बीच में फंस जाते हैं (आमतौर पर ऑब्जेक्ट प्राप्त करने के दौरान)। टीसीपी/आईपी स्टैक की सेटिंग्स को समायोजित करना और गैर-समानांतर कमांड का उपयोग करने से स्थिति में सुधार हो सकता है। टीसीपी सेटिंग को संशोधित करने के लिए आपके पास रूट एक्सेस होना चाहिए:

sudo sysctl -w net.ipv4.tcp_window_scaling=0
repo sync -j1

स्थानीय दर्पण का उपयोग करना

कई क्लाइंट्स का उपयोग करते समय, आप संपूर्ण सर्वर सामग्री का एक स्थानीय मिरर बना सकते हैं और क्लाइंट्स को उस मिरर से सिंक कर सकते हैं (जिसके लिए किसी नेटवर्क एक्सेस की आवश्यकता नहीं है)।

ये निर्देश मानते हैं कि दर्पण /usr/local/aosp/mirror में बनाया गया है। सबसे पहले, मिरर को ही बनाएं और सिंक करें। --mirror फ़्लैग पर ध्यान दें, जिसे आप केवल एक नया क्लाइंट बनाते समय निर्दिष्ट कर सकते हैं:

mkdir -p /usr/local/aosp/mirror
cd /usr/local/aosp/mirror
repo init -u https://android.googlesource.com/mirror/manifest --mirror
repo sync

जब मिरर समन्‍वयित होता है, तो आप इससे नए क्‍लाइंट बना सकते हैं। ध्यान दें कि आपको एक निरपेक्ष पथ निर्दिष्ट करना होगा:

mkdir -p /usr/local/aosp/master
cd /usr/local/aosp/master
repo init -u /usr/local/aosp/mirror/platform/manifest.git
repo sync

अंत में, सर्वर के खिलाफ क्लाइंट को सिंक करने के लिए, सर्वर के खिलाफ मिरर को सिंक करें, फिर क्लाइंट को मिरर के खिलाफ:

cd /usr/local/aosp/mirror
repo sync
cd /usr/local/aosp/master
repo sync

मिरर को LAN सर्वर पर स्टोर करना और इसे NFS, SSH, या Git पर एक्सेस करना संभव है। इसे हटाने योग्य ड्राइव पर स्टोर करना और उपयोगकर्ताओं या मशीनों के बीच उस ड्राइव को पास करना भी संभव है।

गिट टैग सत्यापित करना

निम्न सार्वजनिक कुंजी को अपने GnuPG कुंजी डेटाबेस में लोड करें। कुंजी का उपयोग एनोटेटेड टैग्स पर हस्ताक्षर करने के लिए किया जाता है जो रिलीज का प्रतिनिधित्व करते हैं।

gpg --import

कुंजी को नीचे कॉपी और पेस्ट करें, फिर इनपुट को समाप्त करने और कुंजियों को संसाधित करने के लिए EOF ( Ctrl-D ) टाइप करें।

-----BEGIN PGP PUBLIC KEY BLOCK-----
Version: GnuPG v1.4.2.2 (GNU/Linux)

mQGiBEnnWD4RBACt9/h4v9xnnGDou13y3dvOx6/t43LPPIxeJ8eX9WB+8LLuROSV
lFhpHawsVAcFlmi7f7jdSRF+OvtZL9ShPKdLfwBJMNkU66/TZmPewS4m782ndtw7
8tR1cXb197Ob8kOfQB3A9yk2XZ4ei4ZC3i6wVdqHLRxABdncwu5hOF9KXwCgkxMD
u4PVgChaAJzTYJ1EG+UYBIUEAJmfearb0qRAN7dEoff0FeXsEaUA6U90sEoVks0Z
wNj96SA8BL+a1OoEUUfpMhiHyLuQSftxisJxTh+2QclzDviDyaTrkANjdYY7p2cq
/HMdOY7LJlHaqtXmZxXjjtw5Uc2QG8UY8aziU3IE9nTjSwCXeJnuyvoizl9/I1S5
jU5SA/9WwIps4SC84ielIXiGWEqq6i6/sk4I9q1YemZF2XVVKnmI1F4iCMtNKsR4
MGSa1gA8s4iQbsKNWPgp7M3a51JCVCu6l/8zTpA+uUGapw4tWCp4o0dpIvDPBEa9
b/aF/ygcR8mh5hgUfpF9IpXdknOsbKCvM9lSSfRciETykZc4wrRCVGhlIEFuZHJv
aWQgT3BlbiBTb3VyY2UgUHJvamVjdCA8aW5pdGlhbC1jb250cmlidXRpb25AYW5k
cm9pZC5jb20+iGAEExECACAFAknnWD4CGwMGCwkIBwMCBBUCCAMEFgIDAQIeAQIX
gAAKCRDorT+BmrEOeNr+AJ42Xy6tEW7r3KzrJxnRX8mij9z8tgCdFfQYiHpYngkI
2t09Ed+9Bm4gmEO5Ag0ESedYRBAIAKVW1JcMBWvV/0Bo9WiByJ9WJ5swMN36/vAl
QN4mWRhfzDOk/Rosdb0csAO/l8Kz0gKQPOfObtyYjvI8JMC3rmi+LIvSUT9806Up
hisyEmmHv6U8gUb/xHLIanXGxwhYzjgeuAXVCsv+EvoPIHbY4L/KvP5x+oCJIDbk
C2b1TvVk9PryzmE4BPIQL/NtgR1oLWm/uWR9zRUFtBnE411aMAN3qnAHBBMZzKMX
LWBGWE0znfRrnczI5p49i2YZJAjyX1P2WzmScK49CV82dzLo71MnrF6fj+Udtb5+
OgTg7Cow+8PRaTkJEW5Y2JIZpnRUq0CYxAmHYX79EMKHDSThf/8AAwUIAJPWsB/M
pK+KMs/s3r6nJrnYLTfdZhtmQXimpoDMJg1zxmL8UfNUKiQZ6esoAWtDgpqt7Y7s
KZ8laHRARonte394hidZzM5nb6hQvpPjt2OlPRsyqVxw4c/KsjADtAuKW9/d8phb
N8bTyOJo856qg4oOEzKG9eeF7oaZTYBy33BTL0408sEBxiMior6b8LrZrAhkqDjA
vUXRwm/fFKgpsOysxC6xi553CxBUCH2omNV6Ka1LNMwzSp9ILz8jEGqmUtkBszwo
G1S8fXgE0Lq3cdDM/GJ4QXP/p6LiwNF99faDMTV3+2SAOGvytOX6KjKVzKOSsfJQ
hN0DlsIw8hqJc0WISQQYEQIACQUCSedYRAIbDAAKCRDorT+BmrEOeCUOAJ9qmR0l
EXzeoxcdoafxqf6gZlJZlACgkWF7wi2YLW3Oa+jv2QSTlrx4KLM=
=Wi5D
-----END PGP PUBLIC KEY BLOCK-----

कुंजियाँ आयात करने के बाद, आप निम्न से किसी भी टैग को सत्यापित कर सकते हैं:

git tag -v TAG_NAME

मालिकाना बायनेरिज़ प्राप्त करें

AOSP का उपयोग केवल शुद्ध स्रोत कोड से नहीं किया जा सकता है और इसे चलाने के लिए अतिरिक्त हार्डवेयर से संबंधित मालिकाना पुस्तकालयों की आवश्यकता होती है, जैसे कि हार्डवेयर ग्राफिक्स त्वरण के लिए। अतिरिक्त संसाधनों के लिए डाउनलोड लिंक और डिवाइस बायनेरिज़ के लिए नीचे दिए गए अनुभाग देखें।

मालिकाना बायनेरिज़ डाउनलोड करें

आप Google के ड्राइवरों से टैग की गई AOSP रिलीज़ शाखाओं को चलाने वाले समर्थित उपकरणों के लिए आधिकारिक बायनेरिज़ डाउनलोड कर सकते हैं। ये बायनेरिज़ गैर-ओपन सोर्स कोड के साथ अतिरिक्त हार्डवेयर क्षमताओं तक पहुँच जोड़ते हैं। एओएसपी मास्टर शाखा बनाने के लिए, इसके बजाय बायनेरिज़ पूर्वावलोकन का उपयोग करें। किसी डिवाइस के लिए मास्टर शाखा का निर्माण करते समय, सबसे हाल की क्रमांकित रिलीज़ या सबसे हाल की तारीख के लिए बायनेरिज़ का उपयोग करें।

मालिकाना बायनेरिज़ निकालें

बायनेरिज़ का प्रत्येक सेट एक संपीड़ित संग्रह में स्वयं-निकालने वाली स्क्रिप्ट के रूप में आता है। प्रत्येक संग्रह को असम्पीडित करें, स्रोत ट्री की जड़ से शामिल स्व-निष्कर्षण स्क्रिप्ट को चलाएं, फिर पुष्टि करें कि आप संलग्न लाइसेंस समझौते की शर्तों से सहमत हैं। स्रोत ट्री के vendor/ पदानुक्रम में बायनेरिज़ और उनके मिलान करने वाले मेकफ़ाइल स्थापित हैं।

साफ - सफाई

यह सुनिश्चित करने के लिए कि नए स्थापित बायनेरिज़ को निकाले जाने के बाद ठीक से ध्यान में रखा गया है, किसी भी पिछले निर्माण के मौजूदा आउटपुट का उपयोग करके हटाएं:

make clobber