VS: Fix CMAKE_SUPPRESS_REGENERATION bad ZERO_CHECK dependency (#14378)
When CMAKE_SUPPRESS_REGENERATION tells us not to create the ZERO_CHECK target we should not add dependencies on it from other targets either. Reviewed-by: Mateusz Loskot <mateusz@loskot.net>
This commit is contained in:
parent
b15ad0d1de
commit
e478f03469
|
@ -202,7 +202,7 @@ std::string cmGlobalVisualStudio8Generator::GetUserMacrosRegKeyBase()
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
void cmGlobalVisualStudio8Generator::AddCheckTarget()
|
bool cmGlobalVisualStudio8Generator::AddCheckTarget()
|
||||||
{
|
{
|
||||||
// Add a special target on which all other targets depend that
|
// Add a special target on which all other targets depend that
|
||||||
// checks the build system and optionally re-runs CMake.
|
// checks the build system and optionally re-runs CMake.
|
||||||
|
@ -216,7 +216,7 @@ void cmGlobalVisualStudio8Generator::AddCheckTarget()
|
||||||
// Skip the target if no regeneration is to be done.
|
// Skip the target if no regeneration is to be done.
|
||||||
if(mf->IsOn("CMAKE_SUPPRESS_REGENERATION"))
|
if(mf->IsOn("CMAKE_SUPPRESS_REGENERATION"))
|
||||||
{
|
{
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string cmake_command = mf->GetRequiredDefinition("CMAKE_COMMAND");
|
std::string cmake_command = mf->GetRequiredDefinition("CMAKE_COMMAND");
|
||||||
|
@ -315,21 +315,24 @@ void cmGlobalVisualStudio8Generator::AddCheckTarget()
|
||||||
cmSystemTools::Error("Error adding rule for ", stamps[0].c_str());
|
cmSystemTools::Error("Error adding rule for ", stamps[0].c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
void cmGlobalVisualStudio8Generator::Generate()
|
void cmGlobalVisualStudio8Generator::Generate()
|
||||||
{
|
{
|
||||||
this->AddCheckTarget();
|
if(this->AddCheckTarget())
|
||||||
|
|
||||||
// All targets depend on the build-system check target.
|
|
||||||
for(std::map<cmStdString,cmTarget *>::const_iterator
|
|
||||||
ti = this->TotalTargets.begin();
|
|
||||||
ti != this->TotalTargets.end(); ++ti)
|
|
||||||
{
|
{
|
||||||
if(ti->first != CMAKE_CHECK_BUILD_SYSTEM_TARGET)
|
// All targets depend on the build-system check target.
|
||||||
|
for(std::map<cmStdString,cmTarget *>::const_iterator
|
||||||
|
ti = this->TotalTargets.begin();
|
||||||
|
ti != this->TotalTargets.end(); ++ti)
|
||||||
{
|
{
|
||||||
ti->second->AddUtility(CMAKE_CHECK_BUILD_SYSTEM_TARGET);
|
if(ti->first != CMAKE_CHECK_BUILD_SYSTEM_TARGET)
|
||||||
|
{
|
||||||
|
ti->second->AddUtility(CMAKE_CHECK_BUILD_SYSTEM_TARGET);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -71,7 +71,7 @@ protected:
|
||||||
|
|
||||||
virtual bool VSLinksDependencies() const { return false; }
|
virtual bool VSLinksDependencies() const { return false; }
|
||||||
|
|
||||||
void AddCheckTarget();
|
bool AddCheckTarget();
|
||||||
|
|
||||||
static cmIDEFlagTable const* GetExtraFlagTableVS8();
|
static cmIDEFlagTable const* GetExtraFlagTableVS8();
|
||||||
virtual void WriteSLNHeader(std::ostream& fout);
|
virtual void WriteSLNHeader(std::ostream& fout);
|
||||||
|
|
Loading…
Reference in New Issue