mirror of
https://github.com/Kitware/CMake.git
synced 2026-05-07 06:40:16 -05:00
Ninja: Skip cleandead and recompact if build.ninja is missing
In error cases the `build.ninja` file may not exist. Skip running ninja tools that require it so that we do not generate additional errors.
This commit is contained in:
@@ -553,18 +553,26 @@ void cmGlobalNinjaGenerator::Generate()
|
|||||||
bool const expectBuildManifest =
|
bool const expectBuildManifest =
|
||||||
!this->IsMultiConfig() && this->OutputPathPrefix.empty();
|
!this->IsMultiConfig() && this->OutputPathPrefix.empty();
|
||||||
|
|
||||||
|
// Skip some ninja tools if they need 'build.ninja' but it is missing.
|
||||||
|
bool const missingBuildManifest = expectBuildManifest &&
|
||||||
|
(this->NinjaSupportsCleanDeadTool ||
|
||||||
|
this->NinjaSupportsUnconditionalRecompactTool) &&
|
||||||
|
!cmSystemTools::FileExists("build.ninja");
|
||||||
|
|
||||||
// The `cleandead` tool needs to know about all outputs in the build we just
|
// The `cleandead` tool needs to know about all outputs in the build we just
|
||||||
// wrote out. Ninja-Multi doesn't have a single `build.ninja` we can use that
|
// wrote out. Ninja-Multi doesn't have a single `build.ninja` we can use that
|
||||||
// is the union of all generated configurations, so we can't run it reliably
|
// is the union of all generated configurations, so we can't run it reliably
|
||||||
// in that case.
|
// in that case.
|
||||||
if (this->NinjaSupportsCleanDeadTool && expectBuildManifest) {
|
if (this->NinjaSupportsCleanDeadTool && expectBuildManifest &&
|
||||||
|
!missingBuildManifest) {
|
||||||
run_ninja_tool({ "cleandead" });
|
run_ninja_tool({ "cleandead" });
|
||||||
}
|
}
|
||||||
// The `recompact` tool loads the manifest. As above, we don't have a single
|
// The `recompact` tool loads the manifest. As above, we don't have a single
|
||||||
// `build.ninja` to load for this in Ninja-Multi. This may be relaxed in the
|
// `build.ninja` to load for this in Ninja-Multi. This may be relaxed in the
|
||||||
// future pending further investigation into how Ninja works upstream
|
// future pending further investigation into how Ninja works upstream
|
||||||
// (ninja#1721).
|
// (ninja#1721).
|
||||||
if (this->NinjaSupportsUnconditionalRecompactTool && expectBuildManifest) {
|
if (this->NinjaSupportsUnconditionalRecompactTool && expectBuildManifest &&
|
||||||
|
!missingBuildManifest) {
|
||||||
run_ninja_tool({ "recompact" });
|
run_ninja_tool({ "recompact" });
|
||||||
}
|
}
|
||||||
if (this->NinjaSupportsRestatTool && this->OutputPathPrefix.empty()) {
|
if (this->NinjaSupportsRestatTool && this->OutputPathPrefix.empty()) {
|
||||||
|
|||||||
Reference in New Issue
Block a user