diff options
author | Alexander Neundorf <neundorf@kde.org> | 2007-08-29 14:12:09 (GMT) |
---|---|---|
committer | Alexander Neundorf <neundorf@kde.org> | 2007-08-29 14:12:09 (GMT) |
commit | a392c7b5b19923ed88ff0b7ad7d2e578ad58ed1a (patch) | |
tree | b9c21304b55dffcf45c64fa193204cbca0f2a4a5 | |
parent | fc9f19b202844fb612ccf7e0c38181e0959e7ac1 (diff) | |
download | CMake-a392c7b5b19923ed88ff0b7ad7d2e578ad58ed1a.zip CMake-a392c7b5b19923ed88ff0b7ad7d2e578ad58ed1a.tar.gz CMake-a392c7b5b19923ed88ff0b7ad7d2e578ad58ed1a.tar.bz2 |
ENH: don't hardcode gcc
-put the include dirs in the project file to enable autocompletion
-prepare for nmake
Alex
-rw-r--r-- | Source/cmExtraCodeBlocksGenerator.cxx | 184 | ||||
-rw-r--r-- | Source/cmExtraCodeBlocksGenerator.h | 5 |
2 files changed, 152 insertions, 37 deletions
diff --git a/Source/cmExtraCodeBlocksGenerator.cxx b/Source/cmExtraCodeBlocksGenerator.cxx index 3c90ca7..fc5c8c0 100644 --- a/Source/cmExtraCodeBlocksGenerator.cxx +++ b/Source/cmExtraCodeBlocksGenerator.cxx @@ -24,6 +24,7 @@ #include "cmSourceFile.h" #include "cmGeneratedFileStream.h" #include "cmTarget.h" +#include "cmSystemTools.h" #include <cmsys/SystemTools.hxx> @@ -131,16 +132,17 @@ void cmExtraCodeBlocksGenerator return; } + // figure out the compiler + std::string compiler = this->GetCBCompilerId(mf); std::string make = mf->GetRequiredDefinition("CMAKE_MAKE_PROGRAM"); fout<<"<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\" ?>\n" "<CodeBlocks_project_file>\n" " <FileVersion major=\"1\" minor=\"6\" />\n" - " <Project>\n"; - - fout<<" <Option title=\"" << mf->GetProjectName()<<"\" />\n" + " <Project>\n" + " <Option title=\"" << mf->GetProjectName()<<"\" />\n" " <Option makefile_is_custom=\"1\" />\n" - " <Option compiler=\"gcc\" />\n" + " <Option compiler=\"" << compiler << "\" />\n" " <Build>\n"; bool installTargetCreated = false; @@ -178,27 +180,39 @@ void cmExtraCodeBlocksGenerator case cmTarget::STATIC_LIBRARY: case cmTarget::SHARED_LIBRARY: case cmTarget::MODULE_LIBRARY: -// case cmTarget::UTILITY: - fout<<" <Target title=\""<<ti->first<<"\">\n" - " <Option output=\""<<ti->second.GetLocation(0) - <<"\" prefix_auto=\"0\" extension_auto=\"0\" />\n" - " <Option working_dir=\""<<makefile->GetStartOutputDirectory() - <<"\" />\n" - " <Option type=\"0\" />\n" - " <Option compiler=\"gcc\" />\n" - " <MakeCommands>\n"; - - fout<<" <Build command=\""<<make<<" -f " - <<makefile->GetStartOutputDirectory()<<"/Makefile "<<ti->first<<"\" />\n"; - fout<<" <CompileFile command=\""<<make<<" -f " - <<makefile->GetStartOutputDirectory()<<"/Makefile "<<ti->first<<"\" />\n"; - fout<<" <Clean command=\""<<make<<" -f " - <<makefile->GetStartOutputDirectory()<<"/Makefile clean\" />\n"; - fout<<" <DistClean command=\""<<make<<" -f " - <<makefile->GetStartOutputDirectory()<<"/Makefile clean\" />\n"; - - fout<<" </MakeCommands>\n" + { + int cbTargetType = this->GetCBTargetType(&ti->second); + std::string makefileName = makefile->GetStartOutputDirectory(); + makefileName += "/Makefile"; + makefileName = cmSystemTools::ConvertToOutputPath( + makefileName.c_str()); + + fout<<" <Target title=\"" << ti->first << "\">\n" + " <Option output=\"" << ti->second.GetLocation(0) << "\" prefix_auto=\"0\" extension_auto=\"0\" />\n" + " <Option working_dir=\"" << makefile->GetStartOutputDirectory() <<"\" />\n" + " <Option type=\"" << cbTargetType << "\" />\n" + " <Option compiler=\"" << compiler << "\" />\n" + " <Compiler>\n"; + + // the include directories for this target + const std::vector<std::string>& incDirs = + ti->second.GetMakefile()->GetIncludeDirectories(); + for(std::vector<std::string>::const_iterator dirIt=incDirs.begin(); + dirIt != incDirs.end(); + ++dirIt) + { + fout <<" <Add directory=\"" << dirIt->c_str() << "\" />\n"; + } + + fout<<" </Compiler>\n" + " <MakeCommands>\n" + " <Build command=\"" << this->BuildMakeCommand(make, makefileName.c_str(), ti->first.c_str()) << "\" />\n" + " <CompileFile command=\"" << this->BuildMakeCommand(make, makefileName.c_str(), ti->first.c_str()) << "\" />\n" + " <Clean command=\"" << this->BuildMakeCommand(make, makefileName.c_str(), "clean") << "\" />\n" + " <DistClean command=\"" << this->BuildMakeCommand(make, makefileName.c_str(), "clean") << "\" />\n" + " </MakeCommands>\n" " </Target>\n"; + } break; default: break; @@ -208,47 +222,143 @@ void cmExtraCodeBlocksGenerator fout<<" </Build>\n"; - + std::map<std::string, std::string> sourceFiles; for (std::vector<cmLocalGenerator*>::const_iterator lg=lgs.begin(); lg!=lgs.end(); lg++) - { + { cmMakefile* makefile=(*lg)->GetMakefile(); cmTargets& targets=makefile->GetTargets(); for (cmTargets::iterator ti = targets.begin(); ti != targets.end(); ti++) - { - switch(ti->second.GetType()) { + switch(ti->second.GetType()) + { case cmTarget::EXECUTABLE: case cmTarget::STATIC_LIBRARY: case cmTarget::SHARED_LIBRARY: case cmTarget::MODULE_LIBRARY: - { + { const std::vector<cmSourceFile*>&sources=ti->second.GetSourceFiles(); for (std::vector<cmSourceFile*>::const_iterator si=sources.begin(); si!=sources.end(); si++) - { + { sourceFiles[(*si)->GetFullPath()] = ti->first; + } } - } - default: + default: // intended fallthrough break; + } } } - } - + for (std::map<std::string, std::string>::const_iterator sit=sourceFiles.begin(); sit!=sourceFiles.end(); ++sit) { - fout<<" <Unit filename=\""<<sit->first <<"\">\n"; - fout<<" </Unit>\n"; + fout<<" <Unit filename=\""<<sit->first <<"\">\n" + " </Unit>\n"; } - + fout<<" </Project>\n" "</CodeBlocks_project_file>\n"; +} + + +std::string cmExtraCodeBlocksGenerator::GetCBCompilerId(const cmMakefile* mf) +{ + // figure out which language to use + // for now care only for C and C++ + std::string compilerIdVar = "CMAKE_CXX_COMPILER_ID"; + cmGlobalGenerator* gg=const_cast<cmGlobalGenerator*>(this->GlobalGenerator); + if (gg->GetLanguageEnabled("CXX") == false) + { + compilerIdVar = "CMAKE_C_COMPILER_ID"; + } + + std::string hostSystemName = mf->GetSafeDefinition("CMAKE_HOST_SYSTEM_NAME"); + std::string systemName = mf->GetSafeDefinition("CMAKE_SYSTEM_NAME"); + std::string compilerId = mf->GetRequiredDefinition(compilerIdVar.c_str()); + std::string compiler = "gcc"; + if (compilerId == "MSVC") + { + compiler = "msvc"; + } + else if (compilerId == "Borland") + { + compiler = "bcc"; + } + else if (compilerId == "SDCC") + { + compiler = "sdcc"; + } + else if (compilerId == "Intel") + { + compiler = "icc"; + } + else if (compilerId == "Watcom") + { + compiler = "ow"; + } + else if (compilerId == "GNU") + { + if (hostSystemName == "Windows") + { + compiler = "mingw"; + } + else + { + compiler = "gcc"; + } + } + return compiler; +} + +int cmExtraCodeBlocksGenerator::GetCBTargetType(cmTarget* target) +{ + if ( target->GetType()==cmTarget::EXECUTABLE) + { + if ((target->GetPropertyAsBool("WIN32_EXECUTABLE")) + || (target->GetPropertyAsBool("MACOSX_BUNDLE"))) + { + return 0; + } + else + { + return 1; + } + } + else if ( target->GetType()==cmTarget::STATIC_LIBRARY) + { + return 2; + } + else if ((target->GetType()==cmTarget::SHARED_LIBRARY) + || (target->GetType()==cmTarget::MODULE_LIBRARY)) + { + return 3; + } + return 4; } +std::string cmExtraCodeBlocksGenerator::BuildMakeCommand( + const std::string& make, const char* makefile, const char* target) +{ + std::string command = make; + if (strcmp(this->GlobalGenerator->GetName(), "NMake Makefiles")==0) + { + command += " /NOLOGO /f \\\""; + command += makefile; + command += "\\\" "; + command += target; + } + else + { + command += " -f "; + command += makefile; + command += " "; + command += target; + } + return command; +} diff --git a/Source/cmExtraCodeBlocksGenerator.h b/Source/cmExtraCodeBlocksGenerator.h index 9d59936..6daa976 100644 --- a/Source/cmExtraCodeBlocksGenerator.h +++ b/Source/cmExtraCodeBlocksGenerator.h @@ -22,6 +22,7 @@ class cmLocalGenerator; class cmMakefile; +class cmTarget; /** \class cmExtraCodeBlocksGenerator * \brief Write CodeBlocks project files for Makefile based projects @@ -50,6 +51,10 @@ private: void CreateNewProjectFile(const std::vector<cmLocalGenerator*>& lgs, const std::string& filename); + std::string GetCBCompilerId(const cmMakefile* mf); + int GetCBTargetType(cmTarget* target); + std::string BuildMakeCommand(const std::string& make, const char* makefile, + const char* target); }; |