sln文件简介
Visual Studio使用解决方案文件(后缀为sln的文件)表示一个项目组,它通常包含一个项目中所有的工程文件信息。了解sln文件格式,可以手动修改错误的sln文件,也可以对解析sln文件有帮助。
sln文件是一个文本文件,虽然它没有使用最流行的XML文件标识,但数据结构却类似于XML文件,基本上也是由节组成,一个节由标记和End加标记来限定。比如工程信息的标记为Project,那么它们由Project和EndProject来限定。每个节可以有自己的属性,并且节内部可以再嵌套子节。子节的名称由标记加section标识,然后在名称的后面加上一个小括号,其中记录这个子节的意义,比如表示工程依赖关系的子节就是ProjectSection(ProjectDependencies)。子节也可以有属性,但是子节的属性都是由一个等式表示。
sln文件组成部分
文本版本
在Visual Studio 2017中是这样的一句话:
Microsoft Visual Studio Solution File, Format Version 12.00
工程信息
工程信息包含了解决方案中有哪些工程组成和他们之间的相互依赖关系,每个工程都是单独由Project和EndProject所包括,见下面的这个例子:
Project("{8BC9…C942}") = "Qb", "Qb\Qb.vcproj", "{315B…BD44}" ProjectSection(ProjectDependencies) = postProject {8503…F1D6} = {8503…F1D6} {B8E9…E045} = {B8E9…E045} {13E7…F0B6} = {13E7…F0B6} {F51A…9635} = {F51A…9635} EndProjectSection EndProject
Project有三个属性,由逗号分成三部分:
- 第一部分("{8BC9...C942}")="Qb", 表示工程名称, "{8BC9...C942}"是固定值, 等号后面是工程名称。大部分情况下,工程名称和工程文件名相同。
- 第二部分是工程文件,它是解决方案文件的相对路径。
- 第三部分是工程的GUID,解决方案通过这个GUID识别工程。在后面的依赖关系和编译配置中都会用到。
工程信息中的子节用ProjectSection表示,括号内的标记ProjectDependencies表示该工程的依赖工程。这个子节的属性就是依赖工程的GUID,等式两边的GUID是相同的,有多少个依赖工程,就有多少行的GUID等式。
全局设置
全局设置的标记是Global,通常对我们比较有用的子节包括SourceCodeControl,SolutionConfiguration和ProjectConfiguration。
SourceCodeControl记录了解决方案在SourceSafe中的信息
首先是Scc的基本信息,通常有四行属性,如下:
SccNumberOfProjects = 6 SccLocalPath0 = . CanCheckoutShared = true SolutionUniqueID = {6CFC75CC-2B14-4617-B1CA-D7CDB52E9773}
注意,SccNumberOfProjects比所包含工程数多一个。
有时候,会多出两个属性SccProjectName和SccProvider,大多数时候没有用,如下:
SccNumberOfProjects = 132 SccProjectName0 = \u0022$/V-Fit\u0022,\u0020YKAAAAAA SccLocalPath0 = . SccProvider0 = MSSCCI:Microsoft\u0020Visual\u0020SourceSafe CanCheckoutShared = true SolutionUniqueID = {6CFC75CC-2B14-4617-B1CA-D7CDB52E9773}
接下来,每四行都表示一个工程在SourceSafe中的信息,如下:
SccProjectUniqueName1 = Qb\\Qb.vcproj SccLocalPath1 = . CanCheckoutShared = true SccProjectFilePathRelativizedFromConnection1 = Qb\\
注意这些属性后面都带有一个数字标记这是第几个工程属性。
有时候会多出一个属性SccProjectName并且SccLocalPath也不是当前路径“.”,不过这些信息都没有太多用
SccProjectUniqueName1 = Qb\\Qb.vcproj SccProjectName1 = \u0022$Qb//\u0022,\u0020IHKAAAAA SccLocalPath1 = Qb CanCheckoutShared = true SccProjectFilePathRelativizedFromConnection1 = Qb\\
SolutionConfiguration记录了解决方案可用的编译版本。比如通常能看到
- 在VS2013版本中
Debug = Debug Release = Release
- 在VS2017版本中
GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Win32 = Debug|Win32 Debug|x86 = Debug|x86 Release|Win32 = Release|Win32 Release|x86 = Release|x86 EndGlobalSection
ProjectConfiguration记录了工程可用的编译版本对于SolutionConfiguration中指定的某些没有编译版本则指定可替代的编译版,比如
- 在VS2013版本中
{876A6148-EC66-4DD2-BC82-B61CAC2049AC}.Debug.ActiveCfg = Debug|Win32 {876A6148-EC66-4DD2-BC82-B61CAC2049AC}.Debug.Build.0 = Debug|Win32 {876A6148-EC66-4DD2-BC82-B61CAC2049AC}.Release.ActiveCfg = Release|Win32 {876A6148-EC66-4DD2-BC82-B61CAC2049AC}.Release.Build.0 = Release|Win32
- 在VS2017版本中
GlobalSection(ProjectConfigurationPlatforms) = postSolution {23D8D42C-D711-4C04-BBDF-50B68E1CA83C}.Debug|Win32.ActiveCfg = Debug|Win32 {23D8D42C-D711-4C04-BBDF-50B68E1CA83C}.Debug|Win32.Build.0 = Debug|Win32 {23D8D42C-D711-4C04-BBDF-50B68E1CA83C}.Debug|x86.ActiveCfg = Debug|Win32 {23D8D42C-D711-4C04-BBDF-50B68E1CA83C}.Debug|x86.Build.0 = Debug|Win32 {23D8D42C-D711-4C04-BBDF-50B68E1CA83C}.Release|Win32.ActiveCfg = Release|Win32 {23D8D42C-D711-4C04-BBDF-50B68E1CA83C}.Release|Win32.Build.0 = Release|Win32 {23D8D42C-D711-4C04-BBDF-50B68E1CA83C}.Release|x86.ActiveCfg = Release|Win32 {23D8D42C-D711-4C04-BBDF-50B68E1CA83C}.Release|x86.Build.0 = Release|Win32 {ABA05890-6F82-4004-BAE2-FAE0BC69D4A8}.Debug|Win32.ActiveCfg = Debug|Win32 {ABA05890-6F82-4004-BAE2-FAE0BC69D4A8}.Debug|Win32.Build.0 = Debug|Win32 {ABA05890-6F82-4004-BAE2-FAE0BC69D4A8}.Debug|x86.ActiveCfg = Debug|Win32 {ABA05890-6F82-4004-BAE2-FAE0BC69D4A8}.Debug|x86.Build.0 = Debug|Win32 {ABA05890-6F82-4004-BAE2-FAE0BC69D4A8}.Release|Win32.ActiveCfg = Release|Win32 {ABA05890-6F82-4004-BAE2-FAE0BC69D4A8}.Release|Win32.Build.0 = Release|Win32 {ABA05890-6F82-4004-BAE2-FAE0BC69D4A8}.Release|x86.ActiveCfg = Release|Win32 {ABA05890-6F82-4004-BAE2-FAE0BC69D4A8}.Release|x86.Build.0 = Release|Win32 {E1F23DA7-357E-408E-98D1-72490664848E}.Debug|Win32.ActiveCfg = Debug|Win32 {E1F23DA7-357E-408E-98D1-72490664848E}.Debug|Win32.Build.0 = Debug|Win32 {E1F23DA7-357E-408E-98D1-72490664848E}.Debug|x86.ActiveCfg = Debug|Win32 {E1F23DA7-357E-408E-98D1-72490664848E}.Debug|x86.Build.0 = Debug|Win32 {E1F23DA7-357E-408E-98D1-72490664848E}.Release|Win32.ActiveCfg = Release|Win32 {E1F23DA7-357E-408E-98D1-72490664848E}.Release|Win32.Build.0 = Release|Win32 {E1F23DA7-357E-408E-98D1-72490664848E}.Release|x86.ActiveCfg = Release|Win32 {E1F23DA7-357E-408E-98D1-72490664848E}.Release|x86.Build.0 = Release|Win32 EndGlobalSection