« get me outta code hell

upd8: --show-step-memory + related cleanup - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src/upd8.js
diff options
context:
space:
mode:
author(quasar) nebula <qznebula@protonmail.com>2025-01-12 20:38:40 -0400
committer(quasar) nebula <qznebula@protonmail.com>2025-01-13 16:43:08 -0400
commitdffcfd79cb7256e1f75a753dc5bafcb49e50793e (patch)
tree2bebbe501dcf338fb986f4ddb17ceff8cbaa1def /src/upd8.js
parent535e941125bc5885f7d96e4654094b5aad11a21b (diff)
upd8: --show-step-memory + related cleanup preview
Diffstat (limited to 'src/upd8.js')
-rwxr-xr-xsrc/upd8.js21
1 files changed, 17 insertions, 4 deletions
diff --git a/src/upd8.js b/src/upd8.js
index 9a466ab9..6097f21f 100755
--- a/src/upd8.js
+++ b/src/upd8.js
@@ -124,6 +124,7 @@ const defaultStepStatus = {status: STATUS_NOT_STARTED, annotation: null};
 // This will be initialized and mutated over the course of main().
 let stepStatusSummary;
 let showStepStatusSummary = false;
+let showStepMemoryInSummary = false;
 
 async function main() {
   Error.stackTraceLimit = Infinity;
@@ -418,6 +419,11 @@ async function main() {
       type: 'flag',
     },
 
+    'show-step-memory': {
+      help: `Include total process memory usage traces at the time each top-level build step ends. Use with --show-step-summary. This is mostly useful for programmer debugging!`,
+      type: 'flag',
+    },
+
     'queue-size': {
       help: `Process more or fewer disk files at once to optimize performance or avoid I/O errors, unlimited if set to 0 (between 500 and 700 is usually a safe range for building HSMusic on Windows machines)\nDefaults to ${defaultQueueSize}`,
       type: 'value',
@@ -478,6 +484,7 @@ async function main() {
   });
 
   showStepStatusSummary = cliOptions['show-step-summary'] ?? false;
+  showStepMemoryInSummary = cliOptions['show-step-memory'] ?? false;
 
   if (cliOptions['help']) {
     console.log(
@@ -2608,14 +2615,16 @@ if (true || isMain(import.meta.url) || path.basename(process.argv[1]) === 'hsmus
       const stepMemories =
         stepDetails.map(({memory}) =>
           (memory
-            ? Math.round(memory["heapUsed"] / 1024 / 1024) + "MB"
-            : "-"));
+            ? Math.round(memory["heapUsed"] / 1024 / 1024) + 'MB'
+            : '-'));
 
-      const longestMemoryLength = 7;
+      const longestMemoryLength =
+        Math.max(...stepMemories.map(memory => memory.length));
 
       for (let index = 0; index < stepDetails.length; index++) {
         const {name, status, annotation} = stepDetails[index];
         const duration = stepDurations[index];
+        const memory = stepMemories[index];
 
         let message =
           (stepsNotClean[index]
@@ -2623,7 +2632,11 @@ if (true || isMain(import.meta.url) || path.basename(process.argv[1]) === 'hsmus
             : ` - `);
 
         message += `(${duration} `.padStart(longestDurationLength + 2, ' ');
-        message += ` ${stepMemories[index]})`.padStart(longestMemoryLength + 2, ' ');
+
+        if (showStepMemoryInSummary) {
+          message += ` ${memory})`.padStart(longestMemoryLength + 2, ' ');
+        }
+
         message += ` `;
         message += `${name}: `.padEnd(longestNameLength + 4, '.');
         message += ` `;