课程表

SVN课程

工具箱
速查手册

SVN 更新过程

当前位置:免费教程 » 软件/图像 » SVN

Jerry 提交了他第一个版本的代码. 但是他想他应该写两个函数用来接收输入和显示数组,在修改之后, array.c 看起来像是下面这样。

  1. #include <stdio.h>
  2. #define MAX 16
  3. void accept_input(int *arr, int n) {
  4. int i;
  5. for (i = 0; i < n; ++i)
  6. scanf("%d", &arr[i]);
  7. }
  8. void display(int *arr, int n) {
  9. int i;
  10. for (i = 0; i < n; ++i)
  11. printf("|%d| ", arr[i]);
  12. printf("\n");
  13. }
  14. int main(void) {
  15. int i, n, arr[MAX];
  16. printf("Enter the total number of elements: ");
  17. scanf("%d", &n);
  18. printf("Enter the elements\n");
  19. accept_input(arr, n);
  20. printf("Array has following elements\n");
  21. display(arr, n);
  22. return 0;
  23. }

Jerry 编译和测试了他的代码,现在他准备提交他的更改。在此之前,他想要用下面的命令查看更改。

  1. [jerry@CentOS trunk]$ svn diff

上面的命令将会产生下面的效果

  1. Index: array.c
  2. ===================================================================
  3. --- array.c (revision 2)
  4. +++ array.c (working copy)
  5. @@ -2,6 +2,24 @@
  6. #define MAX 16
  7. +void accept_input(int *arr, int n)
  8. +{
  9. + int i;
  10. +
  11. + for (i = 0; i & n; ++i)
  12. + scanf("%d", &arr[i]);
  13. +}
  14. +
  15. +void display(int *arr, int n)
  16. +{
  17. + int i;
  18. +
  19. + for (i = 0; i < n; ++i)
  20. + printf("|%d| ", arr[i]);
  21. +
  22. + printf("\n");
  23. +}
  24. +
  25. int main(void)
  26. {
  27. int i, n, arr[MAX];
  28. @@ -10,15 +28,10 @@
  29. scanf("%d", &n);
  30. printf("Enter the elements\n");
  31. + accept_input(arr, n);
  32. - for (i = 0; i < n; ++i)
  33. - scanf("%d", &arr[i]);
  34. -
  35. printf("Array has following elements\n");
  36. - for (i = 0; i < n; ++i)
  37. - printf("|%d| ", arr[i]);
  38. -
  39. - printf("\n");
  40. + display(arr, n);
  41. return 0;
  42. }

对于新增加的行, Subversion 在前面加上了 + 号,并且用 - 号标记了删除掉的行。现在, Jerry 尝试使用下面的命令来提交他的更改:

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

上面的命令将会产生下面的效果

  1. Sending trunk/array.c
  2. svn: Commit failed (details follow):
  3. svn: File or directory 'array.c' is out of date; try updating
  4. svn: resource out of date; try updating

Subversion 不会允许 Jerry 提交他的更改,因为 Tom 已经修改了仓库,所以 Jerry 的工作副本已经失效。为了避免两人的代码被互相覆盖,Subversion 不允许他进行这样的操作。Jerry 在提交他的更改之前必须先更新工作副本。所以他使用了 update 命令,如下:

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

Subversion 在这个文件前面加上了字母 G 标记, 这意味着这个文件是被合并过的。

  1. [jerry@CentOS trunk]$ svn diff

上面的命令将会产生下面的效果

  1. Index: array.c
  2. ===================================================================
  3. --- array.c (revision 3)
  4. +++ array.c (working copy)
  5. @@ -2,6 +2,24 @@
  6. #define MAX 16
  7. +void accept_input(int *arr, int n)
  8. +{
  9. + int i;
  10. +
  11. + for (i = 0; i < n; ++i)
  12. + scanf("%d", &arr[i]);
  13. +}
  14. +
  15. +void display(int *arr, int n)
  16. +{
  17. + int i;
  18. +
  19. + for (i = 0; i < n; ++i)
  20. + printf("|%d| ", arr[i]);
  21. +
  22. + printf("\n");
  23. +}
  24. +
  25. int main(void)
  26. {
  27. int i, n, arr[MAX];
  28. @@ -15,15 +33,10 @@
  29. }
  30. printf("Enter the elements\n");
  31. + accept_input(arr, n);
  32. - for (i = 0; i < n; ++i)
  33. - scanf("%d", &arr[i]);
  34. -
  35. printf("Array has following elements\n");
  36. - for (i = 0; i < n; ++i)
  37. - printf("|%d| ", arr[i]);
  38. -
  39. - printf("\n");
  40. + display(arr, n);
  41. return 0;
  42. }

Subversion 只展示出了 Jerry 的更改,但是 array.c 文件被合并了。如果你仔细观察,Subversion 现在展示的版本号是3。在之前的输出中,它展示的版本号是2。只是展示出了谁对其进行了更改和更改的目的。

  1. jerry@CentOS trunk]$ svn log
  2. ------------------------------------------------------------------------
  3. r3 | tom | 2013-08-18 20:21:50 +0530 (Sun, 18 Aug 2013) | 1 line
  4. Fix array overflow problem
  5. ------------------------------------------------------------------------
  6. r2 | jerry | 2013-08-17 20:40:43 +0530 (Sat, 17 Aug 2013) | 1 line
  7. Initial commit
  8. ------------------------------------------------------------------------
  9. r1 | jerry | 2013-08-04 23:43:08 +0530 (Sun, 04 Aug 2013) | 1 line
  10. Create trunk, branches, tags directory structure
  11. ------------------------------------------------------------------------

现在 Jerry 的工作目录是和仓库同步的,他现在可以安全地提交更改了。

  1. [jerry@CentOS trunk]$ svn commit -m "Add function to accept input and to display array contents"
  2. Sending trunk/array.c
  3. Transmitting file data .
  4. Committed revision 4.
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号