summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmExtraEclipseCDT4Generator.cxx156
-rw-r--r--Source/cmExtraEclipseCDT4Generator.h13
2 files changed, 103 insertions, 66 deletions
diff --git a/Source/cmExtraEclipseCDT4Generator.cxx b/Source/cmExtraEclipseCDT4Generator.cxx
index affc0fd..b7461eb 100644
--- a/Source/cmExtraEclipseCDT4Generator.cxx
+++ b/Source/cmExtraEclipseCDT4Generator.cxx
@@ -26,6 +26,7 @@
#include "cmSystemTools.h"
#include <stdlib.h>
+#include <assert.h>
//----------------------------------------------------------------------------
cmExtraEclipseCDT4Generator
@@ -78,6 +79,20 @@ void cmExtraEclipseCDT4Generator::Generate()
this->HomeDirectory = mf->GetHomeDirectory();
this->HomeOutputDirectory = mf->GetHomeOutputDirectory();
+ this->IsOutOfSourceBuild = (this->HomeDirectory!=this->HomeOutputDirectory);
+
+ this->GenerateSourceProject = (this->IsOutOfSourceBuild &&
+ mf->IsOn("ECLIPSE_CDT4_GENERATE_SOURCE_PROJECT"));
+
+ // NOTE: This is not good, since it pollutes the source tree. However,
+ // Eclipse doesn't allow CVS/SVN to work when the .project is not in
+ // the cvs/svn root directory. Hence, this is provided as an option.
+ if (this->GenerateSourceProject)
+ {
+ // create .project file in the source tree
+ this->CreateSourceProjectFile();
+ }
+
// create a .project file
this->CreateProjectFile();
@@ -85,15 +100,44 @@ void cmExtraEclipseCDT4Generator::Generate()
this->CreateCProjectFile();
}
-//----------------------------------------------------------------------------
-void cmExtraEclipseCDT4Generator::CreateProjectFile() const
+void cmExtraEclipseCDT4Generator::CreateSourceProjectFile() const
{
- const cmMakefile* mf
- = this->GlobalGenerator->GetLocalGenerators()[0]->GetMakefile();
+ assert(this->HomeDirectory != this->HomeOutputDirectory);
+
// set up the project name: <project>-Source@<baseSourcePathName>
+ const cmMakefile* mf
+ = this->GlobalGenerator->GetLocalGenerators()[0]->GetMakefile();
std::string name = this->GenerateProjectName(mf->GetProjectName(), "Source",
this->GetPathBasename(this->HomeDirectory));
+ const std::string filename = this->HomeDirectory + "/.project";
+ cmGeneratedFileStream fout(filename.c_str());
+ if (!fout)
+ {
+ return;
+ }
+
+ fout <<
+ "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+ "<projectDescription>\n"
+ "\t<name>" << name << "</name>\n"
+ "\t<comment></comment>\n"
+ "\t<projects>\n"
+ "\t</projects>\n"
+ "\t<buildSpec>\n"
+ "\t</buildSpec>\n"
+ "\t<natures>\n"
+ "\t</natures>\n"
+ "</projectDescription>\n"
+ ;
+}
+
+//----------------------------------------------------------------------------
+void cmExtraEclipseCDT4Generator::CreateProjectFile()
+{
+ const cmMakefile* mf
+ = this->GlobalGenerator->GetLocalGenerators()[0]->GetMakefile();
+
const std::string filename = this->HomeOutputDirectory + "/.project";
cmGeneratedFileStream fout(filename.c_str());
@@ -285,7 +329,7 @@ void cmExtraEclipseCDT4Generator::CreateProjectFile() const
// TODO: refactor this
// create linked resources
- if (this->HomeDirectory != this->HomeOutputDirectory)
+ if (this->IsOutOfSourceBuild)
{
fout << "\t<linkedResources>\n";
// for each sub project create a linked resource to the source dir
@@ -297,18 +341,13 @@ void cmExtraEclipseCDT4Generator::CreateProjectFile() const
{
std::string linkSourceDirectory =this->GetEclipsePath(
it->second[0]->GetMakefile()->GetStartDirectory());
+ // .project dir can't be subdir of a linked resource dir
if (!cmSystemTools::IsSubDirectory(this->HomeOutputDirectory.c_str(),
linkSourceDirectory.c_str()))
{
- fout <<
- "\t\t<link>\n"
- "\t\t\t<name>" << it->first << "</name>\n"
- "\t\t\t<type>2</type>\n"
- "\t\t\t<location>"
- << this->GetEclipsePath(linkSourceDirectory)
- << "</location>\n"
- "\t\t</link>\n"
- ;
+ this->AppendLinkedResource(fout, it->first,
+ this->GetEclipsePath(linkSourceDirectory));
+ this->SrcLinkedResources.push_back(it->first);
}
}
// for EXECUTABLE_OUTPUT_PATH when not in binary dir
@@ -317,20 +356,16 @@ void cmExtraEclipseCDT4Generator::CreateProjectFile() const
this->HomeOutputDirectory.c_str()))
{
std::string name = this->GetPathBasename(output_path);
+
+ // make sure linked resource name is unique
while (this->GlobalGenerator->GetProjectMap().find(name)
!= this->GlobalGenerator->GetProjectMap().end())
{
name += "_";
}
- fout <<
- "\t\t<link>\n"
- "\t\t\t<name>" << name << "</name>\n"
- "\t\t\t<type>2</type>\n"
- "\t\t\t<location>"
- << this->GetEclipsePath(output_path)
- << "</location>\n"
- "\t\t</link>\n"
- ;
+ this->AppendLinkedResource(fout, name,
+ this->GetEclipsePath(output_path));
+ this->OutLinkedResources.push_back(name);
}
// for LIBRARY_OUTPUT_PATH when not in binary dir
if (output_path != mf->GetDefinition("LIBRARY_OUTPUT_PATH"))
@@ -340,20 +375,16 @@ void cmExtraEclipseCDT4Generator::CreateProjectFile() const
this->HomeOutputDirectory.c_str()))
{
std::string name = this->GetPathBasename(output_path);
+
+ // make sure linked resource name is unique
while (this->GlobalGenerator->GetProjectMap().find(name)
!= this->GlobalGenerator->GetProjectMap().end())
{
name += "_";
}
- fout <<
- "\t\t<link>\n"
- "\t\t\t<name>" << name << "</name>\n"
- "\t\t\t<type>2</type>\n"
- "\t\t\t<location>"
- << this->GetEclipsePath(output_path)
- << "</location>\n"
- "\t\t</link>\n"
- ;
+ this->AppendLinkedResource(fout, name,
+ this->GetEclipsePath(output_path));
+ this->OutLinkedResources.push_back(name);
}
}
fout << "\t</linkedResources>\n";
@@ -472,19 +503,19 @@ void cmExtraEclipseCDT4Generator::CreateCProjectFile() const
// - make it type 'src'
// - and exclude it from type 'out'
std::string exclude_from_out;
- for (std::map<cmStdString, std::vector<cmLocalGenerator*> >::const_iterator
- it = this->GlobalGenerator->GetProjectMap().begin();
- it != this->GlobalGenerator->GetProjectMap().end();
+ for (std::vector<std::string>::const_iterator
+ it = this->SrcLinkedResources.begin();
+ it != this->SrcLinkedResources.end();
++it)
{
- fout << "<pathentry kind=\"src\" path=\"" << it->first << "\"/>\n";
+ fout << "<pathentry kind=\"src\" path=\"" << *it << "\"/>\n";
// exlude source directory from output search path
// - only if not named the same as an output directory
if (!cmSystemTools::FileIsDirectory(
- std::string(this->HomeOutputDirectory + "/" + it->first).c_str()))
+ std::string(this->HomeOutputDirectory + "/" + *it).c_str()))
{
- exclude_from_out += it->first + "/|";
+ exclude_from_out += *it + "/|";
}
}
exclude_from_out += "**/CMakeFiles/";
@@ -494,33 +525,12 @@ void cmExtraEclipseCDT4Generator::CreateCProjectFile() const
// - if it is a subdir of homeOutputDirectory, there is no need to add it
// - if it is not then create a linked resource and add the linked name
// but check it doesn't conflict with other linked resources names
- std::string output_path = mf->GetDefinition("EXECUTABLE_OUTPUT_PATH");
- if (!cmSystemTools::IsSubDirectory(output_path.c_str(),
- this->HomeOutputDirectory.c_str()))
- {
- std::string name = this->GetPathBasename(output_path);
- while (this->GlobalGenerator->GetProjectMap().find(name)
- != this->GlobalGenerator->GetProjectMap().end())
- {
- name += "_";
- }
- fout << "<pathentry kind=\"out\" path=\"" << name << "\"/>\n";
- }
- // for LIBRARY_OUTPUT_PATH when not in binary dir
- if (output_path != mf->GetDefinition("LIBRARY_OUTPUT_PATH"))
+ for (std::vector<std::string>::const_iterator
+ it = this->OutLinkedResources.begin();
+ it != this->OutLinkedResources.end();
+ ++it)
{
- output_path = mf->GetDefinition("LIBRARY_OUTPUT_PATH");
- if (!cmSystemTools::IsSubDirectory(output_path.c_str(),
- this->HomeOutputDirectory.c_str()))
- {
- std::string name = this->GetPathBasename(output_path);
- while (this->GlobalGenerator->GetProjectMap().find(name)
- != this->GlobalGenerator->GetProjectMap().end())
- {
- name += "_";
- }
- fout << "<pathentry kind=\"out\" path=\"" << name << "\"/>\n";
- }
+ fout << "<pathentry kind=\"out\" path=\"" << *it << "\"/>\n";
}
// add pre-processor definitions to allow eclipse to gray out sections
@@ -543,7 +553,7 @@ void cmExtraEclipseCDT4Generator::CreateCProjectFile() const
{
std::string::size_type equals = di->find('=', 0);
std::string::size_type enddef = di->length();
-
+
std::string def;
std::string val;
if (equals != std::string::npos && equals < enddef)
@@ -843,3 +853,19 @@ void cmExtraEclipseCDT4Generator
"</profile>\n"
;
}
+
+void cmExtraEclipseCDT4Generator
+::AppendLinkedResource (cmGeneratedFileStream& fout,
+ const std::string& name,
+ const std::string& path)
+{
+ fout <<
+ "\t\t<link>\n"
+ "\t\t\t<name>" << name << "</name>\n"
+ "\t\t\t<type>2</type>\n"
+ "\t\t\t<location>"
+ << path
+ << "</location>\n"
+ "\t\t</link>\n"
+ ;
+}
diff --git a/Source/cmExtraEclipseCDT4Generator.h b/Source/cmExtraEclipseCDT4Generator.h
index d025c89..aa9da23 100644
--- a/Source/cmExtraEclipseCDT4Generator.h
+++ b/Source/cmExtraEclipseCDT4Generator.h
@@ -52,8 +52,11 @@ public:
virtual void Generate();
private:
+ // create .project file in the source tree
+ void CreateSourceProjectFile() const;
+
// create .project file
- void CreateProjectFile() const;
+ void CreateProjectFile();
// create .cproject file
void CreateCProjectFile() const;
@@ -97,8 +100,16 @@ private:
bool runActionUseDefault,
bool sipParserEnabled);
+ static void AppendLinkedResource (cmGeneratedFileStream& fout,
+ const std::string& name,
+ const std::string& path);
+
+ std::vector<std::string> SrcLinkedResources;
+ std::vector<std::string> OutLinkedResources;
std::string HomeDirectory;
std::string HomeOutputDirectory;
+ bool IsOutOfSourceBuild;
+ bool GenerateSourceProject;
};