`

SVN — 为Subversion版本库创建只含部分内容和特殊改动的标签

阅读更多

 

 http://blog.csdn.net/jamesfancy/archive/2007/07/22/1702187.aspx
 

标签和分支在任何一个版本控制系统中都是非常重要的功能。Subversion独特的创意将这两者有机的结合在了一起。准确的说,Subversion中是没有标签和分支的,它们都由一个Subversion中独特的概念给代替了,这就是——拷贝。

Subversion的拷贝是轻量级的。换句话说,Subversion中的拷贝只是保持了文件某个版本的一个链接,而不是将所有内容一并拷贝过来了。只有当内容发生改变的时候,Subversion才会保存变更的内容。

因此,在Subversion中,通常把拷贝当作标签。如果在拷贝的基础之上进行了变动,那么这个拷贝就成为了一个分支。也正是由于这个原因,Subversion版本库中,第一步往往是建立三个子目录:trunk、tags和branches,分别用于保存主分支、作为标签的拷贝和作为分支的拷贝。

由于Subversion标签的特殊性,它不仅可以在制作标签拷贝之后对其进行改动,甚至在制作标签的时候,也可以将一些工作拷贝中所作的改动保存起来。就好像对工作拷贝做了改动之后再将工作拷贝的内容复制到别的地方保存起来一样。下面就详细举例说明(用TortoiseSVN作为客户端为例)。

如果你对Subversion和TortoiseSVN已经有一定的了解,可以跳下面的第1、2、3步。

1. 准备一个试验用库

建立一个svn-repo目录保存Subversion版库:在Windows Explorer中新建一个文件夹svn-repo。右键单击该目录,并在弹出菜单中选择“TortoiseSVN→Create repository here…”,如下图

然后选择创建一个“Native filesystem (FSFS)”的版本库。这里选择文件系统版本库纯属个人习惯,大家可以根据需要或习惯自行选择。

由于svn-repo目录是创建在F:盘的,所以现在版本库的URL是:file:///f:/svn-repo

2. 准备工作拷贝目录并初始化版本库结构

创建一个目录作为工作目录,比如F:\workcopy。然后在这个目录下创建两个空文件夹:trunk和tags。由于本次试验不需要创建分支,所以branches目录就免了。

然后在workcopy目录中,右键点击空白处,选择“TortoiseSVN→Import…”,如图

在随后出现的Import对话框中填入刚才得到的URL:file:///f:/svn-repo,点击OK按钮将刚创建的两个空目录导入到版本库中。如图

这时候的workcopy目录还不在Subversion的控制之下,因此workcopy目录中还不含.svn目录(这个目录通常是隐藏属性)。所以要先将workcopy清空,右键点击目录中的空白处,选择“SVN Checkout…”菜单项,准备将版本库中trunk目录的内容(目前还是空)取出来作为工作拷贝。如图

在随后打开的Checkout对话框中填入trunk的URL,将按OK将内容取出到工作拷贝。如图

3. 准备实验用的目录和文件

在workcopy目录创建一些目录,子目录和文件,以模拟工程文件目录树。创建好后就像下面图示的那样:

现在右键点击workcopy目录,或者目录中的空白处,在弹出菜单中选择“SVN Commit…”,打开Commit对话框。并在这个对话框中将所有文件及目录选中(选择全部,勾选“Seelct / deselect all”选项即可),并提交,以将这些目录和文件添加了版本库的trunk目录中。如图

4. 修改工作拷贝的内容,准备做一个特殊的标签

现在我们需要做一个特殊的标签。假设这次标签是为一次工程测试所做,而这次测试中不需要sub-proj32和proj4的参予,所以现在需要将proj3/sub-proj32以及proj4删除,并且修改build_all.cmd将这两个程的build代码去掉。同时,还需要添加一个tag_readme.txt对这次标签进行详细的说明。操作如下:

分别在Explorer中找到sub-proj32目录和proj4目录,并在其右键菜单中选择“TortoiseSVN→Delete”将它们标记为删除。该操作会将这两个目录中的所有文件删除掉,并将这两个目录标记为删除。此时,如果提交更改,则这两个目录就真的被删除并记录到版本库中。但由于只是为做标签,而不是真的要删,所以,不能提交。

然后,修改build_all.cmd的内容。

在workcopy中新建一个文件,命名为tag_readme.txt,并添加说明内容。右键点击tag_readme.txt文件,在右键菜单中选择“TortoiseSVN→Add…”,并在弹出菜单中确定tag_readme.txt为选中状态,点击OK。再在随后弹出的消息对话框中点击OK。

这些操作完成之后,相关目录和文件的图标会相应变化以显示被标记的状态:proj4和sub-proj32两个目录被标记为删除状态,build_all.cmd被标记为本地修改状态、tag_readme.txt被标记为添加状态,如图

特别注意:这一步中所做的任何修改都不要提交到版本库,即不要运行“SVN Commit…”命令。

5. 制作标签

现在右键单击workcopy目录,在弹出菜单中选择“TortoiseSVN→Branch/Tag…”命令,打开Copy对话框。此Copy对话框中,To URL处填写产生标签的URL:file:///f:/svn-repo/tags/build_2007_07_22;注意一定要在“Create copy in repository from”选项组中选择“Working copy”。这一点非常关键,不然上面的事情都白做了。一般来说,还需要对这个标签有一个简短的说明,填写在Log message中。完整配置之后的Copy对话框如图

点击OK,即开始制作标签。结果如下图

可以看到,这个标签中添加了workcopy目录(被添加为file:///f:/svn-repo/tags/build_2007_07_22),而其中的build_all.cmd有改动;删除了proj4和sub-proj32,并添加了tag_readme.txt。其它内容都保持原样。

6. 恢复工作拷贝

标签完成了,工作还要继续,刚才所做的所有改动,都是要恢复过来的。proj4和sub-proj32是不能丢的,build_all.cmd也要恢复原样,而tag_readme.txt则不再需要了。

这时候,右键单击workcopy目录,或目录中的空白处,选择“TortoiseSVN→Check for modifications”命令,打开对话框,如图

这个对话框中列出来了刚才改动过的内容,包括增、改、删。将它们全部框选,并右键单击选中的内容,在弹出菜单中选择“Revert…”项。这时TortoiseSVN会询问是否revert选中的4项,选择Yes。

现在所有变动标记都去掉了,再将多余的tag_readme.txt文件删除。workcopy又恢复了最后一次Update的样子,对工作一点也不影响。

后记:如果按照上面的操作过程,怕因为误操作选择不必要的麻烦,也可以用另一种办法来实现类似的特殊的“标签”,不过这种“标签”应该叫分支了。1. 通过repo-browser在版本库的tags目录中创建一个标签目录,如file:///f:/svn-repo/tags/test就创建了一个名为test的标签目录。2. 在workcopy中为你需要添加了标签中的每一个目录和文件进行Branch/tag操作,将其拷贝到file:///f:/svn-repo/tags/test下的同名目录中。

这样做标签有一定的局限,比如,需要去掉子目录下的内容,如sub-proj32的时候,就会比较麻烦。而且,这样做会造成多次修改版本号的更新,所以不推荐使用这种方法。

分享到:
评论

相关推荐

    subversion1.8.13版本 svn版本控制器服务器安装包

    3. **创建版本库**:在服务器上创建一个或多个Subversion仓库,这是存储所有项目文件的地方。 4. **设置权限和访问控制**:配置仓库的访问控制,指定哪些用户或组可以访问哪些资源。 5. **客户端配置**:在开发...

    Myeclipse SVN插件subversion.rar

    - **标签(Tag)和分支(Branch)**:Subversion支持创建项目标签和分支,便于不同版本的管理和维护。 - **忽略文件**:可以设置某些文件或目录不被版本控制,避免无用的版本记录。 - **日志查看**:查看文件或项目...

    Subversion客户端TortoiseSVN简单使用指南

    而TortoiseSVN则是Windows平台上最受欢迎的SVN客户端之一,它将SVN的功能无缝集成到Windows资源管理器中,使得版本控制操作更加直观和便捷。以下是对TortoiseSVN主要功能的详细解析: #### 1. 导入项目 导入项目是...

    SVN(Subversion)简易入门教程

    SVN,全称Subversion,是一款开源的版本控制系统,用于管理和跟踪项目源代码的变化。它允许多个开发者在同一个项目上协同工作,同时记录每一次修改,确保团队间的代码同步和冲突解决。SVN在软件开发领域广泛应用,...

    SVN(Subversion)共享资源管理系统(Eclipse插件与使用方法)

    SVN(Subversion)是一种广泛使用的版本控制系统,用于管理和跟踪文件和目录的变更。它允许团队成员协同工作,每个人都可以在项目中进行修改,而不用担心冲突。Subversion通过记录每次更改,使得团队能够轻松地回滚...

    利用SVN和AltiumDesigner进行PCB版本控制设计

    添加工程到版本控制库中可以在版本控制库目录下新建用于存放本工程版本控制库的文件夹,然后设置版本库存放路径。 四、修改后的文件进行版本控制 当PCB工程纳入到SVN版本控制管理后,用户在后续对项目中任何文件...

    MyEclipse 7.0与SVN(subversion)-

    此外,MyEclipse还支持SVN的分支和标签功能。分支允许你创建一个项目的独立副本进行开发,而不会影响主线代码。标签则是对特定版本的一个快照,通常用于发布里程碑或版本。这些功能使得团队协作更加灵活,有利于项目...

    SVN版本库布局详解一.doc

    在使用Subversion (SVN) 进行版本控制时,一个典型的版本库结构通常包含三个主要部分:`trunk`、`branches` 和 `tags`。这种布局不仅有助于保持代码库的整洁有序,也便于团队成员理解和遵循开发流程。 ##### 1. `...

    svn离线版插件(eclipse/sts)

    SVN(Subversion)是一种广泛使用的版本控制系统,用于管理软件项目的源代码和其他文件的历史记录。在给定的压缩包文件“SVN-4.3.3”中,我们可以找到适用于Eclipse和Spring Tools Suite(STS)的离线安装版本的SVN...

    svn 版本管理,分支/标记配置,创建

    首先,svn的版本管理主要通过版本库实现,每个提交都会为项目增加一个新的版本,开发者可以随时回滚到历史版本,查看每次修改的细节。这有助于追溯错误来源,防止误操作,并支持多人同时编辑同一文件。 分支是svn的...

    Subversion (简称SVN)

    管理员可以通过命令行工具如svnadmin创建、备份和恢复版本库,还可以设置权限控制,决定谁可以访问哪些资源。 6. URL访问方式: SVN使用HTTP/HTTPS协议,这意味着可以通过Web浏览器或者专用的SVN客户端访问版本库...

    subversion中文手册svn-book

    - **增量提交**:只发送改动部分而非整个文件。 - **版本化的目录**:包括文件夹在内的所有项目都可以进行版本控制。 - **可插拔的认证和授权**:支持多种认证机制。 - **Subversion的架构**: - **客户端/服务器...

    最新SVN版本控制带汉化

    SVN,全称Subversion,是一种广泛使用的集中式版本控制系统,它能够管理项目中的源代码、文档等文件的版本,使得多个开发者可以协同工作并跟踪每一次修改,有效地避免了代码冲突和数据丢失的问题。最新版本的SVN增加...

    软件开发管理之版本控制管理:Subversion (SVN)

    **软件开发管理中的版本控制是至关重要的环节,而Subversion(SVN)作为一个成熟的版本控制系统,为团队协作和代码管理提供了强大的支持。本篇将深入探讨SVN的基础知识及其在实际开发中的应用。** **一、Subversion...

    SVN插件,版本控制插件

    1. 规范命名:为分支和标签设定有意义的命名规则,便于管理和查找。 2. 常规提交:频繁提交小改动,减少合并冲突的可能性。 3. 分支策略:根据项目需求制定合理的分支策略,如特性分支、修复分支等。 4. 版本注释:...

    SVN简明课程 Subversion基本使用

    `svnserve`命令可以启动Subversion服务器,创建版本库,如`svnadmin create file_path/repo_name`,并设置服务器参数,如`svnserve.exe -d -r file_path`。 在服务器端配置完成后,可以使用`svn import`命令将本地...

    SVN服务器端(subversion)

    总的来说,SVN服务器端Subversion为开发者提供了强大的协作和版本控制能力,即使在DOS这样的非图形化环境下也能高效运作。通过熟练掌握命令行工具,开发者可以在任何环境下充分利用SVN的强大功能。不过,为了更方便...

    Apache Subversion1.10.3服务端SVN

    3. **提交(Commit)**:将本地工作拷贝的改动保存回仓库的过程,同时会记录下修改内容和作者。 4. **更新(Update)**:从仓库获取最新版本的代码到工作拷贝,以保持同步。 5. **合并(Merge)**:处理两个或多个分支的...

    SVN常用操作----查看代码提交以及改动记录方法

    SVN支持分支和标签机制,用于实现特性开发和版本发布。创建分支可以隔离开发,不影响主线代码;创建标签则可以为特定版本创建快照,方便随时回溯。 总之,掌握SVN的这些常用操作,能极大地提升团队的开发效率和代码...

Global site tag (gtag.js) - Google Analytics