Merge topic 'ninja-msvc-only-C-and-CXX'
8a93d3ea
Ninja: Use "deps = msvc" only for C and CXX (#15253)
This commit is contained in:
commit
85fe9400cd
|
@ -200,21 +200,21 @@ cmNinjaTargetGenerator::ComputeFlagsForObject(cmSourceFile const* source,
|
|||
return flags;
|
||||
}
|
||||
|
||||
|
||||
bool cmNinjaTargetGenerator::needsDepFile(const std::string& lang)
|
||||
bool cmNinjaTargetGenerator::NeedDepTypeMSVC(const std::string& lang) const
|
||||
{
|
||||
cmMakefile* mf = this->GetMakefile();
|
||||
|
||||
const bool usingMSVC = std::string("MSVC") ==
|
||||
(mf->GetDefinition("CMAKE_C_COMPILER_ID") ?
|
||||
mf->GetSafeDefinition("CMAKE_C_COMPILER_ID") :
|
||||
mf->GetSafeDefinition("CMAKE_CXX_COMPILER_ID"));
|
||||
|
||||
return !usingMSVC || lang == "RC";
|
||||
if (lang == "C" || lang == "CXX")
|
||||
{
|
||||
cmMakefile* mf = this->GetMakefile();
|
||||
return (
|
||||
strcmp(mf->GetSafeDefinition("CMAKE_C_COMPILER_ID"), "MSVC") == 0 ||
|
||||
strcmp(mf->GetSafeDefinition("CMAKE_CXX_COMPILER_ID"), "MSVC") == 0 ||
|
||||
strcmp(mf->GetSafeDefinition("CMAKE_C_SIMULATE_ID"), "MSVC") == 0 ||
|
||||
strcmp(mf->GetSafeDefinition("CMAKE_CXX_SIMULATE_ID"), "MSVC") == 0
|
||||
);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
|
||||
// TODO: Refactor with
|
||||
// void cmMakefileTargetGenerator::WriteTargetLanguageFlags().
|
||||
std::string
|
||||
|
@ -391,22 +391,22 @@ cmNinjaTargetGenerator
|
|||
|
||||
cmMakefile* mf = this->GetMakefile();
|
||||
|
||||
const std::string cId = mf->GetDefinition("CMAKE_C_COMPILER_ID")
|
||||
? mf->GetSafeDefinition("CMAKE_C_COMPILER_ID")
|
||||
: mf->GetSafeDefinition("CMAKE_CXX_COMPILER_ID");
|
||||
const std::string sId = mf->GetDefinition("CMAKE_C_SIMULATE_ID")
|
||||
? mf->GetSafeDefinition("CMAKE_C_SIMULATE_ID")
|
||||
: mf->GetSafeDefinition("CMAKE_CXX_SIMULATE_ID");
|
||||
const bool usingMSVC = (cId == "MSVC" || sId == "MSVC");
|
||||
|
||||
// Tell ninja dependency format so all deps can be loaded into a database
|
||||
std::string deptype;
|
||||
std::string depfile;
|
||||
std::string cldeps;
|
||||
std::string flags = "$FLAGS";
|
||||
if (usingMSVC)
|
||||
if (this->NeedDepTypeMSVC(lang))
|
||||
{
|
||||
if (!mf->GetIsSourceFileTryCompile() && lang == "RC")
|
||||
deptype = "msvc";
|
||||
depfile = "";
|
||||
flags += " /showIncludes";
|
||||
}
|
||||
else if (lang == "RC" && this->NeedDepTypeMSVC("C"))
|
||||
{
|
||||
// For the MS resource compiler we need cmcldeps, but skip dependencies
|
||||
// for source-file try_compile cases because they are always fresh.
|
||||
if (!mf->GetIsSourceFileTryCompile())
|
||||
{
|
||||
deptype = "gcc";
|
||||
depfile = "$DEP_FILE";
|
||||
|
@ -419,12 +419,6 @@ cmNinjaTargetGenerator
|
|||
cldeps += mf->GetSafeDefinition("CMAKE_CL_SHOWINCLUDES_PREFIX");
|
||||
cldeps += "\" \"" + cl + "\" ";
|
||||
}
|
||||
else
|
||||
{
|
||||
deptype = "msvc";
|
||||
depfile = "";
|
||||
flags += " /showIncludes";
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -636,7 +630,7 @@ cmNinjaTargetGenerator
|
|||
cmNinjaVars vars;
|
||||
vars["FLAGS"] = this->ComputeFlagsForObject(source, language);
|
||||
vars["DEFINES"] = this->ComputeDefines(source, language);
|
||||
if (needsDepFile(language)) {
|
||||
if (!this->NeedDepTypeMSVC(language)) {
|
||||
vars["DEP_FILE"] =
|
||||
cmGlobalNinjaGenerator::EncodeDepfileSpace(objectFileName + ".d");
|
||||
}
|
||||
|
|
|
@ -42,7 +42,7 @@ public:
|
|||
|
||||
std::string GetTargetName() const;
|
||||
|
||||
bool needsDepFile(const std::string& lang);
|
||||
bool NeedDepTypeMSVC(const std::string& lang) const;
|
||||
|
||||
protected:
|
||||
|
||||
|
|
Loading…
Reference in New Issue