diff options
author | Alexander Neundorf <neundorf@kde.org> | 2007-11-25 12:40:57 (GMT) |
---|---|---|
committer | Alexander Neundorf <neundorf@kde.org> | 2007-11-25 12:40:57 (GMT) |
commit | 38896657db4bfa52a0e2906aa86cf2de50b6a17e (patch) | |
tree | 7021de6d14c818688f8bbfe493c5b1d19350dc82 /Source/cmExtraEclipseCDT4Generator.cxx | |
parent | 4ed64cf73a389ff139649bce37e4eefae93329cd (diff) | |
download | CMake-38896657db4bfa52a0e2906aa86cf2de50b6a17e.zip CMake-38896657db4bfa52a0e2906aa86cf2de50b6a17e.tar.gz CMake-38896657db4bfa52a0e2906aa86cf2de50b6a17e.tar.bz2 |
ENH: add the "clean" target
don't add *all existing* targets as Eclipse targets, but only a subset (the
same as for CodeBlocks), e.g. exclude the subtargets of Experimental, and
also edit_cache, ccmake doesn't work from within an IDE
Alex
Diffstat (limited to 'Source/cmExtraEclipseCDT4Generator.cxx')
-rw-r--r-- | Source/cmExtraEclipseCDT4Generator.cxx | 87 |
1 files changed, 83 insertions, 4 deletions
diff --git a/Source/cmExtraEclipseCDT4Generator.cxx b/Source/cmExtraEclipseCDT4Generator.cxx index 89c056e..e3c7620 100644 --- a/Source/cmExtraEclipseCDT4Generator.cxx +++ b/Source/cmExtraEclipseCDT4Generator.cxx @@ -537,7 +537,6 @@ void cmExtraEclipseCDT4Generator::CreateCProjectFile() const "<buildTargets>\n" ; emmited.clear(); - // TODO: Check how to add 'clean' target... const std::string make = mf->GetRequiredDefinition("CMAKE_MAKE_PROGRAM"); cmGlobalGenerator* generator = const_cast<cmGlobalGenerator*>(this->GlobalGenerator); @@ -554,6 +553,25 @@ void cmExtraEclipseCDT4Generator::CreateCProjectFile() const cmExtraEclipseCDT4Generator ::AppendTarget(fout, generator->GetPreinstallTargetName(), make); } + + if (generator->GetCleanTargetName()) + { + emmited.insert(generator->GetCleanTargetName()); + cmExtraEclipseCDT4Generator + ::AppendTarget(fout, generator->GetCleanTargetName(), make); + } + + bool installTargetCreated = false; + bool installStripTargetCreated = false; + bool testTargetCreated = false; + bool experimentalTargetCreated = false; + bool nightlyTargetCreated = false; + bool packageTargetCreated = false; + bool packageSourceTargetCreated = false; + bool rebuildCacheTargetCreated = false; + + // add all executable and library targets and some of the GLOBAL + // and UTILITY targets for (std::vector<cmLocalGenerator*>::const_iterator it = this->GlobalGenerator->GetLocalGenerators().begin(); it != this->GlobalGenerator->GetLocalGenerators().end(); @@ -562,10 +580,71 @@ void cmExtraEclipseCDT4Generator::CreateCProjectFile() const const cmTargets& targets = (*it)->GetMakefile()->GetTargets(); for(cmTargets::const_iterator t = targets.begin(); t != targets.end(); ++t) { - if(emmited.find(t->first) == emmited.end()) + switch(t->second.GetType()) { - emmited.insert(t->first); - cmExtraEclipseCDT4Generator::AppendTarget(fout, t->first, make); + case cmTarget::UTILITY: + case cmTarget::GLOBAL_TARGET: + { + // only add these global targets once + if ((t->first=="install") && (installTargetCreated==false)) + { + installTargetCreated=true; + } + else if ((t->first=="install/strip") + && (installStripTargetCreated==false)) + { + installStripTargetCreated=true; + } + else if ((t->first=="test") && (testTargetCreated==false)) + { + testTargetCreated=true; + } + else if ((t->first=="Experimental") + && (experimentalTargetCreated==false)) + { + experimentalTargetCreated=true; + } + else if ((t->first=="Nightly") && (nightlyTargetCreated==false)) + { + nightlyTargetCreated=true; + } + else if ((t->first=="package") && (packageTargetCreated==false)) + { + packageTargetCreated=true; + } + else if ((t->first=="package_source") + && (packageSourceTargetCreated==false)) + { + packageSourceTargetCreated=true; + } + else if ((t->first=="rebuild_cache") + && (rebuildCacheTargetCreated==false)) + { + rebuildCacheTargetCreated=true; + } + else // in all cases above fallthrough + { + break; + } + } + case cmTarget::EXECUTABLE: + case cmTarget::STATIC_LIBRARY: + case cmTarget::SHARED_LIBRARY: + case cmTarget::MODULE_LIBRARY: + { + if(emmited.find(t->first) == emmited.end()) + { + emmited.insert(t->first); + cmExtraEclipseCDT4Generator::AppendTarget(fout, t->first, make); + } + break; + } + // ignore these: + case cmTarget::INSTALL_FILES: + case cmTarget::INSTALL_PROGRAMS: + case cmTarget::INSTALL_DIRECTORY: + default: + break; } } } |