VC 2005 解决方案的目录结构设置和管理

VC 2005 解决方案的目录结构设置和管理
 
 
一个中等规模的解决方案通常都会包含多个项目,其中一些项目产出静态库,一些产出动态库,一些用于单元测试,还有的产出最终的应用程序执行档。除此以外,根据项目的需求,还会使用一些第三方的库。
 
所以为解决方案设置一个合理的目录结构,不但可以使得代码管理更井井有条,项目成员之间也更容易相互配合,更重要的是能够使得最终应用程序的安装包制作,源代码打包发布和转移变得十分容易。
 
解决方案与项目:
VC6 之后 VC 系列就使用解决方案( Solution )来替代原来的工作空间,用于组织和管理多个相关的项目( Project )。
 
文章首先演示一个虚拟的解决方案和我们期望得到的目录结构,然后使用VC2005的项目设置功能来一步一步达到我们的需求。
 
 
虚拟解决方案:
 
该虚拟解决方案名为GMA,包含一个动态链接库项目ChocolateMilk和一个应用程序项目PureMilk,需要使用一个第三方库log4cxx(Apache log4j的C++移植版本,用于日志输出)。
 
log4cxx是以动态库的方式编译的,所以我们需要它的3样东西,分别是头文件,导入库(log4cxx.lib, log4cxxd.lib)和动态链接库(log4cxx.dll)。
 
假设我们期望的目录结构如下图:
 
VC 2005 解决方案的目录结构设置和管理_第1张图片
 
1. GMA是解决方案目录
2. PureMilk和ChocolateMilk是项目目录
3. Lib目录用于存放导入库或者静态库(包括第三方库和自己的项目)
4. Include用于存放第三方库的头文件
5. Bin目录存放所有动态链接库和执行档,包括自己的产出和第三方库,区分Release和Debug两个版本。另外,程序运行过程中需要外部的数据文件和启动时需要的配置文件等等都可放于该目录
6. Temp用于存放临时生成文件,其中Compile存放编译器编译时生成的obj文件,Link存放链接器的输出文件。
 
上面目录结构清晰,一面了然,当我们的程序需要制作安装包或者要打包源码
发布的时候,它能够使得我们生活变得更容易^_^
 
制作安装包时我们只需将“/GMA/Bin/Release/”目录下的所有文件打包。
 
发布和转移源码的时候我们可以打包除了Temp目录以外“/GMA/”下面的所有文件和目录(如果不需要执行档,也可不包括Bin)。
 
我们的需求是明确的,可是VC 2005并不会自动为我们做好上面所有的事情。不过我们并不需要编写复杂的编译脚本(makefile),只需要简单的修改项目的缺省设置即可。
 
我们需要 VC 为我们做的事情包括:
 
1.使用“/GMA/Temp/Compile/”作为项目编译时使用的中间目录
2.使用“/GMA/Temp/Link/”作为项目链接的输出目录
3.当项目是应用程序时,在构建结束后拷贝执行文件到“/GMA/Bin/Release/”或“/GMA/Bin/Debug/”,当项目是动态链接库时,除了拷贝dll到Bin,还拷贝导入库到“/GMA/Lib/”
4.当项目是应用程序时,调试时运行“/GMA/Bin/Debug/”或“/GMA/Bin/Release/”下面的执行文件,并以“/GMA/Bin/Debug/”或“/GMA/Bin/Release/”为工作目录
 
首先看一下项目设置中可以使用的宏,常用的有:
 
ConfigurationName
配置名字,通常是Debug或者Release
IntDir
编译器使用的中间目录,产出obj文件
OutDir
链接器使用的输出目录
ProjectDir
项目目录
ProjectName
项目名字
SolutionDir
解决方案目录
TargetDir
目标输出文件所在的目录
TargetExt
目标输出的扩展名
TargetFileName
目标输出文件名,包括扩展名
TargetName
目标输出名,不包括扩展名
TargetPath
目标输出文件的全路径名
 
VC 2005 解决方案的目录结构设置和管理_第2张图片 
首先来设置 ChocolateMilk
 
1.使用“/GMA/Temp/Compile/”作为项目编译时使用的中间目录
2.使用“/GMA/Temp/Link/”作为项目链接的输出目录
 
  VC 2005 解决方案的目录结构设置和管理_第3张图片
 
注意高亮的部分,首先将配置改成All Configuration(全部配置),这样可以让我们同时修改Debug和Release的部分;
 
Output Directory(输出目录,链接器)栏位填入:
$(SolutionDir)/Temp/Link/$(ProjectName)/$(ConfigurationName)
 
Intermediate Directory(中间目录,编译器)栏位填入:
$(SolutionDir)/Temp/Compile/$(ProjectName)/$(ConfigurationName)
 
3.构建结束后拷贝动态链接库到“/GMA/Bin/Release/”或“/GMA/Bin/Debug/”,拷贝导入库到“/GMA/Lib/”
 
我们通常都会在Debug版本的输出库后面加上字母“d”以表示这是Debug版本,在Debug配置下,修改Import Library栏位:
 
  VC 2005 解决方案的目录结构设置和管理_第4张图片
 
VC可以让我们设置构建前后执行的脚本程序,所以为了完成3,
我们需要写构建后执行的脚本:
VC 2005 解决方案的目录结构设置和管理_第5张图片 
 
在Command Line中填入,Debug配置下:
 
copy $(TargetPath) $(SolutionDir)/Bin/$(ConfigurationName)/;
copy $(TargetDir)$(TargetName)d.lib $(SolutionDir)/Lib/;
 
Release配置下:
 
copy $(TargetPath) $(SolutionDir)/Bin/$(ConfigurationName)/;
copy $(TargetDir)$(TargetName).lib $(SolutionDir)/Lib/;
 
之所以要分别设置是因为VC没有表示导入库的宏名字 -_-P
 
OK,到此为止,你就可以编译ChocolateMilk项目试试是不是一切正常了,不过请确认拷贝的目标目录事先建立好。
 
接下来我们设置应用程序项目 PureMilk
 
1.使用“/GMA/Temp/Compile/”作为项目编译时使用的中间目录
2.使用“/GMA/Temp/Link/”作为项目链接的输出目录
 
首先将配置改成All Configuration(全部配置),这样可以让我们同时修改Debug和Release的部分;
 
Output Directory(输出目录,链接器)栏位填入:
$(SolutionDir)/Temp/Link/$(ProjectName)/$(ConfigurationName)
 
Intermediate Directory(中间目录,编译器)栏位填入:
$(SolutionDir)/Temp/Compile/$(ProjectName)/$(ConfigurationName)
 
3.构建结束后拷贝执行文件到“/GMA/Bin/Release/”或“/GMA/Bin/Debug/”
 
在Command Line中填入,All配置下:
 
copy $(TargetPath) $(SolutionDir)/Bin/$(ConfigurationName);
 
4.调试时运行“/GMA/Bin/Debug/”或“/GMA/Bin/Release/”下面的执行文件,并以“/GMA/Bin/Debug/”或“/GMA/Bin/Release/”为工作目录
 
VC 2005 解决方案的目录结构设置和管理_第6张图片
 
Command栏位填入:$(SolutionDir)/Bin/$(ConfigurationName)/$(TargetFileName)
Working Directory栏位填入:$(SolutionDir)/Bin/$(ConfigurationName)/
 
这样就大功告成了,现在你就可以编译该执行程序并进行调试。
  

发表于 @ 2007年01月13日 13:13:00|评论(9 )|编辑

新一篇: shared_ptr 两种常见的使用方式 (1) | 旧一篇: Argument Dependent Lookup (ADL, a.k.a. Koenig Lookup) 解析 (3)

评论

# surefire 发表于2007-01-14 11:06:57  IP: 222.240.19.*
弄了一早上没成功,操
# surefire 发表于2007-01-14 11:50:53  IP: 222.240.19.*
生成后事件命令不能正确执行,明明Target已经存在,老是提示说系统找不到指定的文件,而我的Bin/Debug等目录都建好了。
# rogeryi 发表于2007-01-14 15:39:31  IP: 210.21.46.*
copy $(TargetPath) $(SolutionDir)/Bin/$(ConfigurationName)/;

在我的机器上会被展开为

copy d:/work/gma/temp/link/chocolatemilk/debug/chocolatemilk.dll
d:/work/bin/debug/;

你用控制台执行一下就知道肯定是OK的了,可以检查一下你的宏名有没有写错。
# rogeryi 发表于2007-01-14 15:40:49  IP: 210.21.46.*
copy $(TargetPath) $(SolutionDir)/Bin/$(ConfigurationName)/;

在我的机器上会被展开为

copy d:/work/gma/temp/link/chocolatemilk/debug/chocolatemilk.dll
d:/work/gma/bin/debug/;

你用控制台执行一下就知道肯定是OK的了,可以检查一下你的宏名有没有写错。
# wswqwps 发表于2007-10-24 00:34:33  IP: 222.67.54.*
http://blog.csdn.net/rogeryi/archive/2007/01/13/1481923.aspx
# ioby 发表于2008-06-15 09:41:36  IP: 121.107.184.*
ChocolateMilk是动态链接库项目,你最后拷贝的静态库是哪里产生的?ChocolateMilk.lib ChocolateMilkd.lib
# rogeryi 发表于2008-06-16 11:04:40  IP: 218.19.231.*
动态库项目产生的lib是导入库(import library)
# net_syc 发表于2008-12-23 00:05:45  IP: 59.44.76.*
各位兄弟们,那个copy的问题我终于解决了,原来当目标路径的文件夹不存在时,copy命令就不好用了,提示系统找不到指定的路径。,把这句话:
copy $(TargetPath) $(SolutionDir)/Bin/$(ConfigurationName)/;
换成以下这句就OK了……
xcopy $(TargetPath) $(SolutionDir)/Bin/$(ConfigurationName)/
注意,命令变成了xcopy了,而且最后的分号去掉啦,之后即使Bin目录下没有Debug或Release目录编译器也会自动生成的!~
# net_syc 发表于2008-12-23 00:14:39  IP: 59.44.76.*
补充……
避免下次编译覆盖文件提示加个“/y” 参数,具体修改如下:
xcopy $(TargetPath) $(SolutionDir)/Bin/$(ConfigurationName)/ /y
这回就OK了,如果目标文件正在被使用中的话,会提示“共享侵犯”哦!~

你可能感兴趣的:(VC 2005 解决方案的目录结构设置和管理)