Linux下常用cvs命令整理

文章出处:http://mxsfengg.iteye.com/blog/523673


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添加到项目中

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 co <model>
cvs up filename 提交修改
cvs ci filename 确认修改
cvs log filename 察看修改日志
cvs st filename 察看文件状态
cvs rm filename 将某个源文件物理删除


评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值