CSDN博客

img auding1900

收藏的“windows cvs 应用笔记.txt”

发表于2004/9/20 19:21:00  839人阅读

/*------------------------------------------------------------------------
 Module:        windows cvs 应用笔记.txt
 Author:        amine@263.net; http://amine.nease.net; QQ:188710731
 Project:      
 State:   
 Creation Date: 2003-10-16
 Description:  
------------------------------------------------------------------------*/
/*------------------------------------------------------------------------
 Purpose:       环境说明
------------------------------------------------------------------------*/
Win2000 SP4
cvsnt-2.0.10
WinCvs13b13-2
Python-2.3

/*------------------------------------------------------------------------
 Purpose:       cvsnt安装和配置
------------------------------------------------------------------------*/
在服务器端用管理员账号安装cvsnt;
安装后, 会自动启动两个服务: cvsservice和cvslock;

启动 服务控制面板 来配置cvsnt;
可用来停止和启动cvsnt两个服务;
修改cvsnt配置时,应该停止服务.修改后, 再重启动;
设置资源目录, 用于存储归档文件. 一般设目录前缀(如e:/),再添加各分目录(如/cvsrepo).
资源目录建立时会创建cvsroot子目录.
在Advanced页面,选择Use local users for pserver...;
Temporary栏中设置临时目录(如e:/cvstemp).

/*----------------------------用户添加----------------------------------*/
需要在Win2000中先配置用户,归入guest组;

在命令行窗口中,先,
set cvsroot=:ntserver:<主机IP>:<Valid Repository Roots>
为每个用户设置密码,密码可以和Windows用户的密码不同.
administrator可以使用Windows中密码, 不用特别添加.
cvs passwd -a <用户名>

/*------------------------------------------------------------------------
 Purpose:       wincvs安装和配置
------------------------------------------------------------------------*/
启动wincvs需要安装python.

不要在工作盘上使用cvs作为目录名, wincvs使用cvs目录来建立和服务器的联系.
主要需要配置/wincvs preferrence/general/, 如下:
 auth: pserver
 path: /cvsrepo
 host: 192.168.0.112
 user: amine
 cvsroot:amine@192.168.0.112:/cvsrepo(会根据前面设置自动填充)
在/wincvs preferrence/general/cvs/下设置cvs的Home目录(如e:/cvswintemp)

设置完后登录服务器, 输入密码, 登录成功显示:
***** CVS exited normally with code 0 *****

用菜单/view/browser loc/change, 切换到自己的工作盘
管理员平时应该用普通用户工作;实现管理功能时才用administrator登录
administrator和普通用户最好使用不同的工作盘和工作目录

使用外部diff工具
 可以使用cs-diff, beyond compare, examdiff等
 在/wincvs preferrence/general/wincvs/设置
 diff selection时注意选择使用extern diff
 
外部编辑器
 最好用ultraedit
 在/wincvs preferrence/general/wincvs/设置

/*------------------------------------------------------------------------
 Purpose:       wincvs日常使用
------------------------------------------------------------------------*/
import module:
 选择要归档的源代码目录
 
checkout module:
 用户利用wincvs工作前,需要从服务器得到工作目录,建立与服务器的联系
 注意选择module的存储目录,module带服务器上路径(?)
 
add selection
 添加需归档的新文件
 
remove selection
 删除客户端的文件,
 若再commit, 就会删除服务器上的文件,但并非物理删除,可以恢复(?)
 
commit selection
 向服务器提交自己的修改
 有一个好习惯是,在你准备提交到服务器之前,先query update下,因为有可能别的开发者
 在你修改这个文件的同时,也可能也修改了这个文件,这就有可能会存在冲突,
 我们总是在提交前先处理冲突。
 
update selection
 从服务器取最新版本, 注意不要损失自己的修改
 如果自己对本地版本修改过, 操作不成功, 显示M <文件名>
 可以再操作选择"get clean copy"强制取得服务器最新版本,本地文件会备份

query update
 这是个查询命令, 没有实际的操作
 看本地版本和服务器版本是否统一, 可经常使用, 以获得工程的最新进展, 以协调工作
 M <文件名> 表示本地作过修改
 U <文件名> 表示服务器版本已更新
 C <文件名> 表示发生冲突

expoler selection
 激活windows的资源管理器, 进行通常的文件操作

diff selection
 查看本地版本和服务器版本的区别

graph selection
 文件版本进化的图形显示,
 可用他来取得指定版本,
 administrator可利用来删除不想要的版本, 比如最新的不正确提交
 
annotate selecttion:
 查看文件各行的版本号, 修改者, 修改时间
 
macro/tcl/fast search modifed 
 指定要查看的目录, 看本地对那些文件作过修改
 
macro/tcl/build changelog
 指定要查看的目录, 本目录下会生成Changelog文件,
 显示每天服务器版本作过哪些修改

create tag on selection
 开发到某个阶段, 对多个文件进行标记操作.
 标记总是在工程发行或进行重大修改时进行.
 当软件开发到一定阶段,测试完毕,有了一个比较稳定可靠的版本后,
 如果这时又有新的需求到来,需要进一步开发,
 若直接将改过的程序上传,就无法快速得到已经稳定的版本。
 这就需要借助标签来实现,只要将稳定的版本都贴上统一的标签,
 那么在下载时直接选择下载带有该标签的所有文件,就可以迅速得到所需的稳定版本 

create a branch:
 将修改隔离到一个分离的开发线上
 例如:
 我们设计了一个图书管理系统,把1.0版交给了客户A大学;
 然后我们继续开发,有了新版本1.1版、1.2、1.3......
 这时A大学告诉我们,1.0版本有bug,我们很快在1.0版本的源代码中找到了错误所在。
 这时候,最简单的解决办法是给A大学一个bug patch。你会问,为什么不给客户最新版本?
 原因很简单:第一,我们还没有检查最新稳定版本中又无此bug;
 第二,客户的系统已经运行了一段时间,升级到最新版本上可能还会发生更多新问题。
 那么,我们就应该在1.0版本上建立一个分支,在这个分支上进行开发,
 修改bug ,创建bugpatch,客户马上就能解决问题了。
 然后我们关起门来,查看最新版本上又无此bug;
 如果有,就将分支合并到主版本上,解决最新版本的问题。


建议
 某些你还不能确定其含义的操作请先用测试用项目test做试验。
 成员不要随意删除已有文件
 提交代码时应注意某些文件是不需要提交到CVS服务器上的
 当你提交的代码与服务器中的代码冲突时(WinCvs会自动告诉你),应谨慎处理

/*----------------------------管理员操作--------------------------------*/
锁定文件:
 一般而言,在项目小组中,项目经理会定期公布最新的基础版本,
 要求小组成员都在这个基础版本上进行进一步开发。
 在实际工作中,总会有些成员提前完成工作,
 他们提交更改后,最新版本就会比项目经理发布的基础版本的version更高。
 有时候,某些项目成员会有意无意修改基础版本,并且指定提交到基础版本上,
 如果允许他们提交修改,大家可能都会在一个错误的基础版本工作,后果是不堪设想的。
 锁定文件的操作如下:
 菜单栏的admin->>comandline,输入这个命令:
 cvs admin -l版本号 文件全名
 注意,-l和版本号之间没有空格。
 
/*------------------------------------------------------------------------
 Purpose:       其他
------------------------------------------------------------------------*/
版本号w.x.y.z表示意思:
 w: 主版本号,  x: 小版本号
 y: 分支号,  z: 分支修改号

/*------------------------------------------------------------------------
 Purpose:       疑问
------------------------------------------------------------------------*/
?check out成功与否和wincvs的目录选择有关, 历史目录
?如何自下载module到需要的目录, 带module的路径
?cvs资源目录如何恰当设置, 和工程协调
?tag使用
?branch使用
?冲突处理
?功能探索

/*------------------------------------------------------------------------
 Purpose:       网络资源
------------------------------------------------------------------------*/
CVSNT网站:
 可下载csvnt, 最新稳定版2.0.10
 http://www.cvsnt.org/wiki/
 
WinCvs下载
 最新版13b13-2
 http://sourceforge.net/projects/cvsgui/
 
python:
 最新版2.3
 http://www.python.org/

WinCVS与CVSNT简明使用手则(1,2,3,4)
 http://www.csdn.net/develop/article/19/19756.shtm

安装 CVS 并将其配置为 SCM 资源库:
 cvsnt安装图解
 http://www-900.ibm.com/developerWorks/cn/wsdd/library/techarticles/0202_yu/yu2.shtml
team programing wiht cvs in wsad
 http://www.javaresearch.org/article/showarticle.jsp?column=151&thread=4471
 
WinCvs简明操作手册(1,2,3)
 WinCvs操作图解
 http://www.51cmm.com/case/no015.htm
 
cvs的配置和使用
 http://www.xfocus.net/articles/200103/125.html
 
参考"WinCvs日常使用指南", 或英文版"WinCvs Daily Use Guide"
参考"使用WinCVS进行版本控制"
参考"WinCvs客户端使用技巧"

0 0

相关博文

我的热门文章

img
取 消
img