Ninja: Cache target-level flags
Instead of figuring out target flags per-source file, cache the flags that are being used. This results in a *much* faster generate time for Ninja.
This commit is contained in:
parent
5104f55d3f
commit
26762e1681
|
@ -129,15 +129,6 @@ std::string
|
||||||
cmNinjaTargetGenerator::ComputeFlagsForObject(cmSourceFile *source,
|
cmNinjaTargetGenerator::ComputeFlagsForObject(cmSourceFile *source,
|
||||||
const std::string& language)
|
const std::string& language)
|
||||||
{
|
{
|
||||||
std::string flags;
|
|
||||||
|
|
||||||
this->AddFeatureFlags(flags, language.c_str());
|
|
||||||
|
|
||||||
this->GetLocalGenerator()->AddArchitectureFlags(flags,
|
|
||||||
this->GeneratorTarget,
|
|
||||||
language.c_str(),
|
|
||||||
this->GetConfigName());
|
|
||||||
|
|
||||||
// TODO: Fortran support.
|
// TODO: Fortran support.
|
||||||
// // Fortran-specific flags computed for this target.
|
// // Fortran-specific flags computed for this target.
|
||||||
// if(*l == "Fortran")
|
// if(*l == "Fortran")
|
||||||
|
@ -145,42 +136,56 @@ cmNinjaTargetGenerator::ComputeFlagsForObject(cmSourceFile *source,
|
||||||
// this->AddFortranFlags(flags);
|
// this->AddFortranFlags(flags);
|
||||||
// }
|
// }
|
||||||
|
|
||||||
// Add shared-library flags if needed.
|
bool hasLangCached = this->LanguageFlags.count(language) != 0;
|
||||||
this->LocalGenerator->AddCMP0018Flags(flags, this->Target,
|
std::string& languageFlags = this->LanguageFlags[language];
|
||||||
language.c_str(),
|
if(!hasLangCached)
|
||||||
this->GetConfigName());
|
{
|
||||||
|
this->AddFeatureFlags(languageFlags, language.c_str());
|
||||||
|
|
||||||
this->LocalGenerator->AddVisibilityPresetFlags(flags, this->Target,
|
this->GetLocalGenerator()->AddArchitectureFlags(languageFlags,
|
||||||
language.c_str());
|
this->GeneratorTarget,
|
||||||
|
language.c_str(),
|
||||||
|
this->GetConfigName());
|
||||||
|
|
||||||
// Add include directory flags.
|
// Add shared-library flags if needed.
|
||||||
const char *config = this->Makefile->GetDefinition("CMAKE_BUILD_TYPE");
|
this->LocalGenerator->AddCMP0018Flags(languageFlags, this->Target,
|
||||||
{
|
language,
|
||||||
std::vector<std::string> includes;
|
this->GetConfigName());
|
||||||
this->LocalGenerator->GetIncludeDirectories(includes,
|
|
||||||
this->GeneratorTarget,
|
|
||||||
language.c_str(), config);
|
|
||||||
std::string includeFlags =
|
|
||||||
this->LocalGenerator->GetIncludeFlags(includes, this->GeneratorTarget,
|
|
||||||
language.c_str(),
|
|
||||||
language == "RC" ? true : false); // full include paths for RC
|
|
||||||
// needed by cmcldeps
|
|
||||||
if(cmGlobalNinjaGenerator::IsMinGW())
|
|
||||||
cmSystemTools::ReplaceString(includeFlags, "\\", "/");
|
|
||||||
|
|
||||||
this->LocalGenerator->AppendFlags(flags, includeFlags.c_str());
|
this->LocalGenerator->AddVisibilityPresetFlags(languageFlags, this->Target,
|
||||||
}
|
language.c_str());
|
||||||
|
|
||||||
// Append old-style preprocessor definition flags.
|
std::vector<std::string> includes;
|
||||||
this->LocalGenerator->AppendFlags(flags, this->Makefile->GetDefineFlags());
|
this->LocalGenerator->GetIncludeDirectories(includes,
|
||||||
|
this->GeneratorTarget,
|
||||||
|
language.c_str(),
|
||||||
|
this->GetConfigName());
|
||||||
|
// Add include directory flags.
|
||||||
|
std::string includeFlags =
|
||||||
|
this->LocalGenerator->GetIncludeFlags(includes, this->GeneratorTarget,
|
||||||
|
language.c_str(),
|
||||||
|
language == "RC" ? true : false); // full include paths for RC
|
||||||
|
// needed by cmcldeps
|
||||||
|
if(cmGlobalNinjaGenerator::IsMinGW())
|
||||||
|
cmSystemTools::ReplaceString(includeFlags, "\\", "/");
|
||||||
|
|
||||||
// Add target-specific flags.
|
this->LocalGenerator->AppendFlags(languageFlags, includeFlags.c_str());
|
||||||
this->LocalGenerator->AddCompileOptions(flags, this->Target,
|
|
||||||
language.c_str(), config);
|
|
||||||
|
|
||||||
// Add source file specific flags.
|
// Append old-style preprocessor definition flags.
|
||||||
this->LocalGenerator->AppendFlags(flags,
|
this->LocalGenerator->AppendFlags(languageFlags,
|
||||||
source->GetProperty("COMPILE_FLAGS"));
|
this->Makefile->GetDefineFlags());
|
||||||
|
|
||||||
|
// Add target-specific flags.
|
||||||
|
this->LocalGenerator->AddCompileOptions(languageFlags, this->Target,
|
||||||
|
language.c_str(),
|
||||||
|
this->GetConfigName());
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string flags = languageFlags;
|
||||||
|
|
||||||
|
// Add source file specific flags.
|
||||||
|
this->LocalGenerator->AppendFlags(flags,
|
||||||
|
source->GetProperty("COMPILE_FLAGS"));
|
||||||
|
|
||||||
// TODO: Handle Apple frameworks.
|
// TODO: Handle Apple frameworks.
|
||||||
|
|
||||||
|
|
|
@ -154,6 +154,9 @@ private:
|
||||||
/// List of object files for this target.
|
/// List of object files for this target.
|
||||||
cmNinjaDeps Objects;
|
cmNinjaDeps Objects;
|
||||||
|
|
||||||
|
typedef std::map<std::string, std::string> LanguageFlagMap;
|
||||||
|
LanguageFlagMap LanguageFlags;
|
||||||
|
|
||||||
// The windows module definition source file (.def), if any.
|
// The windows module definition source file (.def), if any.
|
||||||
std::string ModuleDefinitionFile;
|
std::string ModuleDefinitionFile;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue