SVN-업데이트 프로세스
Jerry 는 코드의 첫 번째 버전을 커밋했습니다. 그러나 그는 입력을 받아들이고 배열 내용을 표시하기 위해 두 개의 함수를 작성해야한다고 생각합니다. 수정 후 array.c 는 다음과 같이 보입니다.
#include <stdio.h>
#define MAX 16
void accept_input(int *arr, int n) {
int i;
for (i = 0; i < n; ++i)
scanf("%d", &arr[i]);
}
void display(int *arr, int n) {
int i;
for (i = 0; i < n; ++i)
printf("|%d| ", arr[i]);
printf("\n");
}
int main(void) {
int i, n, arr[MAX];
printf("Enter the total number of elements: ");
scanf("%d", &n);
printf("Enter the elements\n");
accept_input(arr, n);
printf("Array has following elements\n");
display(arr, n);
return 0;
}
Jerry 는 자신의 코드를 컴파일 및 테스트하고 변경 사항을 커밋 할 준비가되었습니다. 그 전에 그는 다음 명령을 사용하여 변경 사항을 검토하려고합니다.
[jerry@CentOS trunk]$ svn diff
위의 명령은 다음과 같은 결과를 생성합니다.
Index: array.c
===================================================================
--- array.c (revision 2)
+++ array.c (working copy)
@@ -2,6 +2,24 @@
#define MAX 16
+void accept_input(int *arr, int n)
+{
+ int i;
+
+ for (i = 0; i & n; ++i)
+ scanf("%d", &arr[i]);
+}
+
+void display(int *arr, int n)
+{
+ int i;
+
+ for (i = 0; i < n; ++i)
+ printf("|%d| ", arr[i]);
+
+ printf("\n");
+}
+
int main(void)
{
int i, n, arr[MAX];
@@ -10,15 +28,10 @@
scanf("%d", &n);
printf("Enter the elements\n");
+ accept_input(arr, n);
- for (i = 0; i < n; ++i)
- scanf("%d", &arr[i]);
-
printf("Array has following elements\n");
- for (i = 0; i < n; ++i)
- printf("|%d| ", arr[i]);
-
- printf("\n");
+ display(arr, n);
return 0;
}
새로 추가 된 라인의 경우 Subversion은 + 줄 앞에 서명하고 제거 된 줄에 대해 표시 -기호. 이제 Jerry는 다음 명령을 사용하여 변경 사항을 커밋하려고합니다.
[jerry@CentOS trunk]$ svn commit -m "Add function to accept input and to display array contents"
위의 명령은 다음과 같은 결과를 생성합니다.
Sending trunk/array.c
svn: Commit failed (details follow):
svn: File or directory 'array.c' is out of date; try updating
svn: resource out of date; try updating
Tom 이 이미 저장소를 수정했고 Jerry의 작업 복사본이 오래 되었기 때문에 Subversion은 Jerry의 변경 사항 을 커밋 할 수 없습니다 . 서로의 변경 사항을 덮어 쓰지 않도록 Subversion은이 작업을 실패합니다. Jerry 는 변경 사항을 커밋하기 전에 작업 복사본을 업데이트해야합니다. 그래서 그는 아래와 같이 업데이트 명령을 사용합니다.
[jerry@CentOS trunk]$ svn update
G array.c
Updated to revision 3.
Subversion은 편지를 보여줍니다 G 이 파일이 병합되었음을 의미합니다.
[jerry@CentOS trunk]$ svn diff
위의 명령은 다음과 같은 결과를 생성합니다.
Index: array.c
===================================================================
--- array.c (revision 3)
+++ array.c (working copy)
@@ -2,6 +2,24 @@
#define MAX 16
+void accept_input(int *arr, int n)
+{
+ int i;
+
+ for (i = 0; i < n; ++i)
+ scanf("%d", &arr[i]);
+}
+
+void display(int *arr, int n)
+{
+ int i;
+
+ for (i = 0; i < n; ++i)
+ printf("|%d| ", arr[i]);
+
+ printf("\n");
+}
+
int main(void)
{
int i, n, arr[MAX];
@@ -15,15 +33,10 @@
}
printf("Enter the elements\n");
+ accept_input(arr, n);
- for (i = 0; i < n; ++i)
- scanf("%d", &arr[i]);
-
printf("Array has following elements\n");
- for (i = 0; i < n; ++i)
- printf("|%d| ", arr[i]);
-
- printf("\n");
+ display(arr, n);
return 0;
}
Subversion은 Jerry의 변경 사항 만 표시 하지만 array.c 파일은 병합됩니다. 주의 깊게 살펴보면 Subversion은 이제 개정 번호 3을 표시하고 있습니다. 이전 출력에서는 개정 번호 2를 표시했습니다. 파일을 변경 한 사람과 목적을 검토하십시오.
jerry@CentOS trunk]$ svn log
------------------------------------------------------------------------
r3 | tom | 2013-08-18 20:21:50 +0530 (Sun, 18 Aug 2013) | 1 line
Fix array overflow problem
------------------------------------------------------------------------
r2 | jerry | 2013-08-17 20:40:43 +0530 (Sat, 17 Aug 2013) | 1 line
Initial commit
------------------------------------------------------------------------
r1 | jerry | 2013-08-04 23:43:08 +0530 (Sun, 04 Aug 2013) | 1 line
Create trunk, branches, tags directory structure
------------------------------------------------------------------------
이제 Jerry의 작업 복사본이 저장소와 동기화되어 안전하게 변경 사항을 커밋 할 수 있습니다.
[jerry@CentOS trunk]$ svn commit -m "Add function to accept input and to display array contents"
Sending trunk/array.c
Transmitting file data .
Committed revision 4.