Entries tagged with “cvs”.


1.登录:
$export  CVSROOT=:pserver:username@the_server_name:/home/cvsroot  
Note:pserver是访问方式,如果服务器设置的是口令认证,则是 pserver。
      username是  CVS服务器的用户名,可以根据你的设置修改;
      the_server_name是CVS服务器的名称或者IP地址;
      /home/cvsroot是你的CVS服务器的CVSROOT目录,根据你的CVS服务器设置做修改或者询问管理员.
登陆CVS服务器:  
$cvs  login
这时候cvs会问你口令,请把你在CVS服务器上的口令敲进去:
Passwd:xxxxxxxx
2. 提交项目–import
   cvs import [-options] repository vendortag releasetag…
Note: 该命令将当前目录下的所有文件(包括子目录)导入源代码储存库。
    repository :项目名称,在CVS服务器上会创建以这个名字命名的仓库。
    vendortag :  项目分支的总标记。(不常用)
    releasetag :标识文件的输入层次的标记。 (一般用start)
  使用import提交项目的时候,CVS会要求对项目进行说明。在默认状态下,CVS会弹出文本编辑器。用户也可以用-m “log_message”来输入说明信息。
例如
$cvs import -m “upload the first time as new module” judecvs v_0_0_1 start
 
提示:import 一般在第一次导入module时使用。后期修改文件后可直接使用commit命令提交修改的文件。
  
3. 从CVS导出项目–checkout
   cvs checkout [options] modules…
    此命令将源代码储存库中已有的项目导出到当前目录。
    modules :项目名称
例如,从仓库中检索出judecvs项目的源文件. 
$cvs  checkout  judecvs
4.CVS 主要命令—update 更新当前工作目录中的文件
  cvs update [-options] [files...]
   此命令比较指定CVS源码库中的文件和当前目录下的文件,如果CVS源码库中有更高版本的源文件,则更新当前目录下的文件。此命令只有在checkout命令使用过后才能使用。
   在执行update命令时,CVS并不是简单的将新版本覆盖当前文件,而是试图将新版本所做的修改添加到当前文件中去。如果发生冲突,CVS会以字符串“<<<<<<”和“>>>>>>”来表示冲突发生。这时候你可以修改文件,重新提交。
提示:如果你已经做过一次checkout了,那么不需要重新checkout,只需要进入cvstest项目的目录,更新一把就行了:
  
例如:
$cd  judecvs  
$cvs  update
5.CVS 主要命令—status 如果你不想直接更新,只是想看看有没有更新的东西,那么:  
$cvs  status
会给每个文件有一份状态报告,类似这样:  
==================================================
File:  client.c                    Status:  Up-to-date  
      Working  revision:        1.1.1.1  ‘Some  Date’  
      Repository  revision:  1.2          /home2/cvsroot/judecvs/client.c,v
  
这里最重要的就是  Status  栏,这里总共可能有四种状态:  
Up-to-date:表明你要到的文件是最新的.  
Locally  Modified:表明你曾经修改过该文件,但还没有提交,你的版本比仓库里的新.  
Needing  Patch:表明有人已经修改过该文件并且已经提交了!你的版本比仓库里的旧.  
Needs  Merge:表明你曾经修改国该文件,但是别人也修改了这个文件,而且还提交给仓库了!
6.CVS 主要命令—commit 保存修改到CVS中
  cvs commit  [-lnR]  [-m 'log_message' | -f file] [-r revision] [files...]
   此命令将当前目录下的源代码与CVS中最新版本比较,并进行更新。
   [-m ‘log_message‘ ] :输入修改说明。
   [-r revision] :指定版本。
   [files...] :指定修改文件。
$cvs  commit  -m  “add XXX function”   client.c
系统会提示
CVS: ———————————————————————-
CVS: Enter Log.  Lines beginning with `CVS:’ are removed automatically
CVS:
CVS: Committing in .
CVS:
CVS: Modified Files:
CVS:    client.c
CVS: ———————————————————————-

退出后,系统询问是否continue,输入c,则完成checkin  
Log message unchanged or not specified
a)bort, c)ontinue, e)dit, !)reuse this message unchanged for remaining dirs
Action: (continue) c
Checking in client.c;
/home2/cvsroot/judecvs/client.c,v  <–  client.c
new revision: 1.2; previous revision: 1.1
done

如果CVS上文件已经有其他人更新,也就是我当前工作的不是最新版本,系统提示commit失败,这时候需要先update,然后把整合文件再commit.
cvs server: Up-to-date check failed for `client.c’
cvs [server aborted]: correct above errors first!
cvs commit: saving log message in /tmp/cvsCEjA9N
提示:修改文件之前先update或者先查看文件状态,确认当前工作版本是最新版本。
7.添加文件到项目中—add 
   cvs add [-k kflag] [-m 'message'] files…
    此命令并不真正添加文件,只是将文件注册到项目中,要真正添加文件,还要使用commit命令。
 例如:
$cvs add -m “test add” testadd.c
提示:
cvs server: scheduling file `testadd.c’ for addition on branch `v_0_0_2′
cvs server: use ‘cvs commit’ to add this file permanently
$cvs commit

同commit过程一样,CVS将testadd.c添加到项目中

同commit过程一样,CVS将testadd.c添加到项目中
8.CVS 主要命令—remove 从项目中删除文件
  cvs remove [-k kflag] [-m 'message'] files…
   和add命令一样,此命令并不真正删除文件,只是将文件从项目中取消,要真正删除文件,还要使用commit命令。
  e.g.
  $rm testadd.c
  $cvs rm testadd.c
系统提示
cvs server: scheduling `testadd.c’ for removal
cvs server: use ‘cvs commit’ to remove this file permanently

 
 $cvs  commit testadd.c
 此时,CVS才将testadd.c从项目的最新版本中删除,但是如果它有以前的版本,以前版本依然存在。

CVS想必做软件开发的都听说过,那么怎么才能让开发人员享受这一便利工具呢?当然是装个CVS服务器了。
Windows下有个CVSNT,没用过,据说问题比较多。Linux下当然简单了,Debian下更是如此。
CVS服务器的配置
CVS想必做软件开发的都听说过,那么怎么才能让开发人员享受这一便利工具呢?当然是装个CVS服务器了。
Windows下有个CVSNT,没用过,据说问题比较多。Linux下当然简单了,Debian下更是如此。

安装cvs软件包
apt-get install cvs cvsd

其中cvs是主程序软件包,cvsd是cvs的一个pserver的wrapper,能够非常方便地管理repositories和users,并且以更 安全的形式运行cvs服务。注意安装配置的时候,将cvs的主目录设为none,将cvsd的主目录设为/home/cvs(或者其它你希望的路径)。
修改配置文件
检查一下/etc/cvsd/cvsd.conf文件,确认最后几行类似如下的形式:
RootJail /home/cvs
Repos /repos

第一行的意思就是你的cvsd的根目录,第二行是你的repositories的目录,注意这儿虽然写的是绝对路径,实际上是相对于$cvsdHome的路径,在这里就是指/home/cvs/repos。
建立repositories
如果你在配置cvsd主目录的时候选择了none,你也可以手动创建/home/cvs目录,然后执行
cvsd-buildroot /home/cvs

将cvsd根目录的文件系统建立起来。
然后是创建repositories并初始化:
mkdir /home/cvs/repos
cvs -d /home/cvs/repos init

添加用户
添加用户就很简单了,跟其它服务器程序类似,cvsd可以添加基于本地用户的虚拟用户,如下:
cvsd-passwd /home/cvs/repos cvsuser:cvsd
chown -R cvsd.cvsd /home/cvs/repos

重启服务
最后我们用/etc/init.d/cvsd restart重启cvs服务就可以使用了。
注意用户登录时还是需要使用相对路径,如:
cvs -d :pserver:cvsuser@localhost:/repos login