diff options
author | Alexander Neundorf <neundorf@kde.org> | 2009-09-10 17:49:51 (GMT) |
---|---|---|
committer | Alexander Neundorf <neundorf@kde.org> | 2009-09-10 17:49:51 (GMT) |
commit | 6097c04c4d5f847dc7de1fb32f1cfd12b405db81 (patch) | |
tree | f3b8eb923c39d7d65ebfbdc49410074c58101e2d /Source/cmExtraEclipseCDT4Generator.cxx | |
parent | 10f39d8c802e23b5b6b0f249f5dd8b36cbcb24b5 (diff) | |
download | CMake-6097c04c4d5f847dc7de1fb32f1cfd12b405db81.zip CMake-6097c04c4d5f847dc7de1fb32f1cfd12b405db81.tar.gz CMake-6097c04c4d5f847dc7de1fb32f1cfd12b405db81.tar.bz2 |
sync target generation with the CodeBlocks generator
Basically the code is now a copy of the one from the CodeBlocks generator,
maybe this could move into a common helper function somewhere:
-only insert GLOBAL targets from the toplevel directory
-don't insert the edit_cache target if it calls ccmake, since this doesn't
work in the output tab of Eclipse
-add the /fast targets
Alex
Diffstat (limited to 'Source/cmExtraEclipseCDT4Generator.cxx')
-rw-r--r-- | Source/cmExtraEclipseCDT4Generator.cxx | 130 |
1 files changed, 51 insertions, 79 deletions
diff --git a/Source/cmExtraEclipseCDT4Generator.cxx b/Source/cmExtraEclipseCDT4Generator.cxx index 4551b2f..a21df66 100644 --- a/Source/cmExtraEclipseCDT4Generator.cxx +++ b/Source/cmExtraEclipseCDT4Generator.cxx @@ -40,36 +40,6 @@ cmExtraEclipseCDT4Generator // this->SupportedGlobalGenerators.push_back("MSYS Makefiles"); #endif this->SupportedGlobalGenerators.push_back("Unix Makefiles"); - - // don't create these targets in Eclipse, they are too many and - // should be only rarely used directly - this->TargetsToIgnore.insert("preinstall"); - this->TargetsToIgnore.insert("install/local"); - this->TargetsToIgnore.insert("ContinuousBuild"); - this->TargetsToIgnore.insert("ContinuousConfigure"); - this->TargetsToIgnore.insert("ContinuousCoverage"); - this->TargetsToIgnore.insert("ContinuousMemCheck"); - this->TargetsToIgnore.insert("ContinuousStart"); - this->TargetsToIgnore.insert("ContinuousSubmit"); - this->TargetsToIgnore.insert("ContinuousTest"); - this->TargetsToIgnore.insert("ContinuousUpdate"); - this->TargetsToIgnore.insert("ExperimentalBuild"); - this->TargetsToIgnore.insert("ExperimentalConfigure"); - this->TargetsToIgnore.insert("ExperimentalCoverage"); - this->TargetsToIgnore.insert("ExperimentalMemCheck"); - this->TargetsToIgnore.insert("ExperimentalStart"); - this->TargetsToIgnore.insert("ExperimentalSubmit"); - this->TargetsToIgnore.insert("ExperimentalTest"); - this->TargetsToIgnore.insert("ExperimentalUpdate"); - this->TargetsToIgnore.insert("NightlyBuild"); - this->TargetsToIgnore.insert("NightlyConfigure"); - this->TargetsToIgnore.insert("NightlyCoverage"); - this->TargetsToIgnore.insert("NightlyMemCheck"); - this->TargetsToIgnore.insert("NightlyMemoryCheck"); - this->TargetsToIgnore.insert("NightlyStart"); - this->TargetsToIgnore.insert("NightlySubmit"); - this->TargetsToIgnore.insert("NightlyTest"); - this->TargetsToIgnore.insert("NightlyUpdate"); } //---------------------------------------------------------------------------- @@ -669,59 +639,61 @@ void cmExtraEclipseCDT4Generator::CreateCProjectFile() const ++it) { const cmTargets& targets = (*it)->GetMakefile()->GetTargets(); - for(cmTargets::const_iterator t = targets.begin(); t != targets.end(); ++t) + cmMakefile* makefile=(*it)->GetMakefile(); + for(cmTargets::const_iterator ti=targets.begin(); ti!=targets.end(); ++ti) { - bool addFastTarget = false; - switch(t->second.GetType()) + switch(ti->second.GetType()) { - case cmTarget::EXECUTABLE: - case cmTarget::STATIC_LIBRARY: - case cmTarget::SHARED_LIBRARY: - case cmTarget::MODULE_LIBRARY: - addFastTarget = true; - // no break here - case cmTarget::UTILITY: case cmTarget::GLOBAL_TARGET: { - bool insertTarget = true; - if(insertTarget && - (std::set<std::string>::const_iterator( - this->TargetsToIgnore.find(t->first)) != - this->TargetsToIgnore.end())) - { - insertTarget = false; - } - - if(insertTarget && (emmited.find(t->first) != emmited.end())) - { - insertTarget = false; - } - - // add the edit_cache target only if it's not ccmake - // otherwise ccmake will be executed in the log view of Eclipse, - // which is no terminal, so curses don't work there, Alex - if (insertTarget && (t->first=="edit_cache")) - { - if (strstr(mf->GetRequiredDefinition("CMAKE_EDIT_COMMAND"), - "ccmake")!=NULL) - { - insertTarget = false; - } - } - - if (insertTarget) - { - emmited.insert(t->first); - this->AppendTarget(fout, t->first, make); - if (addFastTarget || t->first=="install") - { - std::string fastTarget = t->first; - fastTarget = fastTarget + "/fast"; - this->AppendTarget(fout, fastTarget, make); - } - } - break; - } + bool insertTarget = false; + // Only add the global targets from CMAKE_BINARY_DIR, + // not from the subdirs + if (strcmp(makefile->GetStartOutputDirectory(), + makefile->GetHomeOutputDirectory())==0) + { + insertTarget = true; + // only add the "edit_cache" target if it's not ccmake, because + // this will not work within the IDE + if (ti->first == "edit_cache") + { + if (strstr(makefile->GetRequiredDefinition + ("CMAKE_EDIT_COMMAND"), "ccmake")!=NULL) + { + insertTarget = false; + } + } + } + if (insertTarget) + { + this->AppendTarget(fout, ti->first, make); + } + } + break; + case cmTarget::UTILITY: + // Add all utility targets, except the Nightly/Continuous/ + // Experimental-"sub"targets as e.g. NightlyStart + if (((ti->first.find("Nightly")==0) &&(ti->first!="Nightly")) + || ((ti->first.find("Continuous")==0)&&(ti->first!="Continuous")) + || ((ti->first.find("Experimental")==0) + && (ti->first!="Experimental"))) + { + break; + } + + this->AppendTarget(fout, ti->first, make); + break; + case cmTarget::EXECUTABLE: + case cmTarget::STATIC_LIBRARY: + case cmTarget::SHARED_LIBRARY: + case cmTarget::MODULE_LIBRARY: + { + this->AppendTarget(fout, ti->first, make); + std::string fastTarget = ti->first; + fastTarget += "/fast"; + this->AppendTarget(fout, fastTarget, make); + } + break; // ignore these: case cmTarget::INSTALL_FILES: case cmTarget::INSTALL_PROGRAMS: |