SVN-실수 수정

Jerry가 실수로 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

Jerryarray.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가 선형 검색 작업을위한 코드를 추가한다고 가정 해 보겠습니다. 확인 후 그는 자신의 변경 사항을 커밋합니다.

[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는 Tom이하는 일이 궁금합니다. 그래서 그는 Subversion 로그 메시지를 확인합니다.

[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

로그 메시지를 본 후 Jerry는 자신이 심각한 실수를 저질렀 음을 알게됩니다. Tom은 이미 선형 검색보다 나은 이진 검색 작업을 구현했기 때문입니다. 그의 코드는 중복되며 이제 Jerry는 변경 사항을 이전 개정으로 되돌려 야합니다. 따라서 먼저 저장소의 현재 개정판을 찾으십시오. 현재 저장소는 개정판 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.