From 8b54b7a68358e0eda5b1d28a2bff68ab90edcf14 Mon Sep 17 00:00:00 2001 From: Andy Cedilnik Date: Thu, 24 Feb 2005 15:34:14 -0500 Subject: ENH: fix spaces in paths problems --- Source/cmGlobalXCodeGenerator.cxx | 32 ++++++++++++++++++++++++-------- Source/cmGlobalXCodeGenerator.h | 1 + 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 const& deplibs = target->GetDependLibraries(); std::string tfull = this->GetTargetFullPath(target->GetcmTarget()); - makefileStream << tfull << ": "; + makefileStream << this->ConvertToRelativeOutputPath(tfull.c_str()) << ": "; for(std::vector::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, -- cgit v0.12