summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorAndy Cedilnik <andy.cedilnik@kitware.com>2005-02-24 20:34:14 (GMT)
committerAndy Cedilnik <andy.cedilnik@kitware.com>2005-02-24 20:34:14 (GMT)
commit8b54b7a68358e0eda5b1d28a2bff68ab90edcf14 (patch)
treed51d695f80eda898dc4d5af950883c2b0c5cc08b /Source
parent495666742baf665e78c8d1d5a38bea6f0e8ab837 (diff)
downloadCMake-8b54b7a68358e0eda5b1d28a2bff68ab90edcf14.zip
CMake-8b54b7a68358e0eda5b1d28a2bff68ab90edcf14.tar.gz
CMake-8b54b7a68358e0eda5b1d28a2bff68ab90edcf14.tar.bz2
ENH: fix spaces in paths problems
Diffstat (limited to 'Source')
-rw-r--r--Source/cmGlobalXCodeGenerator.cxx32
-rw-r--r--Source/cmGlobalXCodeGenerator.h1
2 files changed, 25 insertions, 8 deletions
diff --git a/Source/cmGlobalXCodeGenerator.cxx b/Source/cmGlobalXCodeGenerator.cxx
index e227074..e0aaf88 100644
--- a/Source/cmGlobalXCodeGenerator.cxx
+++ b/Source/cmGlobalXCodeGenerator.cxx
@@ -698,7 +698,8 @@ cmGlobalXCodeGenerator::AddCommandsToBuildPhase(cmXCodeObject* buildphase,
{
if(!this->FindTarget(d->c_str()))
{
- makefileStream << "\\\n" << *d;
+ makefileStream << "\\\n" << this
+ ->ConvertToRelativeOutputPath(d->c_str());
}
else
{
@@ -885,7 +886,7 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
l != linkdirs.end(); ++l)
{
std::string libpath =
- this->ConvertToRelativeOutputPath(l->c_str());
+ this->XCodeEscapePath(l->c_str());
if(emitted.insert(libpath).second)
{
dirs += libpath + " ";
@@ -904,7 +905,7 @@ void cmGlobalXCodeGenerator::CreateBuildSettings(cmTarget& target,
for(;i != includes.end(); ++i)
{
std::string incpath =
- this->ConvertToRelativeOutputPath(i->c_str());
+ this->XCodeEscapePath(i->c_str());
dirs += incpath + " ";
}
if(dirs.size())
@@ -1389,7 +1390,8 @@ cmGlobalXCodeGenerator::CreateXCodeDependHackTarget(
t->GetType() == cmTarget::MODULE_LIBRARY)
{
makefileStream << "\\\n\t"
- << this->GetTargetFullPath(target->GetcmTarget());
+ << this->
+ ConvertToRelativeOutputPath(this->GetTargetFullPath(target->GetcmTarget()).c_str());
}
}
makefileStream << "\n\n";
@@ -1407,7 +1409,7 @@ cmGlobalXCodeGenerator::CreateXCodeDependHackTarget(
{
if(emitted.insert(*d).second)
{
- makefileStream << *d << ":\n";
+ makefileStream << this->ConvertToRelativeOutputPath(d->c_str()) << ":\n";
}
}
}
@@ -1428,14 +1430,15 @@ cmGlobalXCodeGenerator::CreateXCodeDependHackTarget(
{
std::vector<cmStdString> const& deplibs = target->GetDependLibraries();
std::string tfull = this->GetTargetFullPath(target->GetcmTarget());
- makefileStream << tfull << ": ";
+ makefileStream << this->ConvertToRelativeOutputPath(tfull.c_str()) << ": ";
for(std::vector<cmStdString>::const_iterator d = deplibs.begin();
d != deplibs.end(); ++d)
{
- makefileStream << "\\\n\t" << *d;
+ makefileStream << "\\\n\t" << this->ConvertToRelativeOutputPath(d->c_str());
}
makefileStream << "\n";
- makefileStream << "\t/bin/rm -f " << tfull << "\n";
+ makefileStream << "\t/bin/rm -f "
+ << this->ConvertToRelativeOutputPath(tfull.c_str()) << "\n";
makefileStream << "\n\n";
}
}
@@ -1556,3 +1559,16 @@ std::string cmGlobalXCodeGenerator::ConvertToRelativeOutputPath(const char* p)
// and correct escaping/quoting of spaces in the path
return ret;
}
+
+std::string cmGlobalXCodeGenerator::XCodeEscapePath(const char* p)
+{
+ std::string ret = p;
+ if(ret.find(' ') != ret.npos)
+ {
+ std::string t = ret;
+ ret = "\\\"";
+ ret += t;
+ ret += "\\\"";
+ }
+ return ret;
+}
diff --git a/Source/cmGlobalXCodeGenerator.h b/Source/cmGlobalXCodeGenerator.h
index e7197be..cb9cd11 100644
--- a/Source/cmGlobalXCodeGenerator.h
+++ b/Source/cmGlobalXCodeGenerator.h
@@ -69,6 +69,7 @@ public:
virtual void Generate();
private:
+ std::string XCodeEscapePath(const char* p);
std::string ConvertToRelativeOutputPath(const char* p);
void CreateCustomCommands(cmXCodeObject* buildPhases,
cmXCodeObject* sourceBuildPhase,