संस्करण नियंत्रण

सॉफ्टवेयर इंजीनियरिंग में, संस्करण नियंत्रण (जिसे पुनरीक्षण नियंत्रण, स्रोत नियंत्रण या स्रोत कोड प्रबंधन के रूप में भी जाना जाता है) कंप्यूटर प्रोग्राम, दस्तावेज़, बड़ी वेब साइट या सूचना के अन्य संग्रह में परिवर्तन के प्रबंधन के लिए जिम्मेदार सिस्टम का एक वर्ग है। संस्करण नियंत्रण सॉफ्टवेयर कॉन्फ़िगरेशन प्रबंधन का एक घटक है। परिवर्तनों को आमतौर पर एक संख्या या अक्षर कोड द्वारा पहचाना जाता है, जिसे संशोधन संख्या, संशोधन स्तर या केवल संशोधन कहा जाता है। उदाहरण के लिए, फ़ाइलों का प्रारंभिक सेट संशोधन 1 है। जब पहला परिवर्तन किया जाता है, परिणामी सेट संशोधन 2 होता है, और इसी तरह आगे भी। प्रत्येक संशोधन एक TIMESTAMP और परिवर्तन करने वाले व्यक्ति से जुड़ा होता है। संशोधनों की तुलना की जा सकती है, उन्हें पुनर्स्थापित किया जा सकता है, और कुछ प्रकार की फाइलों के साथ विलय किया जा सकता है। संशोधनों को व्यवस्थित और नियंत्रित करने के लिए एक तार्किक तरीके की आवश्यकता लगभग तब तक रही है जब तक लेखन अस्तित्व में रहा है, लेकिन कंप्यूटिंग का युग शुरू होने पर संशोधन नियंत्रण अधिक महत्वपूर्ण और जटिल हो गया। संस्करण (पुस्तक) की संख्या और विनिर्देश (तकनीकी मानक) ऐसे उदाहरण हैं जो प्रिंट-ओनली युग के हैं। आज, सबसे सक्षम (साथ ही जटिल) पुनरीक्षण नियंत्रण प्रणालियां वे हैं जिनका उपयोग सॉफ्टवेयर विकास में किया जाता है, जहां लोगों की एक टीम समवर्ती रूप से समान फ़ाइलों में परिवर्तन कर सकती है।

वर्जन कंट्रोल सिस्टम आमतौर पर स्टैंड-अलोन एप्लिकेशन के रूप में चलाए जाते हैं, लेकिन संशोधन नियंत्रण भी विभिन्न प्रकार के सॉफ्टवेयर डेवलपमेंट एम्बेड किया जाता है, जैसे शब्द संसाधक और स्प्रेडशीट, सहयोगी ग्रुपवेयर, और सामग्री प्रबंधन प्रणालियाँ, उदाहरण के लिए, विकिपीडिया की सहायता: पृष्ठ इतिहास। संशोधन नियंत्रण किसी दस्तावेज़ को पिछले संशोधन में वापस लाने में सक्षम बनाता है, जो संपादकों को एक दूसरे के संपादनों को ट्रैक करने, गलतियों को सुधारने और हफ्ता में बर्बरता और स्पैमिंग से बचाव करने की अनुमति देने के लिए महत्वपूर्ण है।

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

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

सबसे सरल स्तर पर, डेवलपर्स प्रोग्राम के विभिन्न संस्करणों की कई प्रतियों को आसानी से रख सकते हैं, और उन्हें उचित रूप से लेबल कर सकते हैं। इस आसान तरीके का इस्तेमाल कई बड़ी सॉफ्टवेयर परियोजनाओं में किया गया है। जबकि यह विधि काम कर सकती है, यह अक्षम है क्योंकि कार्यक्रम की कई समान-समान प्रतियों को बनाए रखना पड़ता है। इसके लिए डेवलपर्स को बहुत अधिक आत्म-अनुशासन की आवश्यकता होती है और अक्सर गलतियाँ होती हैं। चूंकि कोड आधार समान है, इसलिए इसे डेवलपर्स के एक सेट को पढ़ने-लिखने-निष्पादित करने की अनुमति देने की भी आवश्यकता होती है, और यह अनुमतियों को प्रबंधित करने वाले किसी व्यक्ति के दबाव को जोड़ता है ताकि कोड आधार समझौता न हो, जो अधिक जटिलता जोड़ता है। नतीजतन, संशोधन नियंत्रण प्रक्रिया के कुछ या सभी को स्वचालित करने के लिए सिस्टम विकसित किए गए हैं। यह सुनिश्चित करता है कि संस्करण नियंत्रण चरणों का अधिकांश प्रबंधन पर्दे के पीछे छिपा हुआ है।

इसके अलावा, सॉफ्टवेयर विकास, कानूनी और व्यावसायिक अभ्यास, और अन्य वातावरण में, एक टीम द्वारा संपादित किए जाने वाले एकल दस्तावेज़ या कोड के स्निपेट के लिए यह तेजी से सामान्य हो गया है, जिसके सदस्य भौगोलिक रूप से अलग-अलग हो सकते हैं और अलग-अलग और यहां तक ​​कि इसके विपरीत हो सकते हैं। रूचियाँ। परिष्कृत पुनरीक्षण नियंत्रण जो दस्तावेजों और कोड में परिवर्तनों के स्वामित्व के लिए ट्रैक करता है और ऐसी स्थितियों में अत्यंत सहायक या अपरिहार्य भी हो सकता है।

पुनरीक्षण नियंत्रण विन्यास फाइल में परिवर्तनों को भी ट्रैक कर सकता है, जैसे कि आमतौर पर इसमें संग्रहीत  या   यूनिक्स सिस्टम पर। यह सिस्टम प्रशासकों को किए गए परिवर्तनों को आसानी से ट्रैक करने का एक और तरीका देता है और आवश्यकता पड़ने पर पुराने संस्करणों में वापस जाने का एक तरीका देता है।

इतिहास
OS/360 और उत्तराधिकारी के लिए IBM का OS/360 समर्थन कार्यक्रम #IEBUPDTE सॉफ़्टवेयर अपडेट टूल 1962 से पहले का है, यकीनन संस्करण नियंत्रण प्रणाली टूल का अग्रदूत है। स्रोत कोड नियंत्रण के लिए डिज़ाइन किया गया एक पूर्ण सिस्टम 1972 में शुरू किया गया था, उसी सिस्टम के लिए स्रोत कोड नियंत्रण प्रणाली (OS/360)। स्रोत कोड नियंत्रण प्रणाली की शुरूआत, 4 दिसंबर, 1975 को प्रकाशित होने के कारण, ऐतिहासिक रूप से निहित है कि यह पहली जानबूझकर संशोधन नियंत्रण प्रणाली थी। आरसीएस ने ठीक बाद में पीछा किया, इसके नेटवर्क संस्करण समवर्ती संस्करण प्रणाली के साथ। समवर्ती संस्करण प्रणाली के बाद की अगली पीढ़ी में अपाचे तोड़फोड़ का प्रभुत्व था, गिट जैसे वितरित पुनरीक्षण नियंत्रण उपकरण के उदय के बाद।

संरचना
संशोधन नियंत्रण समय के साथ डेटा के एक सेट में परिवर्तन का प्रबंधन करता है। इन परिवर्तनों को विभिन्न तरीकों से संरचित किया जा सकता है।

अक्सर डेटा को कई व्यक्तिगत वस्तुओं के संग्रह के रूप में माना जाता है, जैसे फ़ाइलें या दस्तावेज़, और व्यक्तिगत फ़ाइलों में परिवर्तन ट्रैक किए जाते हैं। यह अलग-अलग फाइलों के बारे में अंतर्ज्ञान के साथ मेल खाता है लेकिन जब पहचान बदलती है, जैसे फ़ाइलों का नाम बदलने, विभाजित करने या विलय करने के दौरान समस्याएं पैदा होती हैं। तदनुसार, कुछ प्रणालियाँ जैसे कि गिट, इसके बजाय संपूर्ण रूप से डेटा में परिवर्तन पर विचार करती हैं, जो सरल परिवर्तनों के लिए कम सहज है लेकिन अधिक जटिल परिवर्तनों को सरल बनाता है।

जब संशोधन नियंत्रण के अधीन डेटा को संशोधित किया जाता है, चेक आउट द्वारा पुनर्प्राप्त किए जाने के बाद, यह सामान्य रूप से संशोधन नियंत्रण प्रणाली (रिपॉजिटरी में) में तुरंत परिलक्षित नहीं होता है, बल्कि इसके बजाय चेक इन या प्रतिबद्ध होना चाहिए। संशोधन नियंत्रण के बाहर की प्रतिलिपि को कार्यशील प्रति के रूप में जाना जाता है। एक साधारण उदाहरण के रूप में, कंप्यूटर फ़ाइल को संपादित करते समय, संपादन प्रोग्राम द्वारा स्मृति में संग्रहीत डेटा कार्यशील प्रतिलिपि होती है, जिसे सहेज कर प्रतिबद्ध किया जाता है। विशेष रूप से, कोई एक दस्तावेज़ का प्रिंट आउट ले सकता है, इसे हाथ से संपादित कर सकता है, और केवल बाद में मैन्युअल रूप से कंप्यूटर में परिवर्तनों को इनपुट कर सकता है और इसे सहेज सकता है। स्रोत कोड नियंत्रण के लिए, कार्यशील प्रति इसके बजाय एक विशेष संशोधन में सभी फाइलों की एक प्रति है, जो आमतौर पर डेवलपर के कंप्यूटर पर स्थानीय रूप से संग्रहीत होती है; इस मामले में फ़ाइल को सहेजने से केवल कार्यशील प्रति बदल जाती है, और रिपॉजिटरी में जाँच करना एक अलग चरण है।

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

पुनरीक्षण नियंत्रण प्रणालियाँ अक्सर केंद्रीकृत होती हैं, एक एकल आधिकारिक डेटा स्टोर, रिपॉजिटरी, और चेक-आउट और चेक-इन इस केंद्रीय रिपॉजिटरी के संदर्भ में किए जाते हैं। वैकल्पिक रूप से, वितरित पुनरीक्षण नियंत्रण में, कोई भी रिपॉजिटरी आधिकारिक नहीं है, और डेटा को चेक आउट किया जा सकता है और किसी भी रिपॉजिटरी में चेक किया जा सकता है। एक अलग रिपॉजिटरी में चेक करते समय, इसे मर्ज या पैच के रूप में समझा जाता है।

ग्राफ संरचना
ग्राफ सिद्धांत के संदर्भ में, संशोधनों को आम तौर पर विकास की एक रेखा (ट्रंक) के रूप में माना जाता है, जो शाखाओं से दूर होती है, एक निर्देशित वृक्ष का निर्माण करती है, जिसे विकास की एक या एक से अधिक समानांतर रेखाओं (शाखाओं की मुख्य रेखाएं) के रूप में देखा जाता है। तना। वास्तव में संरचना अधिक जटिल है, एक निर्देशित विश्वकोश ग्राफ का निर्माण करती है, लेकिन कई उद्देश्यों के लिए मर्ज के साथ पेड़ एक पर्याप्त सन्निकटन है।

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

विलय की उपस्थिति में, परिणामी ग्राफ़ अब एक पेड़ नहीं है, क्योंकि नोड्स में कई माता-पिता हो सकते हैं, बल्कि इसके बजाय एक रूट निर्देशित एसाइक्लिक ग्राफ (डीएजी) है। ग्राफ विश्वकोश है क्योंकि माता-पिता हमेशा समय में पीछे होते हैं, और जड़ होते हैं क्योंकि एक सबसे पुराना संस्करण है। मान लें कि एक ट्रंक है, शाखाओं से विलय को पेड़ के बाहरी रूप में माना जा सकता है - शाखा में परिवर्तन पैच के रूप में पैक किए जाते हैं, जो हेड (ट्रंक के) पर लागू होते हैं, बिना किसी स्पष्ट संदर्भ के एक नया संशोधन बनाते हैं शाखा, और वृक्ष संरचना को संरक्षित करना। इस प्रकार, जबकि संस्करणों के बीच वास्तविक संबंध एक DAG बनाते हैं, इसे एक ट्री प्लस मर्ज माना जा सकता है, और ट्रंक स्वयं एक रेखा है।

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

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

संस्करण नियंत्रण व्यापार और कानून में व्यापक है। दरअसल, अनुबंध रेडलाइन और कानूनी ब्लैकलाइन संशोधन नियंत्रण के शुरुआती रूपों में से कुछ हैं, और अभी भी अलग-अलग डिग्री के परिष्कार के साथ व्यापार और कानून में कार्यरत हैं। पारंपरिक पुनरीक्षण नियंत्रण के मैनुअल इलेक्ट्रॉनिक कार्यान्वयन को प्रतिस्थापित करते हुए, सीएडी फ़ाइलों में परिवर्तनों की इलेक्ट्रॉनिक ट्रैकिंग (उत्पाद डेटा प्रबंधन देखें) के लिए सबसे परिष्कृत तकनीकों का उपयोग किया जाने लगा है।

स्रोत-प्रबंधन मॉडल
पारंपरिक पुनरीक्षण नियंत्रण प्रणालियाँ एक केंद्रीकृत मॉडल का उपयोग करती हैं जहाँ सभी पुनरीक्षण नियंत्रण कार्य एक साझा सर्वर (कंप्यूटिंग) पर होते हैं। यदि दो डेवलपर एक ही फ़ाइल को एक ही समय में बदलने का प्रयास करते हैं, तो एक्सेस प्रबंधन के किसी तरीके के बिना डेवलपर एक-दूसरे के काम को ओवरराइट कर सकते हैं। केंद्रीकृत पुनरीक्षण नियंत्रण प्रणाली इस समस्या को दो अलग-अलग स्रोत प्रबंधन मॉडल में से एक में हल करती है: फ़ाइल लॉकिंग और वर्जन मर्जिंग।

परमाणु संचालन
एक ऑपरेशन परमाणु है अगर ऑपरेशन बाधित होने पर भी सिस्टम को एक सुसंगत स्थिति में छोड़ दिया जाता है। प्रतिबद्ध ऑपरेशन आमतौर पर इस अर्थ में सबसे महत्वपूर्ण है। कमिट संशोधन नियंत्रण प्रणाली को परिवर्तनों के समूह को अंतिम रूप देने और सभी उपयोगकर्ताओं के लिए उपलब्ध कराने के लिए कहते हैं। सभी पुनरीक्षण नियंत्रण प्रणालियों में परमाणु कार्य नहीं होते हैं; समवर्ती संस्करण सिस्टम में इस सुविधा का अभाव है।

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

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

संस्करण विलय
अधिकांश संस्करण नियंत्रण प्रणाली एक ही समय में कई डेवलपर्स को एक ही फाइल को संपादित करने की अनुमति देती हैं। केंद्रीय रिपॉजिटरी में परिवर्तनों की जांच करने वाला पहला डेवलपर हमेशा सफल होता है। सिस्टम केंद्रीय रिपॉजिटरी में आगे के परिवर्तनों को मर्ज (संशोधन नियंत्रण) करने की सुविधा प्रदान कर सकता है, और जब अन्य डेवलपर चेक इन करते हैं तो पहले डेवलपर से परिवर्तनों को संरक्षित कर सकते हैं।

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

एक आरक्षित संपादन की अवधारणा अनन्य लेखन पहुंच के लिए फ़ाइल को स्पष्ट रूप से लॉक करने का एक वैकल्पिक साधन प्रदान कर सकती है, तब भी जब मर्जिंग क्षमता मौजूद हो।

बेसलाइन, लेबल और टैग
अधिकांश पुनरीक्षण नियंत्रण उपकरण स्नैपशॉट (प्रोजेक्ट को लेबल करें) या स्नैपशॉट के रिकॉर्ड (इसे बेसलाइन एक्स के साथ आज़माएं) की पहचान करने की क्रिया को संदर्भित करने के लिए इन समान शर्तों (बेसलाइन, लेबल, टैग) में से केवल एक का उपयोग करेंगे। दस्तावेज़ीकरण या चर्चा में आमतौर पर बेसलाइन, लेबल या टैग में से केवल एक शब्द का उपयोग किया जाता है; उन्हें पर्यायवाची माना जा सकता है।

अधिकांश परियोजनाओं में, कुछ स्नैपशॉट दूसरों की तुलना में अधिक महत्वपूर्ण होते हैं, जैसे कि प्रकाशित रिलीज़, शाखाओं या मील के पत्थर को इंगित करने के लिए उपयोग किया जाता है।

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

कॉन्फ़िगरेशन प्रबंधन की सबसे औपचारिक चर्चा बेसलाइन (कॉन्फ़िगरेशन प्रबंधन) शब्द का उपयोग करती है।

वितरित संशोधन नियंत्रण
वितरित पुनरीक्षण नियंत्रण प्रणाली (DRCS) केंद्रीकृत प्रणालियों के क्लाइंट-सर्वर मॉडल|क्लाइंट-सर्वर दृष्टिकोण के विपरीत एक सहकर्मी से सहकर्मी दृष्टिकोण लेती है। एक एकल, केंद्रीय रिपॉजिटरी के बजाय जिस पर क्लाइंट सिंक्रोनाइज़ करते हैं, कोडबेस की प्रत्येक सहकर्मी की कार्यशील प्रति एक अच्छा विश्वास है। प्रामाणिक रिपॉजिटरी। वितरित पुनरीक्षण नियंत्रण सहकर्मी से सहकर्मी पैच (यूनिक्स) (परिवर्तन-सेट) का आदान-प्रदान करके सिंक्रनाइज़ेशन आयोजित करता है। यह एक केंद्रीकृत प्रणाली से कुछ महत्वपूर्ण अंतरों का परिणाम है: बल्कि, संचार केवल तभी आवश्यक होता है जब परिवर्तन को अन्य साथियों से या उनके पास धकेला या खींचा जाता है।
 * कोडबेस की कोई विहित, संदर्भ प्रति डिफ़ॉल्ट रूप से मौजूद नहीं है; केवल कार्यशील प्रतियाँ।
 * सामान्य ऑपरेशन (जैसे कि कमिट करना, इतिहास देखना और परिवर्तनों को वापस करना) तेज हैं, क्योंकि केंद्रीय सर्वर के साथ संवाद करने की कोई आवश्यकता नहीं है।
 * प्रत्येक कार्यशील प्रति प्रभावी रूप से कोडबेस और उसके परिवर्तन-इतिहास के दूरस्थ बैकअप के रूप में कार्य करती है, जो डेटा हानि के खिलाफ अंतर्निहित सुरक्षा प्रदान करती है।

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

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

संस्करण नियंत्रण सॉफ़्टवेयर को लाइसेंस देने की लागत के अतिरिक्त, संस्करण नियंत्रण का उपयोग करने के लिए समय और प्रयास की आवश्यकता होती है। संस्करण नियंत्रण में अंतर्निहित अवधारणाओं को समझा जाना चाहिए और चुने गए संस्करण नियंत्रण सॉफ़्टवेयर को संचालित करने के लिए आवश्यक तकनीकी विवरणों को सीखना चाहिए। संस्करण नियंत्रण सर्वोत्तम प्रथाओं को सीखा जाना चाहिए और संगठन के मौजूदा सॉफ़्टवेयर विकास प्रथाओं में एकीकृत किया जाना चाहिए। उपयोगी लाभ प्राप्त करने के लिए सर्वोत्तम प्रथाओं का पालन करने के लिए आवश्यक अनुशासन बनाए रखने के लिए प्रबंधन प्रयास की आवश्यकता हो सकती है।

एक मुख्य लाभ इतिहास को बनाए रखने और परिवर्तनों को वापस लाने की क्षमता है, जिससे डेवलपर परिवर्तनों को आसानी से पूर्ववत कर सकता है। यह डेवलपर को प्रयोग करने का अधिक अवसर देता है, जिससे मौजूदा कोड को तोड़ने का डर समाप्त हो जाता है। ब्रांचिंग तैनाती के साथ सहायता करता है। सोर्स कोड पैच (कंप्यूटिंग) का ब्रांचिंग और विलय, उत्पादन, पैकेजिंग और लेबलिंग और कोड बेस के लिए पैच का आसान अनुप्रयोग, परिनियोजन प्रक्रिया के विभिन्न चरणों से जुड़े कई कोड बेस के रखरखाव और समवर्ती विकास को सरल करता है; विकास, परीक्षण, मंचन, उत्पादन, आदि। क्षति न्यूनीकरण, जवाबदेही, प्रक्रिया और डिजाइन में सुधार, और संस्करण नियंत्रण द्वारा प्रदान किए गए रिकॉर्ड रखने से जुड़े अन्य लाभ हो सकते हैं, किसने, कब, क्यों और कैसे किया, इसकी ट्रैकिंग। यह बेहतर पुनर्मूल्यांकन की अनुमति दे सकता है कि आगे बढ़ने वाली समस्याओं और समाधानों को संबोधित करने के लिए परिवर्तन क्यों किए गए थे। पिछले संस्करणों को स्थापित किया जा सकता है और कोड की परीक्षा और संदेशों को प्रतिबद्ध करने के निष्कर्षों को सत्यापित करने के लिए परीक्षण किया जा सकता है। संस्करण नियंत्रण डिबगिंग को बहुत आसान बना सकता है। कई संस्करणों के लिए एक परीक्षण मामले का अनुप्रयोग उस परिवर्तन की शीघ्रता से पहचान कर सकता है जिसने एक बग पेश किया था। डेवलपर को संपूर्ण कोड आधार से परिचित होने की आवश्यकता नहीं है और इसके बजाय समस्या को प्रस्तुत करने वाले कोड पर ध्यान केंद्रित कर सकता है।

संस्करण नियंत्रण कई तरीकों से सहयोग को बढ़ाता है। चूंकि संस्करण नियंत्रण परस्पर विरोधी परिवर्तनों की पहचान कर सकता है, अर्थात कोड की समान पंक्तियों में किए गए असंगत परिवर्तन, डेवलपर्स के बीच समन्वय की कम आवश्यकता होती है। कमिट्स, शाखाओं, और सभी संबद्ध प्रतिबद्ध संदेशों और संस्करण लेबलों की पैकेजिंग, डेवलपर्स के बीच पल और समय दोनों में संचार में सुधार करती है। बेहतर संचार, चाहे तत्काल हो या स्थगित, कोड समीक्षा प्रक्रिया, परीक्षण प्रक्रिया और सॉफ्टवेयर विकास प्रक्रिया के अन्य महत्वपूर्ण पहलुओं में सुधार कर सकता है।

एकीकरण
कुछ अधिक उन्नत पुनरीक्षण-नियंत्रण उपकरण कई अन्य सुविधाएं प्रदान करते हैं, जिससे अन्य उपकरणों और सॉफ्टवेयर-इंजीनियरिंग प्रक्रियाओं के साथ गहन एकीकरण की अनुमति मिलती है। प्लग-इन (कंप्यूटिंग) अक्सर Oracle JDeveloper, IntelliJ IDEA, एक्लिप्स (कंप्यूटिंग), विजुअल स्टूडियो, डेल्फी (प्रोग्रामिंग भाषा), NetBeans, Xcode, और GNU Emacs (vc.el के माध्यम से) जैसे एकीकृत विकास परिवेश के लिए उपलब्ध हैं। उन्नत अनुसंधान प्रोटोटाइप उपयुक्त प्रतिबद्ध संदेश उत्पन्न करते हैं, लेकिन यह केवल उन परियोजनाओं पर काम करता है जिनका पहले से ही एक बड़ा इतिहास है, क्योंकि प्रतिबद्ध संदेश परियोजना के सम्मेलनों और विशिष्टताओं पर बहुत निर्भर हैं।

सामान्य शब्दावली
शब्दावली प्रणाली से प्रणाली में भिन्न हो सकती है, लेकिन आम उपयोग में आने वाली कुछ शर्तों में शामिल हैं:
 * बेसलाइन (कॉन्फ़िगरेशन प्रबंधन) : किसी दस्तावेज़ या स्रोत फ़ाइल का स्वीकृत पुनरीक्षण जिसमें बाद में परिवर्तन किए जा सकते हैं। देखें #आधार रेखाएँ, लेबल और टैग|आधार रेखाएँ, लेबल और टैग।
 * : लेखक और संशोधन के लिए एक खोज जिसने किसी विशेष पंक्ति को अंतिम रूप से संशोधित किया।
 * शाखाकरण (पुनरीक्षण नियंत्रण) : संस्करण नियंत्रण के तहत फाइलों का एक सेट समय पर एक बिंदु पर शाखाबद्ध या फोर्क किया जा सकता है, ताकि उस समय से आगे, उन फाइलों की दो प्रतियां अलग-अलग गति से या अलग-अलग तरीकों से एक-दूसरे से स्वतंत्र रूप से विकसित हो सकें।
 * परिवर्तन: एक परिवर्तन (या अंतर, या डेल्टा एन्कोडिंग) संस्करण नियंत्रण के तहत दस्तावेज़ में एक विशिष्ट संशोधन का प्रतिनिधित्व करता है। परिवर्तन माने जाने वाले संशोधन की ग्रैन्युलैरिटी संस्करण नियंत्रण प्रणालियों के बीच भिन्न होती है।
 * परिवर्तन सूची: परमाणु लेनदेन बहु-परिवर्तन के साथ कई संस्करण नियंत्रण प्रणालियों पर, एक परिवर्तन सूची (या सीएल), परिवर्तन सेट, अद्यतन, या पैच (कंप्यूटिंग) एक ही प्रतिबद्धता में किए गए परिवर्तनों के सेट की पहचान करता है। यह स्रोत कोड के अनुक्रमिक दृश्य का भी प्रतिनिधित्व कर सकता है, जिससे स्रोत की परीक्षा किसी विशेष चेंजलिस्ट आईडी के रूप में हो सकती है।
 * चेकआउट: चेक आउट (या सह) करने के लिए रिपॉजिटरी से एक स्थानीय कामकाजी प्रति बनाना है। एक उपयोगकर्ता एक विशिष्ट संशोधन निर्दिष्ट कर सकता है या नवीनतम प्राप्त कर सकता है। वर्किंग कॉपी का वर्णन करने के लिए 'चेकआउट' शब्द को संज्ञा के रूप में भी इस्तेमाल किया जा सकता है। जब किसी फ़ाइल को किसी साझा फ़ाइल सर्वर से चेक आउट किया गया है, तो इसे अन्य उपयोगकर्ताओं द्वारा संपादित नहीं किया जा सकता है। इसे एक होटल की तरह समझें, जब आप चेक आउट करते हैं, तो आपकी सुविधाओं तक पहुंच नहीं होती है।
 * क्लोन: क्लोनिंग का अर्थ है एक रिपॉजिटरी बनाना जिसमें किसी अन्य रिपॉजिटरी से संशोधन शामिल हैं। यह एक खाली (नए आरंभिक) रिपॉजिटरी में धकेलने या खींचने के बराबर है। एक संज्ञा के रूप में, दो रिपॉजिटरी को क्लोन कहा जा सकता है यदि उन्हें सिंक्रनाइज़ रखा जाता है, और समान संशोधन होते हैं।
 * चेंजसेट (संज्ञा): एक 'प्रतिबद्ध' या 'संशोधन' (एसवीएन) एक संशोधन है जो रिपॉजिटरी पर लागू होता है।
 * प्रतिबद्ध (संशोधन नियंत्रण) (क्रिया) : प्रतिबद्ध करने के लिए (चेक इन, सीआई या, शायद ही कभी, स्थापित करें, जमा करें या रिकॉर्ड करें) कार्यशील प्रति में किए गए परिवर्तनों को रिपॉजिटरी में वापस लिखना या विलय करना है। एक कमिट में मेटाडेटा, आमतौर पर लेखक की जानकारी और एक प्रतिबद्ध संदेश होता है जो परिवर्तन का वर्णन करता है।
 * कमिट संदेश: कमिट के साथ संग्रहीत डेवलपर द्वारा लिखित एक संक्षिप्त नोट, जो कमिट का वर्णन करता है। आदर्श रूप से, यह रिकॉर्ड करता है कि संशोधन क्यों किया गया था, संशोधन के प्रभाव या उद्देश्य का विवरण, और परिवर्तन कैसे काम करता है, इसके स्पष्ट पहलू।
 * संघर्ष: एक विरोध तब होता है जब विभिन्न पक्ष एक ही दस्तावेज़ में परिवर्तन करते हैं, और सिस्टम परिवर्तनों का समाधान करने में असमर्थ होता है। एक उपयोगकर्ता को परिवर्तनों को मिलाकर, या दूसरे के पक्ष में एक परिवर्तन का चयन करके विरोध का समाधान करना चाहिए।
 * डेल्टा संपीड़न: अधिकांश पुनरीक्षण नियंत्रण सॉफ़्टवेयर डेल्टा संपीड़न का उपयोग करता है, जो फ़ाइलों के क्रमिक संस्करणों के बीच केवल अंतर को बनाए रखता है। यह फ़ाइलों के कई अलग-अलग संस्करणों के अधिक कुशल भंडारण की अनुमति देता है।
 * डायनेमिक स्ट्रीम: एक स्ट्रीम जिसमें कुछ या सभी फ़ाइल संस्करण पैरेंट स्ट्रीम के संस्करणों के दर्पण होते हैं।
 * निर्यात: निर्यात रिपॉजिटरी से फाइलों को प्राप्त करने का कार्य है। यह चेक आउट के समान है, सिवाय इसके कि यह एक वर्किंग कॉपी में उपयोग किए गए वर्जन-कंट्रोल मेटाडेटा के बिना एक क्लीन डायरेक्टरी ट्री बनाता है। यह अक्सर सामग्री प्रकाशित करने से पहले उपयोग किया जाता है, उदाहरण के लिए।
 * लायें : पुल देखें।
 * आगे एकीकरण: मुख्य ट्रंक में किए गए परिवर्तनों को एक विकास (फीचर या टीम) शाखा में विलय करने की प्रक्रिया।
 * सिर: कभी-कभी टिप भी कहा जाता है, यह सबसे हालिया प्रतिबद्धता को संदर्भित करता है, या तो ट्रंक या शाखा में। ट्रंक और प्रत्येक शाखा का अपना सिर होता है, हालांकि हेड को कभी-कभी ट्रंक को संदर्भित करने के लिए उपयोग किया जाता है।
 * आयात: आयात पहली बार रिपॉजिटरी में एक स्थानीय निर्देशिका ट्री (जो कि वर्तमान में एक कार्यशील प्रति नहीं है) को कॉपी करने का कार्य है।
 * प्रारंभ करें : एक नया, खाली रिपॉजिटरी बनाने के लिए।
 * इंटरलीव्ड डेल्टास: कुछ रिवीजन कंट्रोल सॉफ्टवेयर इंटरलीव्ड डेल्टास का उपयोग करता है, एक ऐसी विधि जो टेक्स्ट आधारित फाइलों के इतिहास को डेल्टा कम्प्रेशन का उपयोग करने की तुलना में अधिक कुशल तरीके से संग्रहीत करने की अनुमति देती है।
 * लेबल : टैग देखें।
 * फ़ाइल लॉकिंग: जब कोई डेवलपर किसी फ़ाइल को लॉक करता है, तो कोई भी उस फ़ाइल को तब तक अपडेट नहीं कर सकता जब तक कि वह अनलॉक न हो जाए। लॉकिंग को संस्करण नियंत्रण प्रणाली, या डेवलपर्स (उर्फ सोशल लॉकिंग) के बीच अनौपचारिक संचार के माध्यम से समर्थित किया जा सकता है।
 * मेनलाइन: ट्रंक के समान, लेकिन प्रत्येक शाखा के लिए एक मेनलाइन हो सकती है।
 * विलय (पुनरीक्षण नियंत्रण) : एक विलय या एकीकरण एक ऑपरेशन है जिसमें फ़ाइल या फाइलों के सेट पर परिवर्तन के दो सेट लागू होते हैं। कुछ नमूना परिदृश्य इस प्रकार हैं:
 * * एक उपयोगकर्ता, फाइलों के एक सेट पर काम कर रहा है, अन्य उपयोगकर्ताओं द्वारा किए गए परिवर्तनों के साथ उनकी कार्यशील प्रति को अपडेट या सिंक करता है, और रिपॉजिटरी में चेक किया जाता है।
 * एक उपयोगकर्ता उन फ़ाइलों की जाँच करने का प्रयास करता है जिन्हें फ़ाइलों की जाँच के बाद से दूसरों द्वारा अपडेट किया गया है, और संशोधन नियंत्रण सॉफ़्टवेयर स्वचालित रूप से फ़ाइलों को मर्ज कर देता है (आमतौर पर, उपयोगकर्ता को संकेत देने के बाद कि क्या इसे स्वचालित मर्ज के साथ आगे बढ़ना चाहिए, और कुछ में मामले केवल ऐसा कर रहे हैं यदि विलय स्पष्ट रूप से और उचित रूप से हल किया जा सकता है)।
 * एक शाखा बनाई जाती है, फाइलों में कोड स्वतंत्र रूप से संपादित किया जाता है, और अद्यतन शाखा को बाद में एक एकल, एकीकृत ट्रंक में शामिल किया जाता है।
 * * फाइलों का एक सेट ब्रांच किया गया है, एक शाखा में ब्रांचिंग से पहले मौजूद एक समस्या को ठीक किया गया है, और फ़िक्स को फिर दूसरी शाखा में मिला दिया गया है। (इस प्रकार के चयनात्मक विलय को कभी-कभी पिछले मामले में पूर्ण विलय से अलग करने के लिए चेरी पिक के रूप में जाना जाता है।)


 * प्रचार करें: फ़ाइल सामग्री को कम नियंत्रित स्थान से अधिक नियंत्रित स्थान में कॉपी करने का कार्य। उदाहरण के लिए, उपयोगकर्ता के कार्यक्षेत्र से रिपॉजिटरी में, या स्ट्रीम से उसके माता-पिता तक।
 * खींचो, धक्का दो: एक रिपॉजिटरी से दूसरे में संशोधन कॉपी करें। पुल रिसीविंग रिपॉजिटरी द्वारा शुरू किया जाता है, जबकि स्रोत द्वारा पुश शुरू किया जाता है। फ़ेच का उपयोग कभी-कभी पुल के पर्याय के रूप में किया जाता है, या इसका मतलब है कि पुल के बाद अपडेट होता है।
 * पुल अनुरोध: एक डेवलपर दूसरों से उनके पुश किए गए परिवर्तनों को मर्ज करने के लिए कह रहा है।
 * रिपॉजिटरी (संस्करण नियंत्रण): रिपॉजिटरी (या रेपो) वह जगह है जहां फाइलों का वर्तमान और ऐतिहासिक डेटा संग्रहीत किया जाता है, अक्सर एक सर्वर पर। कभी-कभी डिपो भी कहा जाता है।
 * हल करें: एक ही दस्तावेज़ में विभिन्न परिवर्तनों के बीच विरोध को संबोधित करने के लिए उपयोगकर्ता के हस्तक्षेप का कार्य।
 * रिवर्स इंटीग्रेशन: विभिन्न टीम शाखाओं को वर्जनिंग सिस्टम के मुख्य ट्रंक में मर्ज करने की प्रक्रिया।
 * पुनरीक्षण: इसके अलावा संस्करण: एक सॉफ्टवेयर संस्करण किसी भी रूप में परिवर्तन है। एसवीके में, रिपॉजिटरी में पूरे पेड़ के एक समय में एक संशोधन स्थिति है।
 * साझा करें: एक ही समय में एक फ़ाइल या फ़ोल्डर को कई शाखाओं में उपलब्ध कराने का कार्य। जब एक साझा फ़ाइल को एक शाखा में बदला जाता है, तो इसे अन्य शाखाओं में बदल दिया जाता है।
 * स्ट्रीम: ब्रांच्ड फाइलों के लिए एक कंटेनर जिसका ऐसे अन्य कंटेनरों से संबंध ज्ञात है। धाराएँ एक पदानुक्रम बनाती हैं; प्रत्येक धारा अपनी मूल धारा से विभिन्न गुण (जैसे संस्करण, नामस्थान, कार्यप्रवाह नियम, ग्राहक, आदि) प्राप्त कर सकती है।
 * पुनरीक्षण टैग: एक टैग या लेबल समय में एक महत्वपूर्ण स्नैपशॉट को संदर्भित करता है, जो कई फाइलों में संगत होता है। उस बिंदु पर इन फ़ाइलों को उपयोगकर्ता के अनुकूल, सार्थक नाम या संशोधन संख्या के साथ टैग किया जा सकता है। देखें #आधार रेखाएँ, लेबल और टैग|आधार रेखाएँ, लेबल और टैग।
 * ट्रंक (सॉफ्टवेयर): विकास की अनूठी रेखा जो एक शाखा नहीं है (कभी-कभी इसे बेसलाइन, मेनलाइन या मास्टर भी कहा जाता है) )
 * अपडेट: एक अपडेट (या सिंक, लेकिन सिंक का मतलब संयुक्त पुश और पुल भी हो सकता है) रिपॉजिटरी में किए गए बदलावों (उदाहरण के लिए, अन्य लोगों द्वारा) को स्थानीय वर्किंग कॉपी में मर्ज कर देता है। अद्यतन कुछ सीएम टूल्स (सीएम +, पीएलएस, एसएमएस) द्वारा परिवर्तन पैकेज अवधारणा के लिए इस्तेमाल किया जाने वाला शब्द भी है (परिवर्तन सूची देखें)। पुनरीक्षण नियंत्रण प्रणालियों में चेकआउट का पर्यायवाची जिसके लिए प्रत्येक रिपॉजिटरी में ठीक एक कार्यशील प्रति (वितरित प्रणालियों में सामान्य) की आवश्यकता होती है
 * ताला खोलना: ताला खोलना।
 * वर्किंग कॉपी: वर्किंग कॉपी एक विशिष्ट समय या संशोधन पर रिपॉजिटरी से फाइलों की स्थानीय कॉपी होती है। रिपॉजिटरी में फाइलों पर किए गए सभी काम शुरू में वर्किंग कॉपी पर किए जाते हैं, इसलिए यह नाम है। संकल्पनात्मक रूप से, यह एक सैंडबॉक्स (सॉफ्टवेयर विकास) है।

यह भी देखें
• Change control

• Changelog

• Blockchain

• Comparison of version-control software

• Comparison of source-code-hosting facilities

• Distributed version control

• List of version-control software

• Non-linear editing

• Software configuration management

• Software versioning

• Versioning file system

इस पेज में लापता आंतरिक लिंक की सूची

 * विशिष्टता (तकनीकी मानक)
 * लिखना
 * सामग्री प्रबंधन प्रणाली
 * सोर्स कोड
 * वितरित संशोधन नियंत्रण
 * निर्देशित अचक्रीय ग्राफ
 * विलय (संशोधन नियंत्रण)
 * भंडार (संस्करण नियंत्रण)
 * समवर्ती पहुँच
 * विन्यास प्रबंधन
 * नेक नीयत
 * को़ड समीक्षा
 * एकीकृत विकास पर्यावरण
 * ग्रहण (कंप्यूटिंग)
 * आधार रेखा (कॉन्फ़िगरेशन प्रबंधन)
 * संशोधन टैग
 * सॉफ्टवेयर वर्जनिंग

बाहरी कड़ियाँ

 * . The basics of version control.
 * . The basics of version control.