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:
Ben Boeckel 2014-02-12 00:00:29 -05:00 committed by Brad King
parent 5104f55d3f
commit 26762e1681
2 changed files with 47 additions and 39 deletions

View File

@ -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.

View File

@ -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;
}; };