Click here to Skip to main content
Click here to Skip to main content

Tool for Converting VC++2005 Project to Linux Makefile

By , 13 Jul 2012
 

Introduction

This tool automatically converts Visual C++ 8.0 or 9.0 projects to Linux makefile. Important note, there is no loss during the conversion: source code and .sln/.vcproj files are left unchanged. The tool has been implemented in C# VS 2005.

Why?

  • Your application is cross-platform based.
  • Now you are facing a decision to migrate from Visual C++ 6 to 8 or 9.

Both these reasons force you to create a makefile manually and each small change in your project requires hard physical labor in makefile maintenance.

This tool will do it for you automatically and will provide you with the ability to keep .sln/.vcproj and .mak files synchronized.

Using the Tool

The tool is a command line (console application).

There are three cases for tool use I covered in this article:

  1.  You have a .sln - solution that has one or more .vcproj (projects), among which one of them has the same name as the solution itself and is the main/leading project. This leading project should be a target project that will be compiled into .exe or .dll. Other projects in this solution are dependencies for the leading project. Makefiles will not be generated for those projects that do not have dependencies. Sub-projects can have additional dependencies on external precompiled libraries (libs), stdlib.
  2. You should not sign those dependencies explicitly for a tool; it will be parsed from .vcproj files.

    In this case, the usage:

    sln2mak [Solution_FullPath_File_Name].sln

    Example:

    sln2mak c:/myprojects/test/unit_test.sln
  3. The same case as 1, except that the leading project has a name that is different from the solution name. Flag –l for leading followed by leading project name and then solution fullpath.  
  4. In this case, the usage:

    sln2mak -l [LEADING_Project_Name] [Solution_FullPath_File_Name].sln

    Example:

    sln2mak -l unit_test c:/myprojects/test/test.sln
  5. You'd like to create a makefile from a list of projects without solution "wrapper". For example, you'd like to create a makefile with different structures, not like the one you have for WindowsOS.

    You have a main/leading project and other projects are dependencies of that.

    In addition, you have some precompiled libraries (libs) that you'd like to see them as dependencies for the leading project.  However, they are not listed in the main .vcproj. How can it be, you'll ask? For example, in some solution you have your leading project with all its sub-projects. One of those projects, that the leading project is dependent on, has a dependencies to some precompiled libraries and those are listed within its .vcproj file. So if you use the tool for the whole solution, those dependencies for linker will be parsed from this project and will be listed in its .mak file and then linked by linker to the main/leading project well. But now you'd like to compile only specific list of project that don’t involve  the dependent project, so you  are required to list those libs dependencies manually. Flag –d for dependencies followed by the list of those libs dependencies. 

    sln2mak [LEADING_Project_FullPath_Name].vcproj [Project_FullPath_Name_2].vcproj ... 
             [Project_FullPath_Name_n].vcproj -d [lib_Name_1] ... [lib_Name_n]

    Example:

    sln2mak c:/myprojects/tets/unit_test.vcproj c:/myprojects/tets/test_lib.vcproj 
        -d mystaticlib1 mystaticlib2 mystaticlib3 

    For usage, call sln2mak with no arguments.  

    After application runs, you'll find .mak file in path where .vcproj is located with the same name as the project.

    .mak files have all additional libraries path, sources, flags for compiler, linker, preprocessor and target path. 

In .sln path, you'll find Makefile that will handle all target rules (clean, make) and dependencies.

sln2mak/Makefile.JPG

Points of Interest

Parser Class

This class has a static constructor that aims to be known for all classes without instantiation.

It holds regular expression that serves all other classes for parsing .sln and .vcproj files.

Regex m_ProjectGuid      = new Regex(@"ProjectGUID=""\{(.*)\}"""        ) ;
Regex m_SlnExtention     = new Regex(@"(.*)(.[Ss][Ll][Nn])$"            ) ;
Regex m_VcprojExtention  = new Regex(@"(.*)(.[Vv][Cc][Pp][Rr][Oo][Jj])$") ;
Regex m_ProjectRegex     = new Regex(@"Project\(""\{(.*)\}""\) = ""(.*)"", ""(.*)"",
   ""\{(.*)\}""") ;

VcSlnInfo Class

This class parses solution file and creates Makefile with target rules.

This class uses stream reader for reading .sln file line by line. During reading .sln file, it recognizes an active project (its name is similar to the solution name) and creates four dictionaries that hold information about all main and dependent projects:

  • Key = Guid number , Value = ProjectName
  • Key = ProjectName , Value = ProjectFullPath
  • Key = ProjectName , Value = MakeFileName
  • Key = ProjectName , Value = ProjectDependencies
Dictionary<string, string>  m_ProjGuidName = new Dictionary<string, string>() ;

Then method ParseVcproj is called - public VcProjInfo class's function, but first for each .vcproj  instance of VcProjInfo object created with projectName, projectFullPath and projectMakFileName.

VcProjInfo Class

In this class, VCProjectEngine object is used for retrieving all the necessary information about .vcproj, like target type and name, compiler flags, additional libraries, linker flags, sources and filters, preprocessor definitions, configurations, etc.

using Microsoft.VisualStudio.VCProjectEngine;
VCProjectEngine vcprojEngine = new VCProjectEngineObject();
//Init VCProject vcProj object
VCProject m_VcProj = (VCProject)vcprojEngine.LoadProject(vcProjFile);

//Init vcproj configurations list 
IVCCollection m_ConfigCollection = (IVCCollection)m_VcProj.Configurations;

All these helped me to create .mak file with CFLAGS, LDFLAGS, OBJS, etc.

Important Notes

  • There is no loss during the conversion: source code stays unchanged.  
  • Probably I did not cover all flags during parsing from .vcproj to .mak, but now you have all necessary information to be able to add anything I've missed.
  • During my work I inspect that there are few differences between VC++ 8 solution/vcproj and VC++ 9, so you can use this tool for both.
  • If you convert this source code to Visual Studio 2008, please use proper Microsoft.VisualStudio.VCProjectEngine reference version 9.0.0.0 instead of 8.0.0.0.

History  

Prior to writing the application, I tried to find a similar tool on the internet, but was only successful in finding other people's questions on online forums regarding the issue.
Then I attempted to understand XML-schema of a VC++8 solution and project, but the schema wasn't clear enough.

Suddenly I found a Microsoft.VisualStudio.VCProjectEngine reference with VCProjectEngine object within .NET components which helped me to understand the structure of a VC++ 2005 project. I used this object in my application for .vcproj parsing instead of using System.Xml for XML tree reading, and this without proper XML schema documentation.

sln2mak/reference.JPG

Disclaimer 

The information provided on this page comes without any warranty whatsoever.  

This tool has been extensively tested before being published, but always there is the possibility to find some weakness. I strongly recommend that you back up your project before using this tool. Moreover, though I am willing to know if there is anything I can do in order to improve it, let me clearly say that it's not my fault if your project is corrupted by this tool.

Update History  

  • 20/4/2009 Bug fixes (sorry for long delay)
    • Added some spaces in dependencies
    • Removed a loop which was creating multiple rules for a single project
    • Added uppercase WIN32 to be replaced by uppercase LINUX
    • Removed -o option for CPP files
    • Removed printing of "else"
    • Full path for dependent project fixed.

    Especially thanks to Ahmad and Adrej, who helped me to find and fix all listed bugs.

  • 6/9/2008 Bug fixes
    • Uses sln2mak.exe from the same path as .sln/.vcproj.
  • 16/9/2008 Bug fixes 
    • Handles null reference for VC compiler tool, recursive file filters expanding during sources list creation

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

Maria Adamsky
Software Developer EFC Real Solutions on Time,LTD
Israel Israel
Member
Software developer at EFC Real Solutions on Time,LTD(Israel) in infrastructure team.
Developing Grid computing application for data communication simulations.
Writing Cross-Platform Software (Windows and Linux).

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
Hint: For improved responsiveness ensure Javascript is enabled and choose 'Normal' from the Layout dropdown and hit 'Update'.
You must Sign In to use this message board.
Search this forum  
    Spacing  Noise  Layout  Per page   
QuestionProblems when using sln2mak in VS2010 [modified]memberShuai Zhang22hrs 16mins ago 
QuestionUse sln2mak for fortran projectsmemberMartin Estrada22 Mar '13 - 6:45 
AnswerRe: Use sln2mak for fortran projectsmemberMaria Adamsky23 Mar '13 - 0:38 
QuestionUnhandled COMExceptionmemberMember 938139515 Mar '13 - 7:39 
AnswerRe: Unhandled COMExceptionmemberMaria Adamsky23 Mar '13 - 0:47 
AnswerRe: Unhandled COMExceptionmemberHowitZer2619 Apr '13 - 8:08 
GeneralRe: Unhandled COMExceptionmemberMaria Adamsky20 Apr '13 - 1:27 
QuestionUnhandle ExceptionmemberMrKyaw1 Nov '12 - 6:55 
AnswerRe: Unhandle ExceptionmemberMaria Adamsky1 Nov '12 - 8:23 
AnswerRe: Unhandle ExceptionmemberMaria Adamsky1 Nov '12 - 8:30 
GeneralRe: Unhandle ExceptionmemberPeterFig21 Nov '12 - 10:00 
GeneralRe: Unhandle ExceptionmemberNamrata Shet5 Dec '12 - 1:37 
GeneralRe: Unhandle Exceptionmemberc0mas25 Mar '13 - 7:09 
GeneralRe: Unhandle ExceptionmemberMaria Adamsky25 Mar '13 - 8:19 
GeneralRe: Unhandle Exceptionmemberc0mas26 Mar '13 - 0:15 
AnswerRe: Unhandle Exceptionmemberc0mas25 Mar '13 - 7:06 
Questionnot working crapmemberVadim Zyarko8 Oct '12 - 8:43 
AnswerRe: not working crapmemberMaria Adamsky10 Oct '12 - 2:12 
GeneralRe: not working crapmemberHenry Fang28 Oct '12 - 17:24 
QuestionVisual Studio 10 and 11membervit_lynx13 Jul '12 - 1:13 
GeneralRe: Visual Studio 10 and 11memberMaria Adamsky13 Jul '12 - 4:22 
AnswerRe: Visual Studio 10 and 11memberPeterFig21 Nov '12 - 8:48 
GeneralRe: Visual Studio 10 and 11memberMaria Adamsky21 Nov '12 - 10:10 
QuestionRe: Visual Studio 10 and 11memberHowitZer265 Dec '12 - 5:23 
Questiondoes not work in XP ??memberMember 915682722 Jun '12 - 4:49 
AnswerRe: does not work in XP ??memberMaria Adamsky12 Jul '12 - 21:34 
QuestionWin 7 x32 attempt?memberKenLThomas7 Jun '12 - 10:36 
GeneralRe: Win 7 x32 attempt?memberMember 795545011 Jul '12 - 14:08 
GeneralRe: Win 7 x32 attempt?memberMaria Adamsky12 Jul '12 - 21:33 
QuestionLittle improvement for non-project directories in slnmemberMember 895463610 May '12 - 1:12 
AnswerRe: Little improvement for non-project directories in slnmemberMaria Adamsky11 May '12 - 1:21 
QuestionSome bugs?memberGzork22 Mar '12 - 11:01 
AnswerRe: Some bugs?memberMaria Adamsky12 Jul '12 - 21:38 
GeneralMy vote of 5memberLaxmikant_Yadav18 Nov '11 - 0:58 
Questionextracting project makefile pathmemberAmy Phillips 74 Nov '11 - 6:17 
AnswerRe: extracting project makefile pathmemberMaria Adamsky4 Nov '11 - 11:58 
QuestionNeed the correct comandmemberMember 81264623 Aug '11 - 19:54 
AnswerRe: Need the correct comandmemberMaria Adamsky3 Aug '11 - 20:44 
GeneralRe: Need the correct comandmemberMember 81264623 Aug '11 - 20:56 
GeneralRe: Need the correct comandmemberMaria Adamsky3 Aug '11 - 21:55 
GeneralRe: Need the correct comandmemberMember 81264624 Aug '11 - 0:22 
GeneralRe: Need the correct comandmemberMaria Adamsky4 Aug '11 - 0:42 
GeneralRe: Need the correct comandmemberMember 81264624 Aug '11 - 0:52 
GeneralRe: Need the correct comandmemberMaria Adamsky4 Aug '11 - 1:05 
GeneralRe: Need the correct comandmemberMember 81264624 Aug '11 - 1:12 
GeneralRe: Need the correct comandmemberMaria Adamsky4 Aug '11 - 1:26 
GeneralRe: Need the correct comandmemberMember 81264624 Aug '11 - 2:43 
GeneralRe: Need the correct comandmemberMaria Adamsky4 Aug '11 - 2:57 
QuestionIssue when using with VS2005memberMember 22164234 Jul '11 - 3:58 
AnswerRe: Issue when using with VS2005memberMaria Adamsky4 Jul '11 - 6:54 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Permalink | Advertise | Privacy | Mobile
Web03 | 2.6.130513.1 | Last Updated 13 Jul 2012
Article Copyright 2008 by Maria Adamsky
Everything else Copyright © CodeProject, 1999-2013
Terms of Use
Layout: fixed | fluid