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:
parent
c482dd8c97
commit
f447db7f10
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue