带你高效管理代码

上一篇文章带你玩转Visual Studio——带你高效开发通过对VAssistX优秀插件的讲解,让我们掌握了快速开发C++代码的技能。然而大部分的程序都不是一个人的开发的,是由一个团队的多个人一起开发的,大型的系统还可能由多个不同的团队分包进行开发。多人进行协作开发时,代码的管理就显得及为重要,需要借助代码管理工具的辅助,这种工具又称为版本控制系统

目前主流的版本控制系统有: 
CVS:是一个用于代码版本控制的自由软件,它是一个比较早出现的工具,由于它有很多自身的缺陷,现在几乎被SVN所取代了。 
SVN:SVN是Subversion的简称,它是集中式的版本控制系统。SVN继承了CVS的基本思想,包含了CVS的几乎所有功能。你可以认为SVN是CVS的升级版(但实际上它们完全是两个软件)。 
GIT:GIT是分布式的版本控制系统。相信玩过开源代码的都知道github吧,它就是一个基于git的代码托管平台。 
关于SVN与GIT的区别,可参考:GIT和SVN之间的五个基本区别

本文假设您已经对SVN有基本的了解和掌握,并用TortoiseSVN客户端进行过代码的迁入、选出、更新等功能进行团队的协作开发。如果没有这方面的知识,建议先查阅其它的相关资料,以对SVN有大致的了解后再来阅读本文。

向服务器上传一个工程

关于SVN环境的搭建是另外一个主题,你可以自己去查找相关的资料,这里只讲VS相关的东西。您也可以参考这篇文章:Windows下的SVN环境搭建详解,个人觉得写的还可以。要是在公司里一般会有已经搭建好的SVN环境,你只需要一个代码存放的地址。

现在假设你已经搭建好了SVN的环境,有一个SVN的工作地址:svn://localhost/CppRepos(这是我本SVN机服务器的库地址,远程服务器的地址也是一样的),有一个SVN的用户名(luoweifu)和密码(svn_luoweifu)。现在要把本机D:CppWorkspaceDesignPattern下的DesignPattern工程上传到服务器,以后在VS2010下开发这个工程并在VS2010提交和更新代码。基本的操作流程如下:

  1. 用VS2010打开DesignPattern工程。安装完VisualSVN插件后,VS上会多一个菜单项VisualSVN。
  2. 选择菜单VisualSVNAdd Solution to Subversion…

  3. 选择要添加工程的本地路径,一般会自动给你设置好,如果路径是正确的就直接一步。 

     
    图 1:Add Solution to Subversion 1

  4. 这里我们选择Existing Repository,因为我们已经有一个SVN的地址,如果服务器没有创建对应的库可选择New Repository创建一个新的库。 

     
    图 2:Add Solution to Subversion 2

  5. 这里填入你的SVN的地址:svn://localhost/CppRepos 

     
    图 3:Add Solution to Subversion 3

  6. 点击Import就可以了,这时你的VS会有一个Pending Changes的视图,如果没有可通过ViewOther WindowsPending Changes菜单调出来。这个视图将显示所有你要添加到服务器的文件。 

     
    图 4:Add Solution to Subversion 4

  7. Import后只是将本地的文件与服务器上的地址做了映射,并没有真正将文件上传到服务器。你需要将所有文件提交(Commit),才是真正上传到服务器。选中Pending Changes中的所有文件并右键Commit。 

     
    图 5:Add Solution to Subversion 5

  8. 对话框的底部会显示你要提交的所有文件,你可以勾选要提交或不提交哪些文件。写上你提交的原因或备注(这个很重要,一定要有这样的习惯,以便后期查看历史记录时一看就能知道你做了什么),然后点击Ok就可以了。 

     
    图 6:Add Solution to Subversion 6

  9. 第一次提交会要求输入用户名和密码,输入你的SVN用户名和密码就可以了。 

     
    图 7:Add Solution to Subversion 7

VisualSVN的主要功能

VisualSVN有TortoiseSVN的几乎所有功能,它的作用就是将TortoiseSVN集成到VS中,这样代码的编码、代码的管理就可以都在一个IDE中进行,而不用每次提交或更新代码都要切换到TortoiseSVN去做。这跟Java的MyEclipse、Intellij IDEA的SVN插件是类似的。

添加VisualSVN插件后,VisualSVN菜单会有TortoiseSVN的几乎所有功能。如将Solution添加到服务器,从服务器获得Solution,更新代码、提交代码,打分支、合并分支等,如下图。这些功能只要你对SVN有大致的了解,模索模索就会用了,不再过多的介绍。

 
图 8:VisualSVN的整体视图

Pending Chages视图将显示所有新添加、删除或被改动的文件。 
Solution Explorer视图对不同状态的文件也会用不同颜色的圆点标注:绿色表示未做更改的文件,黄色表示已做改动或新添加的文件。

C++工程上传服务器要忽视的文件

带你玩转Visual Studio——带你新建一个工程一文中讲到了C++工程中的各种类型文件,然后我们在代码的版本控制时有很多文件和目录并不需要上传到服务器。因为服务器中只需要存一些有用的数据和文件,一些无用的辅助性文件(如pch文件,Debug目录等)只会给服务器和管理带来负担。这里将列出需要上传和不需要上传的文件类型。

需要上传的文件类型:

h: 头文件 
cpp: 源文件 
txt: 说明文件,如readme 
rc: 资源文件 
rc2: 资源文件 
ico: 图标,如logo等 
sln: 解决方案工程文件 
vcxproj: 工程文件 
filters: 文件过虑器

不要上传的文件类型

Debug、Release等编译结构目录 
ipch目录 
aps: last resource editor state 
exe: build result 
idb: build state 
ipch: build helper 
lastbuildstate: build helper 
lib: build result. Can be 3rd party 
log: build log 
manifest: build helper. Can be written yourself. 
obj: build helper 
pch: build helper 
pdb: build result 
res: build helper 
sdf: intellisense dbase 
suo: solution user options 
tlog: build log 
user: debug settings. Do preserve if just one dev or custom debug settings

如果用TortoiseSVN进行管理,需要手动添加ignore属性将不需要上传的文件忽略掉。在你工程目录里,右键->TortoiseSVN->Properties->New->Other,弹出的对话框中Property name中选择svn:ignore,Property value中填入要忽略的内容(这里可以使用能配符),如下图。 

 
图 9:添加ingore属性

用VisualSVN进行上传Solution时,默认就帮你设置好了,将不需要的文件给屏蔽了。这也是VisualSVN的一大好处。



上一篇回顾: 
带你玩转Visual Studio——带你高效开发

下一篇要讲述的内容: 
带你玩转Visual Studio——带你发布自己的工程库

文章导航