XCode generator won't infinitely parse compiler flags (bug #13354).

When parsing the compiler flag list we reduce the search space on
each iteration to be the subset of the string we hadn't searched
before.
This commit is contained in:
Robert Maynard 2013-01-18 11:29:22 -05:00
parent c482dd8c97
commit f447db7f10
1 changed files with 10 additions and 5 deletions

View File

@ -1367,16 +1367,18 @@ void cmGlobalXCodeGenerator::CreateCustomCommands(cmXCodeObject* buildPhases,
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
// This function removes each occurence of the flag and returns the last one // This function removes each occurrence of the flag and returns the last one
// (i.e., the dominant flag in GCC) // (i.e., the dominant flag in GCC)
std::string cmGlobalXCodeGenerator::ExtractFlag(const char* flag, std::string cmGlobalXCodeGenerator::ExtractFlag(const char* flag,
std::string& flags) std::string& flags)
{ {
std::string retFlag; std::string retFlag;
std::string::size_type pos = flags.rfind(flag); std::string::size_type lastOccurancePos = flags.rfind(flag);
bool saved = false; bool saved = false;
while(pos != flags.npos) while(lastOccurancePos != flags.npos)
{ {
//increment pos, we use lastOccurancePos to reduce search space on next inc
std::string::size_type pos = lastOccurancePos;
if(pos == 0 || flags[pos-1]==' ') if(pos == 0 || flags[pos-1]==' ')
{ {
while(pos < flags.size() && flags[pos] != ' ') while(pos < flags.size() && flags[pos] != ' ')
@ -1388,9 +1390,12 @@ std::string cmGlobalXCodeGenerator::ExtractFlag(const char* flag,
flags[pos] = ' '; flags[pos] = ' ';
pos++; pos++;
} }
}
saved = true; saved = true;
pos = flags.rfind(flag); }
//decrement lastOccurancePos while making sure we don't loop around
//and become a very large positive number since size_type is unsigned
lastOccurancePos = lastOccurancePos == 0 ? 0 : lastOccurancePos-1;
lastOccurancePos = flags.rfind(flag,lastOccurancePos);
} }
return retFlag; return retFlag;
} }