SVN 更新過程

2018-08-12 21:14 更新

SVN 更新過程

Jerry 提交了他第一個版本的代碼. 但是他想他應(yīng)該寫兩個函數(shù)用來接收輸入和顯示數(shù)組,在修改之后, 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 編譯和測試了他的代碼,現(xiàn)在他準(zhǔn)備提交他的更改。在此之前,他想要用下面的命令查看更改。

[jerry@CentOS trunk]$ svn diff

上面的命令將會產(chǎn)生下面的效果

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 在前面加上了 + 號,并且用 - 號標(biāo)記了刪除掉的行。現(xiàn)在, Jerry 嘗試使用下面的命令來提交他的更改:

[jerry@CentOS trunk]$ svn commit -m "Add function to accept input and to display array contents"

上面的命令將會產(chǎn)生下面的效果

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

Subversion 不會允許 Jerry 提交他的更改,因為 Tom 已經(jīng)修改了倉庫,所以 Jerry 的工作副本已經(jīng)失效。為了避免兩人的代碼被互相覆蓋,Subversion 不允許他進(jìn)行這樣的操作。Jerry 在提交他的更改之前必須先更新工作副本。所以他使用了 update 命令,如下:

[jerry@CentOS trunk]$ svn update
G    array.c
Updated to revision 3.

Subversion 在這個文件前面加上了字母 G 標(biāo)記, 這意味著這個文件是被合并過的。

[jerry@CentOS trunk]$ svn diff

上面的命令將會產(chǎn)生下面的效果

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 文件被合并了。如果你仔細(xì)觀察,Subversion 現(xiàn)在展示的版本號是3。在之前的輸出中,它展示的版本號是2。只是展示出了誰對其進(jìn)行了更改和更改的目的。

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
------------------------------------------------------------------------

現(xiàn)在 Jerry 的工作目錄是和倉庫同步的,他現(xiàn)在可以安全地提交更改了。

[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.
以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號