Merge topic 'ninja-rc-compile-flag'

a1c9c13 Ninja: filter target specific compile flags with language specific regex
This commit is contained in:
Brad King 2012-09-19 13:57:47 -04:00 committed by CMake Topic Stage
commit 65af5e90b9
1 changed files with 35 additions and 5 deletions

View File

@ -167,11 +167,41 @@ cmNinjaTargetGenerator::ComputeFlagsForObject(cmSourceFile *source,
// Append old-style preprocessor definition flags. // Append old-style preprocessor definition flags.
this->LocalGenerator->AppendFlags(flags, this->Makefile->GetDefineFlags()); this->LocalGenerator->AppendFlags(flags, this->Makefile->GetDefineFlags());
// Add target-specific and source-specific flags. // Add target-specific flags.
this->LocalGenerator->AppendFlags(flags, if(this->Target->GetProperty("COMPILE_FLAGS"))
this->Target->GetProperty("COMPILE_FLAGS")); {
this->LocalGenerator->AppendFlags(flags, std::string langIncludeExpr = "CMAKE_";
source->GetProperty("COMPILE_FLAGS")); langIncludeExpr += language;
langIncludeExpr += "_FLAG_REGEX";
const char* regex = this->Makefile->
GetDefinition(langIncludeExpr.c_str());
if(regex)
{
cmsys::RegularExpression r(regex);
std::vector<std::string> args;
cmSystemTools::ParseWindowsCommandLine(
this->Target->GetProperty("COMPILE_FLAGS"),
args);
for(std::vector<std::string>::iterator i = args.begin();
i != args.end(); ++i)
{
if(r.find(i->c_str()))
{
this->LocalGenerator->AppendFlags
(flags, i->c_str());
}
}
}
else
{
this->LocalGenerator->AppendFlags
(flags, this->Target->GetProperty("COMPILE_FLAGS"));
}
}
// Add source file specific flags.
this->LocalGenerator->AppendFlags(flags,
source->GetProperty("COMPILE_FLAGS"));
// TODO: Handle Apple frameworks. // TODO: Handle Apple frameworks.