- SVN 教程
- SVN - 主頁
- SVN - 基本概念
- SVN - 環境設定
- SVN - 生命週期
- SVN - 簽出流程
- SVN - 執行更改
- SVN - 稽核更改
- SVN - 更新流程
- SVN - 修復錯誤
- SVN - 解決衝突
- SVN - 標記
- SVN - 分支
- SVN 實用資源
- SVN - 快速指南
- SVN - 實用資源
- SVN - 討論
SVN - 更新流程
傑瑞已經提交了程式碼的第一版。但他認為他應該編寫兩個函式來接受輸入和顯示陣列內容。修改後,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@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@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
Subversion 不允許提交 傑瑞的更改,因為 湯姆已經修改了儲存庫,而 傑瑞的工作副本已過期。為了避免互相覆蓋更改,Subversion 失敗了此操作。傑瑞必須在提交更改前更新工作副本。因此,他使用如下所示的更新命令。
[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 僅顯示了 傑瑞的更改,但 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@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.
廣告