Merge topic 'fix-remove-forbidden-flags'

3a8f34b Makefile: Remove "forbidden" flags only as a whole
This commit is contained in:
Brad King 2013-11-19 09:46:59 -05:00 committed by CMake Topic Stage
commit e752a02368
1 changed files with 34 additions and 1 deletions

View File

@ -27,6 +27,7 @@
#include "cmMakefileLibraryTargetGenerator.h"
#include "cmMakefileUtilityTargetGenerator.h"
#include <ctype.h>
cmMakefileTargetGenerator::cmMakefileTargetGenerator(cmTarget* target)
: OSXBundleGenerator(0)
@ -1694,10 +1695,42 @@ void cmMakefileTargetGenerator::RemoveForbiddenFlags(const char* flagVar,
this->Makefile->GetSafeDefinition(removeFlags.c_str());
std::vector<std::string> removeList;
cmSystemTools::ExpandListArgument(removeflags, removeList);
for(std::vector<std::string>::iterator i = removeList.begin();
i != removeList.end(); ++i)
{
cmSystemTools::ReplaceString(linkFlags, i->c_str(), "");
std::string tmp;
std::string::size_type lastPosition = 0;
for(;;)
{
std::string::size_type position = linkFlags.find(*i, lastPosition);
if(position == std::string::npos)
{
tmp += linkFlags.substr(lastPosition);
break;
}
else
{
std::string::size_type prefixLength = position - lastPosition;
tmp += linkFlags.substr(lastPosition, prefixLength);
lastPosition = position + i->length();
bool validFlagStart = position == 0 ||
isspace(linkFlags[position - 1]);
bool validFlagEnd = lastPosition == linkFlags.size() ||
isspace(linkFlags[lastPosition]);
if(!validFlagStart || !validFlagEnd)
{
tmp += *i;
}
}
}
linkFlags = tmp;
}
}