मुझे लगता है कि यह git स्लैश नोटेशन शायद आपके .git
फ़ोल्डर के अंदर देखकर सबसे अच्छा समझा जाता है ।
उदाहरण के लिए, यहाँ लिबर ऑफिस सोर्स बेस के लिए मेरा .गित का कुछ संक्षिप्त पेड़ है।
में linux sudo apt-get install tree
इस देखने के लिए उपयोगी है।
में विंडोज मुझे लगता है कि tree
आदेश काम हो सकता है अभी भी।
नीचे स्क्रॉल करें और नीचे के पास रेफ (उर्फ 'संदर्भ') पर एक नज़र डालें:
$ tree
.
├── branches
├── config
├── description
├── FETCH_HEAD
├── gitk.cache
├── HEAD
├── hooks
│ ├── applypatch-msg.sample
...
├── index
├── info
│ └── exclude
├── logs
│ ├── HEAD
│ └── refs
│ ├── heads
│ │ ├── master
│ │ └── remotes
│ │ └── origin
│ └── remotes
│ └── origin
│ ├── distro
│ │ ├── cib
│ │ │ └── libreoffice-6-0
│ │ ├── collabora
│ │ │ └── cp-6.0
│ │ └── lhm
│ │ └── libreoffice-5-2+backports
│ ├── HEAD
│ ├── libreoffice-6-2
│ ├── master
│ └── private
│ └── mst
│ └── sw_redlinehide_4a
├── objects
│ ├── info
│ └── pack
│ ├── pack-b80087dc57e2b3315f449ca0f1aaa91987bf0c5e.idx
│ ├── pack-b80087dc57e2b3315f449ca0f1aaa91987bf0c5e.pack
│ ├── pack-eb4e6808029e712d8d9c2671accbbd98aaeb9a04.idx
│ └── pack-eb4e6808029e712d8d9c2671accbbd98aaeb9a04.pack
├── ORIG_HEAD
├── packed-refs
└── refs
├── heads
│ ├── master
│ └── remotes
│ └── origin
├── remotes
│ └── origin
│ ├── distro
│ │ ├── cib
│ │ │ └── libreoffice-6-0
│ │ ├── collabora
│ │ │ └── cp-6.0
│ │ └── lhm
│ │ └── libreoffice-5-2+backports
│ ├── HEAD
│ ├── libreoffice-6-2
│ ├── master
│ └── private
│ └── mst
│ └── sw_redlinehide_4a
└── tags
└── libreoffice-6-2-branch-point
32 directories, 45 files
यह इस तरह से रखी गई थी, तो कम भ्रमित हो सकता है, लेकिन यह नहीं था:
repositories (i.e. independent trees)
├──local
│ └──master
│
└──origin1
│ └──master
└──origin2
└──master
हमारे पास तीन मूल प्रकार के संदर्भ हैं: सिर , रिमोट और टैग ।
.it / refs / heads हमारे स्थानीय स्वामी को रखते हैं ।
.it / refs / remotes में कई रीमोट हो सकते हैं, हालांकि फिलहाल हमारे पास केवल इसका मूल है।
.it / refs / टैग (अन्यत्र चर्चा की गई है)।
इस प्रकार मूल , हमारा एक और केवल दूरस्थ है। यह मूल / गुरु रखता है ।
हम पाते हैं कि हमारे पास 2 HEADS (वर्तमान शाखाओं के लिए संकेत), एक स्थानीय और एक रिमोट है:
$ cat .git/HEAD # local: HEAD -> master
ref: refs/heads/master
$ cat .git/refs/remotes/origin/HEAD # remote origin: HEAD -> master
ref: refs/remotes/origin/master
यदि आप अपनी शाखाएं सूचीबद्ध करते हैं :
$ git branch -a
* master
remotes/origin/HEAD -> origin/master
remotes/origin/aoo/aw080
remotes/origin/aoo/trunk
remotes/origin/distro/capgemini/cg-4.1
remotes/origin/distro/cib/libreoffice-5-0
remotes/origin/distro/cib/libreoffice-5-1
remotes/origin/distro/cib/libreoffice-5-2
...
- सूचीबद्ध पहली शाखा ( मास्टर ) केवल एक ही है जो रिमोट नहीं है। तो इस मामले में हमारी एक स्थानीय शाखा है। यह वह जगह है जहाँ हम अपनी नई शाखाओं और बाद में आने के लिए अपना काम शुरू करेंगे।
अगला, आपके पास कई दूरस्थ ट्रैकिंग शाखाएँ हो सकती हैं, और हम यहाँ करते हैं। आप जानते हैं कि ये दूरस्थ ट्रैकिंग शाखाएँ हैं क्योंकि वे ' रीमोट्स / ' के साथ उपसर्ग करती हैं । यहाँ दिखाए गए रिमोट नाम की उत्पत्ति के लिए हैं।
तो दूसरी पंक्ति उत्पत्ति की वर्तमान शाखा सूचक है। रिमोट / मूल: HEAD - पॉइंट्स से -> मास्टर। इससे पता चलता है कि दूरदराज के भंडार में, वर्तमान शाखा उनकी शाखा नामित है मास्टर , (हमारे स्थानीय शाखा नामित साथ भ्रमित होने की नहीं मास्टर )।
शेष शाखाएँ आपके .गित / रेफ्स / ट्री में नहीं पाई जाती हैं, बल्कि आप उन्हें खोज लेंगे .git/packed-refs
।
जब हम लाते हैं तो हम दूरस्थ रिपॉजिटरी से हमारे रिमोट ट्रैकिंग रिपॉजिटरी में परिवर्तन डाउनलोड करते हैं।
जब हम मर्ज करते हैं तो हम इस कार्य में स्थानीय, दूरस्थ ट्रैकिंग रिपॉजिटरी को हमारी कार्यशील स्थानीय शाखा या शाखाओं में मर्ज करते हैं, इस मामले में हमारी मास्टर शाखा में।
(जब हम खींचते हैं तो हम इन दोनों चरणों को एक ऑपरेशन में करते हैं।)
यह भी दिलचस्प है कि इन स्थानीय और दूरस्थ यूयूआईडी को मास्टर के लिए वर्तमान में एक ही नोड (उर्फ 'कमिट) में इंगित करना दिलचस्प है :
$ cat refs/heads/master # local master
1ca409292272632f443733450313de5a82c54a9c
$ cat refs/remotes/origin/master # remote origin master
1ca409292272632f443733450313de5a82c54a9c
तो हमारे स्थानीय मास्टर रिमोट के मूल मास्टर के रूप में उसी स्थान पर इंगित करते हैं:
[local] master = [remote] origin master
अंत में, मुझे लगता है कि इसे देखना भी उपयोगी है .git/packed-refs
$ cat packed-refs
# pack-refs with: peeled fully-peeled
3c1d4742e649fe9c8aed8c2817fe3e1f3364f298 refs/remotes/origin/aoo/aw080
e87c8b7922e9a73e0abb7f9a7a47c9ac3374a826 refs/remotes/origin/aoo/trunk
b70fdffb041c12f124dcc0822b61bf3450e53137 refs/remotes/origin/distro/capgemini/cg-4.1
5dbc3f1754809b9489faaf380b1a4bdbcfbb6205 refs/remotes/origin/distro/cib/libreoffice-5-0
cfdbc96ca47d68d6785fd21829a8d61f49d6e591 refs/remotes/origin/distro/cib/libreoffice-5-1
5189c8c47461ef09739086e55512fc6a10245273 refs/remotes/origin/distro/cib/libreoffice-5-2
3bee5917569ca8e6ee3b086458f5b1a917b88ca1 refs/remotes/origin/distro/cib/libreoffice-5-3
92fbe703f9ca480d3a2b8610d87e991c729edf77 refs/remotes/origin/distro/cib/libreoffice-5-4
05c0a5df66cc69d75280f05b804cf82f3387d42b refs/remotes/origin/distro/cib/libreoffice-6-0
7fe193e759b24b90852e6e327115b77114d7b119 refs/remotes/origin/distro/cib/libreoffice-6-1
8187f7aa413e7ef7b377eea2b057d336bf256867 refs/remotes/origin/distro/collabora/cd-5.3
7a6b608591e21ef61dc05cff9fc58da531035755 refs/remotes/origin/distro/collabora/cd-5.3-3.1
....
इसमें कोई संदेह नहीं है कि यह उत्तर से अधिक प्रश्न छोड़ता है, लेकिन मुझे लगता है कि यह आपके सवालों के जवाब देने में मदद कर सकता है कि क्या है।