diff options
author | (quasar) nebula <qznebula@protonmail.com> | 2025-01-21 07:32:44 -0400 |
---|---|---|
committer | (quasar) nebula <qznebula@protonmail.com> | 2025-01-21 07:32:44 -0400 |
commit | 2f1b3e6dac14e26af7f2f184198d497990aef7a4 (patch) | |
tree | e00f0ecf528369f93ad408f75be94b58d28b14e0 /src | |
parent | 35b3b4f4876804fed9542d8d04e93425a96e1fa1 (diff) |
upd8: write preload file sizes cache
This isn't viable yet because it includes full on-device path names - not good for sharing between devices (or privacy!). But the gist of writing and integration into the queue is here.
Diffstat (limited to 'src')
-rw-r--r-- | src/file-size-preloader.js | 23 | ||||
-rwxr-xr-x | src/upd8.js | 32 | ||||
-rw-r--r-- | src/util/cli.js | 2 |
3 files changed, 57 insertions, 0 deletions
diff --git a/src/file-size-preloader.js b/src/file-size-preloader.js index 4eadde7b..a5db1cb0 100644 --- a/src/file-size-preloader.js +++ b/src/file-size-preloader.js @@ -20,6 +20,7 @@ import {stat} from 'node:fs/promises'; import {logWarn} from '#cli'; +import {transposeArrays} from '#sugar'; export default class FileSizePreloader { #paths = []; @@ -101,4 +102,26 @@ export default class FileSizePreloader { if (index > this.#loadedPathIndex) return null; return this.#sizes[index]; } + + saveAsCache() { + const entries = + transposeArrays([ + this.#paths.slice(0, this.#loadedPathIndex), + this.#sizes.slice(0, this.#loadedPathIndex), + ]); + + return Object.fromEntries(entries); + } + + loadFromCache(cache) { + const entries = + Object.entries(cache) + .filter(([p]) => !this.#paths.includes(p)); + + const [newPaths, newSizes] = transposeArrays(entries); + + this.#paths.splice(this.#loadedPathIndex + 1, 0, ...newPaths); + this.#sizes.splice(this.#loadedPathIndex + 1, 0, ...newSizes); + this.#loadedPathIndex += entries.length; + } } diff --git a/src/upd8.js b/src/upd8.js index 306715dd..b9e71784 100755 --- a/src/upd8.js +++ b/src/upd8.js @@ -2614,6 +2614,38 @@ async function main() { memory: process.memoryUsage(), }); } + + // TODO: kinda jank that this is out of band of any particular step, + // even though it's operationally a follow-up to preloadFileSizes + + let oopsCache = false; + saveFileSizeCache: { + let cache; + try { + cache = fileSizePreloader.saveAsCache(); + } catch (error) { + console.error(error); + logWarn`Couldn't compute file size preloader's cache.`; + oopsCache = true; + break saveFileSizeCache; + } + + const cacheFile = path.join(mediaCachePath, 'file-size-cache.json'); + + try { + await writeFile(cacheFile, stringifyCache(cache)); + } catch (error) { + console.error(error); + logWarn`Couldn't save preloaded file sizes to a cache file:`; + logWarn`${cacheFile}`; + oopsCache = true; + } + } + + if (oopsCache) { + logWarn`This won't affect the build, but this build should not be used`; + logWarn`as a model for another build accessing its media files online.`; + } } if (stepStatusSummary.buildSearchIndex.status === STATUS_NOT_STARTED) { diff --git a/src/util/cli.js b/src/util/cli.js index be59b35e..a40a911f 100644 --- a/src/util/cli.js +++ b/src/util/cli.js @@ -5,6 +5,8 @@ const {process} = globalThis; +import {sortByName} from './sort.js'; + export const ENABLE_COLOR = process && ((process.env.CLICOLOR_FORCE && process.env.CLICOLOR_FORCE === '1') ?? |