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.