From cf43d6a34bd32d9de4f893dddaabcdc1d774f1a4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Henrik=20B=C3=B6ving?= Date: Fri, 5 Jul 2024 15:18:41 +0200 Subject: [PATCH] perf: reduce size of .lake/build/doc --- DocGen4/Output.lean | 6 ++++-- DocGen4/Output/Base.lean | 6 ++++-- lakefile.lean | 4 ++-- 3 files changed, 10 insertions(+), 6 deletions(-) diff --git a/DocGen4/Output.lean b/DocGen4/Output.lean index 52c605b2..623ad6a0 100644 --- a/DocGen4/Output.lean +++ b/DocGen4/Output.lean @@ -117,8 +117,10 @@ def htmlOutputIndex (baseConfig : SiteBaseContext) : IO Unit := do let finalJson := toJson index let finalHeaderJson := toJson headerIndex -- The root JSON for find - FS.writeFile (declarationsBasePath / "declaration-data.bmp") finalJson.compress - FS.writeFile (declarationsBasePath / "header-data.bmp") finalHeaderJson.compress + let declarationDir := lakeBuildDir / "declarations" + FS.createDirAll declarationDir + FS.writeFile (declarationDir / "declaration-data.bmp") finalJson.compress + FS.writeFile (declarationDir / "header-data.bmp") finalHeaderJson.compress /-- The main entrypoint for outputting the documentation HTML based on an diff --git a/DocGen4/Output/Base.lean b/DocGen4/Output/Base.lean index 1ea53c9a..9f2e01c0 100644 --- a/DocGen4/Output/Base.lean +++ b/DocGen4/Output/Base.lean @@ -11,9 +11,11 @@ namespace DocGen4.Output open scoped DocGen4.Jsx open Lean System Widget Elab Process -def basePath := FilePath.mk "." / ".lake" / "build" / "doc" + +def lakeBuildDir := FilePath.mk "." / ".lake" / "build" +def basePath := lakeBuildDir / "doc" def srcBasePath := basePath / "src" -def declarationsBasePath := basePath / "declarations" +def declarationsBasePath := lakeBuildDir / "doc-data" /-- The context used in the `BaseHtmlM` monad for HTML templating. diff --git a/lakefile.lean b/lakefile.lean index 5b7c669b..bcb4b26d 100644 --- a/lakefile.lean +++ b/lakefile.lean @@ -144,8 +144,8 @@ module_facet docs (mod) : FilePath := do -- TODO: technically speaking this target does not show all file dependencies target coreDocs : FilePath := do let exeJob ← «doc-gen4».fetch - let basePath := (←getWorkspace).root.buildDir / "doc" - let dataFile := basePath / "declarations" / "declaration-data-Lean.bmp" + let dataPath := (← getWorkspace).root.buildDir / "doc-data" + let dataFile := dataPath / "declaration-data-Lean.bmp" exeJob.bindSync fun exeFile exeTrace => do let trace ← buildFileUnlessUpToDate dataFile exeTrace do proc {