summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2020-01-27 20:31:53 (GMT)
committerBrad King <brad.king@kitware.com>2020-01-27 20:39:04 (GMT)
commitccaa0bccc42a31f7515c6f85a0601ac0ad006e96 (patch)
tree308ecc3051bab349341ffcaa4ee4df606bcba7b9
parent657820a00b83cb28e018a94af2a8bf7475827c8b (diff)
downloadCMake-ccaa0bccc42a31f7515c6f85a0601ac0ad006e96.zip
CMake-ccaa0bccc42a31f7515c6f85a0601ac0ad006e96.tar.gz
CMake-ccaa0bccc42a31f7515c6f85a0601ac0ad006e96.tar.bz2
Ninja: Do not clean metadata when re-generating inside a running build
When `ninja` re-runs CMake to re-generate the build system, do not try to use the ninja tools to update metadata on Windows. The outer ninja process is already holding the files open. Issue: #20274
-rw-r--r--Source/cmGlobalNinjaGenerator.cxx10
1 files changed, 9 insertions, 1 deletions
diff --git a/Source/cmGlobalNinjaGenerator.cxx b/Source/cmGlobalNinjaGenerator.cxx
index f92ffd3..d093c43 100644
--- a/Source/cmGlobalNinjaGenerator.cxx
+++ b/Source/cmGlobalNinjaGenerator.cxx
@@ -528,7 +528,15 @@ void cmGlobalNinjaGenerator::Generate()
this->CloseRulesFileStream();
this->CloseBuildFileStreams();
- this->CleanMetaData();
+#ifdef _WIN32
+ // The ninja tools will not be able to update metadata on Windows
+ // when we are re-generating inside an existing 'ninja' invocation
+ // because the outer tool has the files open for write.
+ if (!this->GetCMakeInstance()->GetRegenerateDuringBuild())
+#endif
+ {
+ this->CleanMetaData();
+ }
}
void cmGlobalNinjaGenerator::CleanMetaData()