SVN - गलतियों को ठीक करें
मान लीजिए कि जैरी अकस्मात array.c फ़ाइल को संशोधित करता है और उसे संकलन त्रुटियाँ हो रही हैं। अब वह बदलावों को दूर फेंकना चाहता है। इस स्थिति में, 'रिवर्ट' ऑपरेशन मदद करेगा। रिवर्ट ऑपरेशन किसी स्थानीय परिवर्तन को फ़ाइल या निर्देशिका में बदल देगा और किसी भी विवादित स्थिति को हल कर देगा।
[jerry@CentOS trunk]$ svn status
उपरोक्त आदेश निम्नलिखित परिणाम का उत्पादन करेगा।
M array.c
आइए निम्नानुसार सरणी बनाने का प्रयास करें:
[jerry@CentOS trunk]$ make array
उपरोक्त आदेश निम्नलिखित परिणाम का उत्पादन करेगा।
cc array.c -o array
array.c: In function ‘main’:
array.c:26: error: ‘n’ undeclared (first use in this function)
array.c:26: error: (Each undeclared identifier is reported only once
array.c:26: error: for each function it appears in.)
array.c:34: error: ‘arr’ undeclared (first use in this function)
make: *** [array] Error 1
जैरी array.c फ़ाइल पर 'रिवर्ट' ऑपरेशन करता है ।
[jerry@CentOS trunk]$ svn revert array.c
Reverted 'array.c'
[jerry@CentOS trunk]$ svn status
[jerry@CentOS trunk]$
अब कोड संकलित करें।
[jerry@CentOS trunk]$ make array
cc array.c -o array
रिवर्ट ऑपरेशन के बाद, उसकी वर्किंग कॉपी वापस अपनी मूल स्थिति में आ जाती है। रिवर्ट ऑपरेशन एक एकल फ़ाइल के साथ-साथ एक पूर्ण निर्देशिका को वापस ला सकता है। किसी निर्देशिका को वापस करने के लिए, नीचे दिखाए गए अनुसार -R विकल्प का उपयोग करें।
[jerry@CentOS project_repo]$ pwd
/home/jerry/project_repo
[jerry@CentOS project_repo]$ svn revert -R trunk
अब तक, हमने देखा है कि परिवर्तनों को कैसे वापस किया जाए, जो कि कार्यशील प्रतिलिपि में किया गया है। लेकिन अगर आप एक प्रतिबद्ध संशोधन वापस करना चाहते हैं तो क्या होगा! संस्करण नियंत्रण प्रणाली उपकरण रिपॉजिटरी से इतिहास को हटाने की अनुमति नहीं देता है। हम केवल इतिहास को जोड़ सकते हैं। यह तब भी होगा जब आप रिपॉजिटरी से फ़ाइलों को हटा देंगे। एक पुराने संशोधन को पूर्ववत करने के लिए, हमें पुराने संशोधन में जो भी बदलाव किए गए थे, उन्हें उल्टा करना होगा और फिर एक नया संशोधन करना होगा। इसे रिवर्स मर्ज कहा जाता है।
मान लीजिए कि जैरी रैखिक खोज ऑपरेशन के लिए एक कोड जोड़ता है। सत्यापन के बाद वह अपने बदलाव करता है।
[jerry@CentOS trunk]$ svn diff
Index: array.c
===================================================================
--- array.c (revision 21)
+++ array.c (working copy)
@@ -2,6 +2,16 @@
#define MAX 16
+int linear_search(int *arr, int n, int key)
+{
+ int i;
+
+ for (i = 0; i < n; ++i)
+ if (arr[i] == key)
+ return i;
+ return -1;
+}
+
void bubble_sort(int *arr, int n)
{
int i, j, temp, flag = 1;
[jerry@CentOS trunk]$ svn status
? array
M array.c
[jerry@CentOS trunk]$ svn commit -m "Added code for linear search"
Sending trunk/array.c
Transmitting file data .
Committed revision 22.
जेरी इस बात को लेकर उत्सुक है कि टॉम क्या कर रहा है। इसलिए वह तोड़फोड़ लॉग संदेशों की जाँच करता है।
[jerry@CentOS trunk]$ svn log
उपरोक्त आदेश निम्नलिखित परिणाम का उत्पादन करेगा।
------------------------------------------------------------------------
r5 | tom | 2013-08-24 17:15:28 +0530 (Sat, 24 Aug 2013) | 1 line
Add binary search operation
------------------------------------------------------------------------
r4 | jerry | 2013-08-18 20:43:25 +0530 (Sun, 18 Aug 2013) | 1 line
Add function to accept input and to display array contents
लॉग संदेशों को देखने के बाद, जेरी को पता चलता है कि उसने एक गंभीर गलती की है। क्योंकि टॉम ने पहले से ही द्विआधारी खोज ऑपरेशन को लागू किया था, जो रैखिक खोज से बेहतर है; उसका कोड बेमानी है, और अब जेरी को अपने परिवर्तनों को पिछले संशोधन में वापस लाना है। तो, पहले रिपॉजिटरी के वर्तमान संशोधन को ढूंढें। वर्तमान में, रिपॉजिटरी संशोधन 22 पर है और हमें इसे पिछले संशोधन यानी संशोधन 21 पर वापस लाना होगा।
[jerry@CentOS trunk]$ svn up
At revision 22.
[jerry@CentOS trunk]$ svn merge -r 22:21 array.c
--- Reverse-merging r22 into 'array.c':
U array.c
[jerry@CentOS trunk]$ svn commit -m "Reverted to revision 21"
Sending trunk/array.c
Transmitting file data .
Committed revision 23.