现在的位置: 首页 > 综合 > 正文

CVS的使用

2013年10月02日 ⁄ 综合 ⁄ 共 2769字 ⁄ 字号 评论关闭
文章目录

 

<!--[if !supportLists]-->1. <!--[endif]-->创建cvs仓库

#mkdir /cvsroot

#chmod 777 /cvsroot

$cvs –d /cvsroot init

$export CVSROOT=/cvsroot

首先使用root帐户在根目录下创建一个cvsroot目录,并修改目录访问权限为所有人都可以访问。再用普通用户创建并初始化cvs仓库。最后设置CVSROOT环境变量(或在bashrc文件中配置,或/etc/profile文件中配置),供以后使用。

<!--[if !supportLists]-->2. <!--[endif]-->向cvsroot中添加目录

$cd /home/qibing/myproject

$cvs import –m “first time” myproject v1 r1

到需要加到cvs中的工程目录下,允许import命令把目录下的所有文件和目录添加到cvs的管理中。注意,尽量删除掉myproject目录下对编译和make没有影响的文件和目录,比如.o、.dep、可执行文件等等,包括COPYING等根据系统automake或autoconf生成的文件和目录。

<!--[if !supportLists]-->3. <!--[endif]-->使用cvs

$mkdir /home/qibing/cvsroot

$cd /home/qibing/cvsroot

$cvs checkout myproject

先在自己的目录下创建一个用于cvs管理的目录cvsroot,这时可以从cvs服务器上checkout工程目录了。
下面是几个经常用到的cvs管理的命令,下面的命令都是在本地cvs工程目录myproject中使用,

$cvs up –AC

更新至最新主线

$cvs tag –b mytag

在主线上打分支标签mytag

$cvs up –r mytag

进入到分支mytag中,此后的修改都是在分支上进行

$cvs up –j mytag

把分支mytag的修改合入到主线,并更新至主线

$cvs st –v | more

查看打过的标签,包括主线和分支;和当前所在的分支标签或主线

$cvs ci –m “something words”

把修改合入到当前所在的分支标签或主线上

$cvs tag mymaintag

在主线上打标签,以标记软件版本或开发的阶段

$cvs up ./

检查是否有冲突

<!--[if !supportLists]-->4. <!--[endif]-->向cvsroot中添加新加的文件

$cd /home/qibing/cvsroot/myproject

$cvs add file.c

$cvs commit –m “first add” file.c

首先到本地cvs目录中,用add命令添加文件,再把此文件commit上到cvs中。

1. 检出源代码操作(cvs checkout)

  • 将项目工作库目录取到个人工作库:cvs checkout dirname
  • 将项目工作库中某个文件取到本地个人工作库:cvs checkout filename

2. 将文件同步到最新的版本(cvs update)

   开发人员每天开始工作前,请将项目工作库中的最新版本代码文件取到个人工作库中,养成"先同步,后修改"的习惯;
   更新单个文件:cvs update file_name
   更新目录:cvs update (不指定文件名,cvs将同步所有子目录下的文件)
   注意:第一次导出文件以后,就不是通过cvs checkout来同步文件了,而是要进入刚才cvs checkout project_name导出的project_name目录下进行具体文件的版本同步(添加,修改,删除)操作。

3. 文件提交(cvs commit)

   确认文件修改写入CVS库:cvs commit -m "注释内容" file_name;

   建议每次文件提交都只修改一个文件,以避免多个文件以同样注释commit到CVS库里了;每次确认提交时,请认真填写修改注释,以帮助其他开发人员了解修改的原因;

 

4. 添加(cvs add)

   添加某个目录操作:cvs add dir_name
   添加某个文件操作:cvs add new_file;
   然后确认添加文件并注释
    cvs commit -m "write some comments here"
  对于图片,Word文档等非纯文本的项目,需要使用cvs add -kb选项按2进制文件方式导入,否则有可能出现文件被破坏的情况;
   cvs add -kb readme.doc

5. 删除文件(cvs rm)

  将某个文件物理删除操作:cvs remove -f file_name
  确认删除文件并注释cvs commit -m "why delete file"
  查看修改历史(cvs log)
  查看日志操作命令:
    cvs log file_name
    cvs log dirname
  操作历史命令:cvs history file_name
  查看版本操作:cvs status -v filename
  查看当前文件不同版本的区别:
    cvs diff file_name
    cvs diff -c file_name 查看对照的输出

6. 更名
   cvs里没有cvs move或cvs rename两个命令;
     可先移动老命名文件:cvs remove old_file_name;
     然后再增加新命名文件实现更名操作:cvs add new_file_name;
    例:将文件tt.c改名为test.c,具体操作如下
      mv tt.c test.c
      cvs remove -f tt.c
      cvs commit -m "remove for rename" tt.c
      cvs add test.c

7. 导出不带CVS目录的源代码文件
   每个开发目录下,CVS都创建了一个CVS/目录。里面有文件用于记录当前目录和CVS库之间的对应信息。项目发布的时候一般不希望把文件目录还带着含有CVS信息的CVS目录导出,这个一次性的导出过程使用cvs export命令,不过export只能针对一个TAG或者日期导出;
   cvs export -r release1 project_name;
   cvs export -D 20021023 project_name
   cvs export -D now project_name

8. 基线标识
   多个文件各自版本号不一样,项目到一定阶段,可以给所有文件统一指定一个阶段里程碑版本号,方便以后按照这个阶段里程碑版本号导出项目,同时也是项目的多个分支开发的基础;
   确认版本基线cvs tag release_1_0
   开始一个新的版本基线;
      cvs commit -r 2 标记所有文件开始进入2.0的开发
      cvs update -j release_1_0_patch_1

抱歉!评论已关闭.