From ddf814f964f16b72ed294b099a4c0c9c575efb92 Mon Sep 17 00:00:00 2001 From: Andy Cedilnik Date: Wed, 28 Apr 2004 10:15:40 -0400 Subject: ENH: Encode object files with funny characters in the name. It should fix Bug #418 - Borland 5.5.1, Templates/*.cxx files with '+' chars used in execs --- Source/cmLocalUnixMakefileGenerator.cxx | 50 ++++++++++++++++++++++++++++++--- Source/cmLocalUnixMakefileGenerator.h | 7 +++++ 2 files changed, 53 insertions(+), 4 deletions(-) diff --git a/Source/cmLocalUnixMakefileGenerator.cxx b/Source/cmLocalUnixMakefileGenerator.cxx index 936839b..80dd767 100644 --- a/Source/cmLocalUnixMakefileGenerator.cxx +++ b/Source/cmLocalUnixMakefileGenerator.cxx @@ -536,8 +536,9 @@ void cmLocalUnixMakefileGenerator::OutputTargetRules(std::ostream& fout) if(outExt.size() && !(*i)->GetPropertyAsBool("EXTERNAL_OBJECT") ) { fout << "\\\n"; - fout << this->ConvertToMakeTarget(this->ConvertToRelativeOutputPath((*i)->GetSourceName().c_str()).c_str()) - << outExt.c_str() << " "; + std::string ofname = (*i)->GetSourceName() + outExt; + ofname = this->CreateSafeUniqueObjectFileName(ofname.c_str()); + fout << this->ConvertToMakeTarget(this->ConvertToRelativeOutputPath(ofname.c_str()).c_str()); } } } @@ -569,8 +570,9 @@ void cmLocalUnixMakefileGenerator::OutputTargetRules(std::ostream& fout) std::string outExt(this->GetOutputExtension((*i)->GetSourceExtension().c_str())); if(outExt.size() && !(*i)->GetPropertyAsBool("EXTERNAL_OBJECT") ) { - fout << "\\\n\"" << this->ConvertToMakeTarget(ConvertToRelativeOutputPath((*i)->GetSourceName().c_str()).c_str()) - << outExt.c_str() << "\" "; + std::string ofname = (*i)->GetSourceName() + outExt; + ofname = this->CreateSafeUniqueObjectFileName(ofname.c_str()); + fout << "\\\n\"" << this->ConvertToMakeTarget(ConvertToRelativeOutputPath(ofname.c_str()).c_str()) << "\" "; } } } @@ -2691,6 +2693,7 @@ OutputBuildObjectFromSource(std::ostream& fout, std::string comment = "object file"; std::string objectFile = std::string(shortName) + this->GetOutputExtension(source.GetSourceExtension().c_str()); + objectFile = this->CreateSafeUniqueObjectFileName(objectFile.c_str()); objectFile = this->ConvertToRelativeOutputPath(objectFile.c_str()); cmSystemTools::FileFormat format = cmSystemTools::GetFileFormat(source.GetSourceExtension().c_str()); @@ -3058,6 +3061,45 @@ std::string cmLocalUnixMakefileGenerator::LowerCasePath(const char* path) #endif } +std::string& +cmLocalUnixMakefileGenerator::CreateSafeUniqueObjectFileName(const char* sin) +{ + std::map::iterator it = m_UniqueObjectNamesMap.find(sin); + if ( it == m_UniqueObjectNamesMap.end() ) + { + std::string ssin = sin; + bool done = false; + int cc = 0; + char rpstr[100]; + sprintf(rpstr, "_p_"); + cmSystemTools::ReplaceString(ssin, "+", rpstr); + std::string sssin = sin; + do + { + done = true; + for ( it = m_UniqueObjectNamesMap.begin(); + it != m_UniqueObjectNamesMap.end(); + ++ it ) + { + if ( it->second == ssin ) + { + done = false; + } + } + if ( done ) + { + break; + } + sssin = ssin; + cmSystemTools::ReplaceString(ssin, "_p_", rpstr); + sprintf(rpstr, "_p%d_", cc++); + } + while ( !done ); + m_UniqueObjectNamesMap[sin] = ssin; + } + return m_UniqueObjectNamesMap[sin]; +} + std::string cmLocalUnixMakefileGenerator::CreateMakeVariable(const char* sin, const char* s2in) { diff --git a/Source/cmLocalUnixMakefileGenerator.h b/Source/cmLocalUnixMakefileGenerator.h index 7a05d2e..756190d 100644 --- a/Source/cmLocalUnixMakefileGenerator.h +++ b/Source/cmLocalUnixMakefileGenerator.h @@ -232,12 +232,19 @@ protected: /** Output an echo command to the Makefile */ void OutputEcho(std::ostream& fout, const char *msg); + + /** + * Convert source file name to a safe object file name. Safe here means that + * it will not clash with compilers or linkers. + */ + std::string& CreateSafeUniqueObjectFileName(const char* sin); ///! final processing for a path to be put in a makefile protected: int m_MakefileVariableSize; std::map m_MakeVariableMap; std::map m_ShortMakeVariableMap; + std::map m_UniqueObjectNamesMap; bool m_IgnoreLibPrefix; std::string m_IncludeDirective; std::string m_MakeSilentFlag; -- cgit v0.12