不少人都遇到过这种情况:在Windows下用Visual Studio工具开发的程序需要迁移到Linux系统中,做成Linux版本的,但程序比较大,在Linux上又离不开Make,手动编写Makefile文件的工作量又太大。在这里提供一种方法仅供参考。

由于VS的解决方案文件“*.sln”和项目文件“*.vcproj”文件中保存了源代码的依赖关系和编译信息,只要把它转换成Makefile文件就行了,剩下的就是修改API函数和相关的头文件等保证兼容性的工作了。本人网上搜索了一下,找到一种工具提供这种功能,网址为http://www.codeproject.com/Articles/28908/Tool-for-Converting-VC-2005-Project-to-Linux-Makef。这个站点提供程序源代码和执行文件,比较人性化。
这里简单介绍一下程序的使用。
sln2mak
可以把VS2005或者VS2008(见下面的说明3)的解决方案sln文件解析成Makefile文件,那么这样就可以将VS的项目迁移到Linux中(当然,I/O函数等要变成相应的名字)。
在命令解释器中运行。几种命令格式如下:
1、如果工程名和解决方案名相似
则为:
sln2mak [Solution_FullPath_File_Name].sln
例如:
sln2mak c:/myprojects/test/unit_test.sln
2、如果工程名不同于解决方案名
则为:
sln2mak -l [Main_Project_Name] [Solution_FullPath_File_Name].sln
例如:
sln2mak -l unit_test c:/myprojects/test/test.sln
3、如果你想转换一系列.vcproj文件,第一个是主工程,后面跟着剩下的工程,然后使用 -d添加额外的依赖,像lib(如果存在)
则为:
sln2mak [Main_Project_FullPath_Name].vcproj [Project_FullPath_Name_2].vcproj ...
[Project_FullPath_Name_n].vcproj -d [lib_Name_1] ... [lib_Name_n]
例如:
sln2mak c:/myprojects/tets/unit_test.vcproj c:/myprojects/tets/test_lib.vcproj
-d mystaticlib1 mystaticlib2 mystaticlib3
程序运行后,会发现在.vcproj的文件夹里有一个和这个工程名字相同的.mak文件。.mak文件包含全部额外的libraries、sources和flags为编译、连接、预处理和目标路径。在.sln路径,会发现用于处理全部目标规则(clean,make)和依赖的Makefile文件。
说明:
1、转换过程中没有损失:源文件不会变;
2、可能在从.vcproj到.mak转换中,并没有覆盖所有的flags;
3、使用sln2mak解析VS2008的sln文件时,在“引用”项中去掉8.0.0.0版本的Microsoft.VisualStudio.VCProjectEngine,添加上9.0.0.0版本的Microsoft.VisualStudio.VCProjectEngine,再用VS2008编译一下
4、转换好后连同整个工程一起考到 linux 下。在一个终端中进入当前工程目录,然后make,会提示“找不到 projectname.mak 文件”,打开 Makefile,把其中的 “cd && $(MAKE)” 都改成 “cd . && $(MAKE)” 或者 “$(MAKE)”。再 make,会提示“找不到 -l -lstdc++",打开 projectname.mak 文件,把其中的 “-l -lstdc++” 都改成 “-lstdc++”,这里多了一个空 -l 。

5、projectname.mak 这个文件结构比较简单,它通过一个 CFG 变量来判断当前的编译版本,是 Debug、Release 或 其他,紧接着是每种编译版本对应的编译链接选项,最后是编译命令。这里很多 windows 相关的 宏、资源文件 和 dep 文件,都可以去掉。