@decaf-ts/utils 0.3.13 → 0.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -37,6 +37,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
37
37
  };
38
38
  Object.defineProperty(exports, "__esModule", { value: true });
39
39
  exports.BuildScripts = void 0;
40
+ exports.parseList = parseList;
41
+ exports.packageToGlobal = packageToGlobal;
42
+ exports.getPackageDependencies = getPackageDependencies;
40
43
  const command_1 = require("./../command.cjs");
41
44
  const constants_1 = require("./../constants.cjs");
42
45
  const utils_1 = require("./../../utils/index.cjs");
@@ -47,9 +50,64 @@ const plugin_typescript_1 = __importDefault(require("@rollup/plugin-typescript")
47
50
  const plugin_commonjs_1 = __importDefault(require("@rollup/plugin-commonjs"));
48
51
  const plugin_node_resolve_1 = require("@rollup/plugin-node-resolve");
49
52
  const plugin_json_1 = __importDefault(require("@rollup/plugin-json"));
53
+ const module_1 = require("module");
54
+ const logging_1 = require("@decaf-ts/logging");
50
55
  const ts = __importStar(require("typescript"));
51
56
  const typescript_1 = require("typescript");
52
- const VERSION_STRING = "0.3.13";
57
+ function parseList(input) {
58
+ if (!input)
59
+ return [];
60
+ if (Array.isArray(input))
61
+ return input.map((i) => `${i}`.trim()).filter(Boolean);
62
+ return `${input}`
63
+ .split(",")
64
+ .map((p) => p.trim())
65
+ .filter(Boolean);
66
+ }
67
+ function packageToGlobal(name) {
68
+ // Remove scope and split by non-alphanumeric chars, then camelCase
69
+ const withoutScope = name.replace(/^@/, "");
70
+ const parts = withoutScope.split(/[/\-_.]+/).filter(Boolean);
71
+ return parts
72
+ .map((p, i) => i === 0
73
+ ? p.replace(/[^a-zA-Z0-9]/g, "")
74
+ : `${p.charAt(0).toUpperCase()}${p.slice(1)}`)
75
+ .join("");
76
+ }
77
+ function getPackageDependencies() {
78
+ // Try the current working directory first
79
+ let pkg;
80
+ try {
81
+ pkg = (0, utils_1.getPackage)(process.cwd());
82
+ }
83
+ catch {
84
+ pkg = undefined;
85
+ }
86
+ // If no dependencies found in cwd, try the package next to this source file (fallback for tests)
87
+ try {
88
+ const hasDeps = pkg &&
89
+ (Object.keys(pkg.dependencies || {}).length > 0 ||
90
+ Object.keys(pkg.devDependencies || {}).length > 0 ||
91
+ Object.keys(pkg.peerDependencies || {}).length > 0);
92
+ if (!hasDeps) {
93
+ const fallbackDir = path_1.default.resolve(__dirname, "../../..");
94
+ try {
95
+ pkg = (0, utils_1.getPackage)(fallbackDir);
96
+ }
97
+ catch {
98
+ // ignore and keep pkg as-is
99
+ }
100
+ }
101
+ }
102
+ catch {
103
+ // ignore
104
+ }
105
+ const deps = Object.keys((pkg && pkg.dependencies) || {});
106
+ const peer = Object.keys((pkg && pkg.peerDependencies) || {});
107
+ const dev = Object.keys((pkg && pkg.devDependencies) || {});
108
+ return Array.from(new Set([...deps, ...peer, ...dev]));
109
+ }
110
+ const VERSION_STRING = "0.4.1";
53
111
  const PACKAGE_STRING = "@decaf-ts/utils";
54
112
  var Modes;
55
113
  (function (Modes) {
@@ -62,11 +120,6 @@ var BuildMode;
62
120
  BuildMode["BUNDLE"] = "bundle";
63
121
  BuildMode["ALL"] = "all";
64
122
  })(BuildMode || (BuildMode = {}));
65
- var SEPARATORS;
66
- (function (SEPARATORS) {
67
- SEPARATORS["DOT"] = ".";
68
- })(SEPARATORS || (SEPARATORS = {}));
69
- const binSourceLocation = "/src/bin";
70
123
  const options = {
71
124
  prod: {
72
125
  type: "boolean",
@@ -80,6 +133,14 @@ const options = {
80
133
  type: "string",
81
134
  default: BuildMode.ALL,
82
135
  },
136
+ includes: {
137
+ type: "string",
138
+ default: "",
139
+ },
140
+ externals: {
141
+ type: "string",
142
+ default: "",
143
+ },
83
144
  docs: {
84
145
  type: "boolean",
85
146
  default: false,
@@ -193,17 +254,33 @@ class BuildScripts extends command_1.Command {
193
254
  .forEach((file) => (0, utils_1.patchFile)(path_1.default.join(file.parentPath, file.name), this.replacements));
194
255
  log.verbose(`Module ${name} ${version} patched in ${p}...`);
195
256
  }
196
- reportDiagnostics(diagnostics) {
197
- diagnostics.forEach((diagnostic) => {
198
- let message = "Error";
257
+ reportDiagnostics(diagnostics, logLevel) {
258
+ const msg = this.formatDiagnostics(diagnostics);
259
+ if (!Object.values(logging_1.LogLevel).includes(logLevel))
260
+ throw new Error(`Invalid LogLevel ${logLevel}`);
261
+ try {
262
+ this.log[logLevel](msg);
263
+ }
264
+ catch (e) {
265
+ console.warn(`Failed to get logger for ${logLevel}`);
266
+ throw e;
267
+ }
268
+ return msg;
269
+ }
270
+ // Format diagnostics into a single string for throwing or logging
271
+ formatDiagnostics(diagnostics) {
272
+ return diagnostics
273
+ .map((diagnostic) => {
274
+ let message = "";
199
275
  if (diagnostic.file && diagnostic.start) {
200
276
  const { line, character } = diagnostic.file.getLineAndCharacterOfPosition(diagnostic.start);
201
- message += ` ${diagnostic.file.fileName} (${line + 1},${character + 1})`;
277
+ message += `${diagnostic.file.fileName} (${line + 1},${character + 1})`;
202
278
  }
203
279
  message +=
204
280
  ": " + ts.flattenDiagnosticMessageText(diagnostic.messageText, "\n");
205
- console.log(message);
206
- });
281
+ return message;
282
+ })
283
+ .join("\n");
207
284
  }
208
285
  readConfigFile(configFileName) {
209
286
  // Read config file
@@ -212,17 +289,73 @@ class BuildScripts extends command_1.Command {
212
289
  const result = ts.parseConfigFileTextToJson(configFileName, configFileText);
213
290
  const configObject = result.config;
214
291
  if (!configObject) {
215
- this.reportDiagnostics([result.error]);
216
- throw new Error("Failed to parse tsconfig.json");
292
+ this.reportDiagnostics([result.error], logging_1.LogLevel.error);
217
293
  }
218
294
  // Extract config infromation
219
295
  const configParseResult = ts.parseJsonConfigFileContent(configObject, ts.sys, path_1.default.dirname(configFileName));
220
- if (configParseResult.errors.length > 0) {
221
- this.reportDiagnostics(configParseResult.errors);
222
- throw new Error("Failed to parse tsconfig.json");
223
- }
296
+ if (configParseResult.errors.length > 0)
297
+ this.reportDiagnostics(configParseResult.errors, logging_1.LogLevel.error);
224
298
  return configParseResult;
225
299
  }
300
+ evalDiagnostics(diagnostics) {
301
+ if (diagnostics && diagnostics.length > 0) {
302
+ const errors = diagnostics.filter((d) => d.category === ts.DiagnosticCategory.Error);
303
+ const warnings = diagnostics.filter((d) => d.category === ts.DiagnosticCategory.Warning);
304
+ const suggestions = diagnostics.filter((d) => d.category === ts.DiagnosticCategory.Suggestion);
305
+ const messages = diagnostics.filter((d) => d.category === ts.DiagnosticCategory.Message);
306
+ // Log diagnostics to console
307
+ if (warnings.length)
308
+ this.reportDiagnostics(warnings, logging_1.LogLevel.info);
309
+ if (errors.length) {
310
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
311
+ const formatted = this.reportDiagnostics(diagnostics, logging_1.LogLevel.error);
312
+ this.log.info(`TypeScript reported ${diagnostics.length} diagnostic(s) during check; aborting.`);
313
+ // throw new Error(
314
+ // `TypeScript reported ${diagnostics.length} diagnostic(s) during check; aborting.`
315
+ // );
316
+ }
317
+ if (suggestions.length)
318
+ this.reportDiagnostics(suggestions, logging_1.LogLevel.info);
319
+ if (messages.length)
320
+ this.reportDiagnostics(messages, logging_1.LogLevel.info);
321
+ }
322
+ }
323
+ preCheckDiagnostics(program) {
324
+ const diagnostics = ts.getPreEmitDiagnostics(program);
325
+ this.evalDiagnostics(diagnostics);
326
+ }
327
+ // Create a TypeScript program for the current tsconfig and fail if there are any error diagnostics.
328
+ async checkTsDiagnostics(isDev, mode, bundle = false) {
329
+ const log = this.log.for(this.checkTsDiagnostics);
330
+ let tsConfig;
331
+ try {
332
+ tsConfig = this.readConfigFile("./tsconfig.json");
333
+ }
334
+ catch (e) {
335
+ throw new Error(`Failed to parse tsconfig.json: ${e}`);
336
+ }
337
+ if (bundle) {
338
+ tsConfig.options.module = typescript_1.ModuleKind.AMD;
339
+ tsConfig.options.outDir = "dist";
340
+ tsConfig.options.isolatedModules = false;
341
+ tsConfig.options.outFile = this.pkgName;
342
+ }
343
+ else {
344
+ tsConfig.options.outDir = `lib${mode === Modes.ESM ? "/esm" : ""}`;
345
+ tsConfig.options.module =
346
+ mode === Modes.ESM ? typescript_1.ModuleKind.ES2022 : typescript_1.ModuleKind.CommonJS;
347
+ }
348
+ if (isDev) {
349
+ tsConfig.options.inlineSourceMap = true;
350
+ tsConfig.options.sourceMap = false;
351
+ }
352
+ else {
353
+ tsConfig.options.sourceMap = false;
354
+ }
355
+ const program = ts.createProgram(tsConfig.fileNames, tsConfig.options);
356
+ this.preCheckDiagnostics(program);
357
+ log.verbose(`TypeScript checks passed (${bundle ? "bundle" : "normal"} mode).`);
358
+ }
226
359
  async buildTs(isDev, mode, bundle = false) {
227
360
  const log = this.log.for(this.buildTs);
228
361
  log.info(`Building ${this.pkgName} ${this.pkgVersion} module (${mode}) in ${isDev ? "dev" : "prod"} mode...`);
@@ -263,19 +396,7 @@ class BuildScripts extends command_1.Command {
263
396
  const allDiagnostics = ts
264
397
  .getPreEmitDiagnostics(program)
265
398
  .concat(emitResult.diagnostics);
266
- allDiagnostics.forEach((diagnostic) => {
267
- if (diagnostic.file) {
268
- const { line, character } = diagnostic.file.getLineAndCharacterOfPosition(diagnostic.start);
269
- const message = ts.flattenDiagnosticMessageText(diagnostic.messageText, "\n");
270
- log.info(`${diagnostic.file.fileName} (${line + 1},${character + 1}): ${message}`);
271
- }
272
- else {
273
- log.info(ts.flattenDiagnosticMessageText(diagnostic.messageText, "\n"));
274
- }
275
- });
276
- if (emitResult.emitSkipped) {
277
- throw new Error("Build failed");
278
- }
399
+ this.evalDiagnostics(allDiagnostics);
279
400
  }
280
401
  async build(isDev, mode, bundle = false) {
281
402
  const log = this.log.for(this.build);
@@ -303,42 +424,56 @@ class BuildScripts extends command_1.Command {
303
424
  if (hasAssets)
304
425
  (0, utils_1.copyFile)("./src/assets", `./${mode === Modes.CJS ? "lib" : "dist"}/assets`);
305
426
  }
306
- async buildCommands() {
307
- const commands = fs_1.default.readdirSync(path_1.default.join(process.cwd() + binSourceLocation)).map((cmd) => cmd.split(SEPARATORS.DOT)[0]);
308
- for (const cmd of commands) {
309
- if (!cmd.endsWith(".ts"))
310
- continue;
311
- await this.bundle(Modes.CJS, true, true, `${binSourceLocation}/${cmd}.ts`, cmd);
312
- let data = (0, utils_1.readFile)(`bin/${cmd}.cjs`);
313
- data = "#!/usr/bin/env node\n" + data;
314
- (0, utils_1.writeFile)(`bin/${cmd}.cjs`, data);
315
- fs_1.default.chmodSync(`bin/${cmd}.cjs`, "755");
316
- }
317
- }
318
- async bundle(mode, isDev, isLib, entryFile = "src/index.ts", nameOverride = this.pkgName, externals, include = [
427
+ async bundle(mode, isDev, isLib, entryFile = "src/index.ts", nameOverride = this.pkgName, externalsArg, includeArg = [
319
428
  "prompts",
320
429
  "styled-string-builder",
321
430
  "typed-object-accumulator",
322
431
  "@decaf-ts/logging",
323
432
  ]) {
433
+ // Run a TypeScript-only diagnostic check for the bundling configuration and fail fast on any errors.
434
+ await this.checkTsDiagnostics(isDev, mode, true);
324
435
  const isEsm = mode === Modes.ESM;
325
436
  const pkgName = this.pkgName;
437
+ // normalize include and externals
438
+ const include = Array.from(new Set([...parseList(includeArg)]));
439
+ let externalsList = parseList(externalsArg);
440
+ if (externalsList.length === 0) {
441
+ // if no externals specified, include package.json dependencies to avoid rollup treating them as resolvable
442
+ externalsList = getPackageDependencies();
443
+ }
326
444
  const ext = Array.from(new Set([
327
- ...[
328
- "fs",
329
- "path",
330
- "process",
331
- "rollup",
332
- "@rollup/plugin-typescript",
333
- "@rollup/plugin-json",
334
- "@rollup/plugin-commonjs",
335
- "@rollup/plugin-node-resolve",
336
- "child_process",
337
- "tslib",
338
- "util",
339
- "https",
340
- ],
341
- ...(externals || []),
445
+ // builtins and always external runtime deps
446
+ ...(function builtinList() {
447
+ try {
448
+ return (Array.isArray(module_1.builtinModules) ? module_1.builtinModules : []);
449
+ }
450
+ catch {
451
+ // fallback to a reasonable subset if `builtinModules` is unavailable
452
+ return [
453
+ "fs",
454
+ "path",
455
+ "process",
456
+ "child_process",
457
+ "util",
458
+ "https",
459
+ "http",
460
+ "os",
461
+ "stream",
462
+ "crypto",
463
+ "zlib",
464
+ "net",
465
+ "tls",
466
+ "url",
467
+ "querystring",
468
+ "assert",
469
+ "events",
470
+ "tty",
471
+ "dns",
472
+ "querystring",
473
+ ];
474
+ }
475
+ })(),
476
+ ...externalsList,
342
477
  ]));
343
478
  const plugins = [
344
479
  (0, plugin_typescript_1.default)({
@@ -353,10 +488,22 @@ class BuildScripts extends command_1.Command {
353
488
  }),
354
489
  (0, plugin_json_1.default)(),
355
490
  ];
491
+ // production minification
492
+ if (!isDev) {
493
+ // terser is optional at runtime; import lazily inside bundle to avoid test-time resolution errors
494
+ try {
495
+ const terserMod = await Promise.resolve().then(() => __importStar(require("@rollup/plugin-terser")));
496
+ const terserFn = (terserMod && terserMod.terser) || terserMod.default || terserMod;
497
+ plugins.push(terserFn());
498
+ }
499
+ catch {
500
+ // if terser isn't available, ignore
501
+ }
502
+ }
356
503
  if (isLib) {
357
504
  plugins.push((0, plugin_commonjs_1.default)({
358
505
  include: [],
359
- exclude: externals,
506
+ exclude: externalsList,
360
507
  }), (0, plugin_node_resolve_1.nodeResolve)({
361
508
  resolveOnly: include,
362
509
  }));
@@ -366,6 +513,12 @@ class BuildScripts extends command_1.Command {
366
513
  plugins: plugins,
367
514
  external: ext,
368
515
  };
516
+ // prepare output globals mapping for externals
517
+ const globals = {};
518
+ // include all externals and builtins (ext) so Rollup won't guess names for builtins
519
+ ext.forEach((e) => {
520
+ globals[e] = packageToGlobal(e);
521
+ });
369
522
  const outputs = [
370
523
  {
371
524
  file: `${isLib ? "bin/" : "dist/"}${nameOverride ? nameOverride : `.bundle.${!isDev ? "min" : ""}`}${isEsm ? ".esm" : ""}.cjs`,
@@ -373,7 +526,7 @@ class BuildScripts extends command_1.Command {
373
526
  name: pkgName,
374
527
  esModule: isEsm,
375
528
  sourcemap: isDev ? "inline" : false,
376
- globals: {},
529
+ globals: globals,
377
530
  exports: "auto",
378
531
  },
379
532
  ];
@@ -382,8 +535,7 @@ class BuildScripts extends command_1.Command {
382
535
  console.log(bundle.watchFiles);
383
536
  async function generateOutputs(bundle) {
384
537
  for (const outputOptions of outputs) {
385
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
386
- const { output } = await bundle.write(outputOptions);
538
+ await bundle.write(outputOptions);
387
539
  }
388
540
  }
389
541
  await generateOutputs(bundle);
@@ -392,7 +544,8 @@ class BuildScripts extends command_1.Command {
392
544
  throw new Error(`Failed to bundle: ${e}`);
393
545
  }
394
546
  }
395
- async buildByEnv(isDev, mode = BuildMode.ALL) {
547
+ async buildByEnv(isDev, mode = BuildMode.ALL, includesArg, externalsArg) {
548
+ // note: includes and externals will be passed through from run() into this method by callers
396
549
  try {
397
550
  (0, utils_1.deletePath)("lib");
398
551
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
@@ -415,18 +568,18 @@ class BuildScripts extends command_1.Command {
415
568
  this.patchFiles("lib");
416
569
  }
417
570
  if ([BuildMode.ALL, BuildMode.BUNDLE].includes(mode)) {
418
- await this.bundle(Modes.ESM, true, false);
419
- await this.bundle(Modes.CJS, true, false);
571
+ await this.bundle(Modes.ESM, isDev, false, "src/index.ts", this.pkgName, externalsArg, includesArg);
572
+ await this.bundle(Modes.CJS, isDev, false, "src/index.ts", this.pkgName, externalsArg, includesArg);
420
573
  this.patchFiles("dist");
421
574
  }
422
575
  this.copyAssets(Modes.CJS);
423
576
  this.copyAssets(Modes.ESM);
424
577
  }
425
- async buildDev(mode = BuildMode.ALL) {
426
- return this.buildByEnv(true, mode);
578
+ async buildDev(mode = BuildMode.ALL, includesArg, externalsArg) {
579
+ return this.buildByEnv(true, mode, includesArg, externalsArg);
427
580
  }
428
- async buildProd(mode = BuildMode.ALL) {
429
- return this.buildByEnv(false, mode);
581
+ async buildProd(mode = BuildMode.ALL, includesArg, externalsArg) {
582
+ return this.buildByEnv(false, mode, includesArg, externalsArg);
430
583
  }
431
584
  async buildDocs() {
432
585
  await (0, utils_1.runCommand)(`npm install better-docs taffydb`).promise;
@@ -460,15 +613,12 @@ class BuildScripts extends command_1.Command {
460
613
  });
461
614
  }
462
615
  async run(answers) {
463
- const { dev, prod, docs, commands, buildMode } = answers;
464
- if (commands) {
465
- await this.buildCommands();
466
- }
616
+ const { dev, prod, docs, buildMode, includes, externals } = answers;
467
617
  if (dev) {
468
- return await this.buildDev(buildMode);
618
+ return await this.buildDev(buildMode, includes, externals);
469
619
  }
470
620
  if (prod) {
471
- return await this.buildProd(buildMode);
621
+ return await this.buildProd(buildMode, includes, externals);
472
622
  }
473
623
  if (docs) {
474
624
  return await this.buildDocs();
@@ -476,4 +626,4 @@ class BuildScripts extends command_1.Command {
476
626
  }
477
627
  }
478
628
  exports.BuildScripts = BuildScripts;
479
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-scripts.js","sourceRoot":"","sources":["../../../src/cli/commands/build-scripts.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from \"../command\";\nimport { CommandOptions } from \"../types\";\nimport { DefaultCommandOptions, DefaultCommandValues } from \"../constants\";\nimport {\n  copyFile,\n  deletePath,\n  getAllFiles,\n  getPackage,\n  patchFile,\n  readFile,\n  renameFile,\n  runCommand,\n  writeFile,\n} from \"../../utils\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { InputOptions, OutputOptions, rollup, RollupBuild } from \"rollup\";\nimport typescript from \"@rollup/plugin-typescript\";\nimport commonjs from \"@rollup/plugin-commonjs\";\nimport { nodeResolve } from \"@rollup/plugin-node-resolve\";\nimport json from \"@rollup/plugin-json\";\nimport { LoggingConfig } from \"@decaf-ts/logging\";\nimport * as ts from \"typescript\";\nimport { Diagnostic, EmitResult, ModuleKind, SourceFile } from \"typescript\";\n\nconst VERSION_STRING = \"##VERSION##\";\nconst PACKAGE_STRING = \"##PACKAGE##\";\n\nenum Modes {\n  CJS = \"commonjs\",\n  ESM = \"es2022\",\n}\n\nenum BuildMode {\n  BUILD = \"build\",\n  BUNDLE = \"bundle\",\n  ALL = \"all\",\n}\n\nenum SEPARATORS {\n  DOT = \".\"\n}\n\nconst binSourceLocation = \"/src/bin\"\n\nconst options = {\n  prod: {\n    type: \"boolean\",\n    default: false,\n  },\n  dev: {\n    type: \"boolean\",\n    default: false,\n  },\n  buildMode: {\n    type: \"string\",\n    default: BuildMode.ALL,\n  },\n  docs: {\n    type: \"boolean\",\n    default: false,\n  },\n  commands: {\n    type: \"boolean\",\n    default: false,\n  },\n  banner: {\n    type: \"boolean\",\n    default: false,\n  },\n};\n\nconst cjs2Transformer = (ext = \".cjs\") => {\n  const log = BuildScripts.log.for(cjs2Transformer);\n  const resolutionCache = new Map<string, string>();\n\n  return (transformationContext: ts.TransformationContext) => {\n    return (sourceFile: ts.SourceFile) => {\n      const sourceDir = path.dirname(sourceFile.fileName);\n\n      function resolvePath(importPath: string) {\n        const cacheKey = JSON.stringify([sourceDir, importPath]);\n        const cachedValue = resolutionCache.get(cacheKey);\n        if (cachedValue != null) return cachedValue;\n\n        let resolvedPath = importPath;\n        try {\n          resolvedPath = path.resolve(sourceDir, resolvedPath + \".ts\");\n        } catch (error: unknown) {\n          throw new Error(`Failed to resolve path ${importPath}: ${error}`);\n        }\n        let stat;\n        try {\n          stat = fs.statSync(resolvedPath);\n        } catch (e: unknown) {\n          try {\n            log.verbose(\n              `Testing existence of path ${resolvedPath} as a folder defaulting to index file`\n            );\n            stat = fs.statSync(resolvedPath.replace(/\\.ts$/gm, \"\"));\n          } catch (e2: unknown) {\n            throw new Error(\n              `Failed to resolve path ${importPath}: ${e}, ${e2}`\n            );\n          }\n        }\n        if (stat.isDirectory())\n          resolvedPath = resolvedPath.replace(/\\.ts$/gm, \"/index.ts\");\n\n        if (path.isAbsolute(resolvedPath)) {\n          const extension =\n            (/\\.tsx?$/.exec(path.basename(resolvedPath)) || [])[0] || void 0;\n\n          resolvedPath =\n            \"./\" +\n            path.relative(\n              sourceDir,\n              path.resolve(\n                path.dirname(resolvedPath),\n                path.basename(resolvedPath, extension) + ext\n              )\n            );\n        }\n\n        resolutionCache.set(cacheKey, resolvedPath);\n        return resolvedPath;\n      }\n\n      function visitNode(node: ts.Node): ts.VisitResult<ts.Node> {\n        if (shouldMutateModuleSpecifier(node)) {\n          if (ts.isImportDeclaration(node)) {\n            const resolvedPath = resolvePath(node.moduleSpecifier.text);\n            const newModuleSpecifier =\n              transformationContext.factory.createStringLiteral(resolvedPath);\n            return transformationContext.factory.updateImportDeclaration(\n              node,\n              node.modifiers,\n              node.importClause,\n              newModuleSpecifier,\n              undefined\n            );\n          } else if (ts.isExportDeclaration(node)) {\n            const resolvedPath = resolvePath(node.moduleSpecifier.text);\n            const newModuleSpecifier =\n              transformationContext.factory.createStringLiteral(resolvedPath);\n            return transformationContext.factory.updateExportDeclaration(\n              node,\n              node.modifiers,\n              node.isTypeOnly,\n              node.exportClause,\n              newModuleSpecifier,\n              undefined\n            );\n          }\n        }\n\n        return ts.visitEachChild(node, visitNode, transformationContext);\n      }\n\n      function shouldMutateModuleSpecifier(node: ts.Node): node is (\n        | ts.ImportDeclaration\n        | ts.ExportDeclaration\n      ) & {\n        moduleSpecifier: ts.StringLiteral;\n      } {\n        if (!ts.isImportDeclaration(node) && !ts.isExportDeclaration(node))\n          return false;\n\n        if (node.moduleSpecifier === undefined) return false;\n        // only when module specifier is valid\n        if (!ts.isStringLiteral(node.moduleSpecifier)) return false;\n        // only when path is relative\n        if (\n          !node.moduleSpecifier.text.startsWith(\"./\") &&\n          !node.moduleSpecifier.text.startsWith(\"../\")\n        )\n          return false;\n        // only when module specifier has no extension\n        if (path.extname(node.moduleSpecifier.text) !== \"\") return false;\n        return true;\n      }\n\n      return ts.visitNode(sourceFile, visitNode) as SourceFile;\n    };\n  };\n};\n\nexport class BuildScripts extends Command<\n  CommandOptions<typeof options>,\n  void\n> {\n  private replacements: Record<string, string> = {};\n  private readonly pkgVersion: string;\n  private readonly pkgName: string;\n\n  constructor() {\n    super(\n      \"BuildScripts\",\n      Object.assign({}, DefaultCommandOptions, options) as CommandOptions<\n        typeof options\n      >\n    );\n    const pkg = getPackage() as { name: string; version: string };\n    const { name, version } = pkg;\n    this.pkgName = name.includes(\"@\") ? name.split(\"/\")[1] : name;\n    this.pkgVersion = version;\n    this.replacements[VERSION_STRING] = this.pkgVersion;\n    this.replacements[PACKAGE_STRING] = name;\n  }\n\n  patchFiles(p: string) {\n    const log = this.log.for(this.patchFiles);\n    const { name, version } = getPackage() as any;\n    log.info(`Patching ${name} ${version} module in ${p}...`);\n    const stat = fs.statSync(p);\n    if (stat.isDirectory())\n      fs.readdirSync(p, { withFileTypes: true, recursive: true })\n        .filter((p) => p.isFile())\n        .forEach((file) =>\n          patchFile(path.join(file.parentPath, file.name), this.replacements)\n        );\n    log.verbose(`Module ${name} ${version} patched in ${p}...`);\n  }\n\n  private reportDiagnostics(diagnostics: Diagnostic[]): void {\n    diagnostics.forEach((diagnostic) => {\n      let message = \"Error\";\n      if (diagnostic.file && diagnostic.start) {\n        const { line, character } =\n          diagnostic.file.getLineAndCharacterOfPosition(diagnostic.start);\n        message += ` ${diagnostic.file.fileName} (${line + 1},${character + 1})`;\n      }\n      message +=\n        \": \" + ts.flattenDiagnosticMessageText(diagnostic.messageText, \"\\n\");\n      console.log(message);\n    });\n  }\n\n  private readConfigFile(configFileName: string) {\n    // Read config file\n    const configFileText = fs.readFileSync(configFileName).toString();\n\n    // Parse JSON, after removing comments. Just fancier JSON.parse\n    const result = ts.parseConfigFileTextToJson(configFileName, configFileText);\n    const configObject = result.config;\n    if (!configObject) {\n      this.reportDiagnostics([result.error!]);\n      throw new Error(\"Failed to parse tsconfig.json\");\n    }\n\n    // Extract config infromation\n    const configParseResult = ts.parseJsonConfigFileContent(\n      configObject,\n      ts.sys,\n      path.dirname(configFileName)\n    );\n    if (configParseResult.errors.length > 0) {\n      this.reportDiagnostics(configParseResult.errors);\n      throw new Error(\"Failed to parse tsconfig.json\");\n    }\n    return configParseResult;\n  }\n\n  private async buildTs(isDev: boolean, mode: Modes, bundle = false) {\n    const log = this.log.for(this.buildTs);\n    log.info(\n      `Building ${this.pkgName} ${this.pkgVersion} module (${mode}) in ${isDev ? \"dev\" : \"prod\"} mode...`\n    );\n    let tsConfig;\n    try {\n      tsConfig = this.readConfigFile(\"./tsconfig.json\");\n    } catch (e: unknown) {\n      throw new Error(`Failed to parse tsconfig.json: ${e}`);\n    }\n\n    if (bundle) {\n      tsConfig.options.module = ModuleKind.AMD;\n      tsConfig.options.outDir = \"dist\";\n      tsConfig.options.isolatedModules = false;\n      tsConfig.options.outFile = this.pkgName;\n    } else {\n      tsConfig.options.outDir = `lib${mode === Modes.ESM ? \"/esm\" : \"\"}`;\n      tsConfig.options.module =\n        mode === Modes.ESM ? ModuleKind.ES2022 : ModuleKind.CommonJS;\n    }\n\n    if (isDev) {\n      tsConfig.options.inlineSourceMap = true;\n      tsConfig.options.sourceMap = false;\n    } else {\n      tsConfig.options.sourceMap = false;\n    }\n\n    const program = ts.createProgram(tsConfig.fileNames, tsConfig.options);\n\n    const transformations: { before?: any[] } = {};\n    if (mode === Modes.CJS) {\n      transformations.before = [cjs2Transformer(\".cjs\")];\n    } else if (mode === Modes.ESM) {\n      transformations.before = [cjs2Transformer(\".js\")];\n    }\n\n    const emitResult: EmitResult = program.emit(\n      undefined,\n      undefined,\n      undefined,\n      undefined,\n      transformations\n    );\n\n    const allDiagnostics = ts\n      .getPreEmitDiagnostics(program)\n      .concat(emitResult.diagnostics);\n\n    allDiagnostics.forEach((diagnostic) => {\n      if (diagnostic.file) {\n        const { line, character } =\n          diagnostic.file.getLineAndCharacterOfPosition(diagnostic.start!);\n        const message = ts.flattenDiagnosticMessageText(\n          diagnostic.messageText,\n          \"\\n\"\n        );\n        log.info(\n          `${diagnostic.file.fileName} (${line + 1},${character + 1}): ${message}`\n        );\n      } else {\n        log.info(ts.flattenDiagnosticMessageText(diagnostic.messageText, \"\\n\"));\n      }\n    });\n    if (emitResult.emitSkipped) {\n      throw new Error(\"Build failed\");\n    }\n  }\n\n  private async build(isDev: boolean, mode: Modes, bundle = false) {\n    const log = this.log.for(this.build);\n    await this.buildTs(isDev, mode, bundle);\n\n    log.verbose(\n      `Module ${this.pkgName} ${this.pkgVersion} (${mode}) built in ${isDev ? \"dev\" : \"prod\"} mode...`\n    );\n    if (mode === Modes.CJS && !bundle) {\n      const files = getAllFiles(\n        \"lib\",\n        (file) => file.endsWith(\".js\") && !file.includes(\"/esm/\")\n      );\n\n      for (const file of files) {\n        log.verbose(`Patching ${file}'s cjs imports...`);\n        const f = file.replace(\".js\", \".cjs\");\n        await renameFile(file, f);\n      }\n    }\n  }\n\n  copyAssets(mode: Modes) {\n    const log = this.log.for(this.copyAssets);\n    let hasAssets = false;\n    try {\n      hasAssets = fs.statSync(\"./src/assets\").isDirectory();\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      return log.verbose(`No assets found in ./src/assets to copy`);\n    }\n    if (hasAssets)\n      copyFile(\n        \"./src/assets\",\n        `./${mode === Modes.CJS ? \"lib\" : \"dist\"}/assets`\n      );\n  }\n\n  async buildCommands() {\n    const commands: string[]  = fs.readdirSync(path.join(process.cwd() + binSourceLocation)).map((cmd) => cmd.split(SEPARATORS.DOT)[0]) \n    for (const cmd of commands) {\n      if (!cmd.endsWith(\".ts\")) continue;\n\n      await this.bundle(Modes.CJS, true, true, `${binSourceLocation}/${cmd}.ts`, cmd);\n      let data = readFile(`bin/${cmd}.cjs`);\n      data = \"#!/usr/bin/env node\\n\" + data;\n      writeFile(`bin/${cmd}.cjs`, data);\n      fs.chmodSync(`bin/${cmd}.cjs`, \"755\");\n    }\n  }\n\n  async bundle(\n    mode: Modes,\n    isDev: boolean,\n    isLib: boolean,\n    entryFile: string = \"src/index.ts\",\n    nameOverride: string = this.pkgName,\n    externals?: string[],\n    include: string[] = [\n      \"prompts\",\n      \"styled-string-builder\",\n      \"typed-object-accumulator\",\n      \"@decaf-ts/logging\",\n    ]\n  ) {\n    const isEsm = mode === Modes.ESM;\n    const pkgName = this.pkgName;\n\n    const ext = Array.from(\n      new Set([\n        ...[\n          \"fs\",\n          \"path\",\n          \"process\",\n          \"rollup\",\n          \"@rollup/plugin-typescript\",\n          \"@rollup/plugin-json\",\n          \"@rollup/plugin-commonjs\",\n          \"@rollup/plugin-node-resolve\",\n          \"child_process\",\n          \"tslib\",\n          \"util\",\n          \"https\",\n        ],\n        ...(externals || []),\n      ])\n    );\n\n    const plugins = [\n      typescript({\n        compilerOptions: {\n          module: \"esnext\",\n          declaration: false,\n          outDir: isLib ? \"bin\" : \"dist\",\n        },\n        include: [\"src/**/*.ts\"],\n        exclude: [\"node_modules\", \"**/*.spec.ts\"],\n        tsconfig: \"./tsconfig.json\",\n      }),\n      json(),\n    ];\n\n    if (isLib) {\n      plugins.push(\n        commonjs({\n          include: [],\n          exclude: externals,\n        }),\n        nodeResolve({\n          resolveOnly: include,\n        })\n      );\n    }\n\n    const input: InputOptions = {\n      input: entryFile,\n      plugins: plugins,\n      external: ext,\n    };\n\n    const outputs: OutputOptions[] = [\n      {\n        file: `${isLib ? \"bin/\" : \"dist/\"}${nameOverride ? nameOverride : `.bundle.${!isDev ? \"min\" : \"\"}`}${isEsm ? \".esm\" : \"\"}.cjs`,\n        format: isLib ? \"cjs\" : isEsm ? \"esm\" : \"umd\",\n        name: pkgName,\n        esModule: isEsm,\n        sourcemap: isDev ? \"inline\" : false,\n        globals: {},\n        exports: \"auto\",\n      },\n    ];\n\n    try {\n      const bundle = await rollup(input);\n      console.log(bundle.watchFiles);\n      async function generateOutputs(bundle: RollupBuild) {\n        for (const outputOptions of outputs) {\n          // eslint-disable-next-line @typescript-eslint/no-unused-vars\n          const { output } = await bundle.write(outputOptions);\n        }\n      }\n\n      await generateOutputs(bundle);\n    } catch (e: unknown) {\n      throw new Error(`Failed to bundle: ${e}`);\n    }\n  }\n\n  private async buildByEnv(isDev: boolean, mode: BuildMode = BuildMode.ALL) {\n    try {\n      deletePath(\"lib\");\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      // do nothing\n    }\n    try {\n      deletePath(\"dist\");\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      // do nothing\n    }\n    fs.mkdirSync(\"lib\");\n    fs.mkdirSync(\"dist\");\n\n    if ([BuildMode.ALL, BuildMode.BUILD].includes(mode)) {\n      await this.build(isDev, Modes.ESM);\n      await this.build(isDev, Modes.CJS);\n      this.patchFiles(\"lib\");\n    }\n\n    if ([BuildMode.ALL, BuildMode.BUNDLE].includes(mode)) {\n      await this.bundle(Modes.ESM, true, false);\n      await this.bundle(Modes.CJS, true, false);\n      this.patchFiles(\"dist\");\n    }\n\n    this.copyAssets(Modes.CJS);\n    this.copyAssets(Modes.ESM);\n  }\n\n  async buildDev(mode: BuildMode = BuildMode.ALL) {\n    return this.buildByEnv(true, mode);\n  }\n\n  async buildProd(mode: BuildMode = BuildMode.ALL) {\n    return this.buildByEnv(false, mode);\n  }\n\n  async buildDocs() {\n    await runCommand(`npm install better-docs taffydb`).promise;\n    await runCommand(`npx markdown-include ./workdocs/readme-md.json`).promise;\n    await runCommand(\n      `npx jsdoc -c ./workdocs/jsdocs.json -t ./node_modules/better-docs`\n    ).promise;\n    await runCommand(`npm remove better-docs taffydb`).promise;\n    [\n      {\n        src: \"workdocs/assets\",\n        dest: \"./docs/workdocs/assets\",\n      },\n      {\n        src: \"workdocs/reports/coverage\",\n        dest: \"./docs/workdocs/reports/coverage\",\n      },\n      {\n        src: \"workdocs/reports/html\",\n        dest: \"./docs/workdocs/reports/html\",\n      },\n      {\n        src: \"workdocs/resources\",\n        dest: \"./docs/workdocs/resources\",\n      },\n      {\n        src: \"LICENSE.md\",\n        dest: \"./docs/LICENSE.md\",\n      },\n    ].forEach((f) => {\n      const { src, dest } = f;\n      copyFile(src, dest);\n    });\n  }\n\n  protected async run<R>(\n    answers: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof options]: unknown }\n  ): Promise<string | void | R> {\n    const { dev, prod, docs, commands, buildMode } = answers;\n\n    if (commands) {\n      await this.buildCommands();\n    }\n\n    if (dev) {\n      return await this.buildDev(buildMode as BuildMode);\n    }\n    if (prod) {\n      return await this.buildProd(buildMode as BuildMode);\n    }\n    if (docs) {\n      return await this.buildDocs();\n    }\n  }\n}\n"]}
629
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-scripts.js","sourceRoot":"","sources":["../../../src/cli/commands/build-scripts.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from \"../command\";\nimport { CommandOptions } from \"../types\";\nimport { DefaultCommandOptions, DefaultCommandValues } from \"../constants\";\nimport {\n  copyFile,\n  deletePath,\n  getAllFiles,\n  getPackage,\n  patchFile,\n  renameFile,\n  runCommand,\n} from \"../../utils\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { InputOptions, OutputOptions, rollup, RollupBuild } from \"rollup\";\nimport typescript from \"@rollup/plugin-typescript\";\nimport commonjs from \"@rollup/plugin-commonjs\";\nimport { nodeResolve } from \"@rollup/plugin-node-resolve\";\nimport json from \"@rollup/plugin-json\";\nimport { builtinModules } from \"module\";\nimport { LoggingConfig, LogLevel } from \"@decaf-ts/logging\";\nimport * as ts from \"typescript\";\nimport { Diagnostic, EmitResult, ModuleKind, SourceFile } from \"typescript\";\n\nexport function parseList(input?: string | string[]): string[] {\n  if (!input) return [];\n  if (Array.isArray(input))\n    return input.map((i) => `${i}`.trim()).filter(Boolean);\n  return `${input}`\n    .split(\",\")\n    .map((p) => p.trim())\n    .filter(Boolean);\n}\n\nexport function packageToGlobal(name: string): string {\n  // Remove scope and split by non-alphanumeric chars, then camelCase\n  const withoutScope = name.replace(/^@/, \"\");\n  const parts = withoutScope.split(/[/\\-_.]+/).filter(Boolean);\n  return parts\n    .map((p, i) =>\n      i === 0\n        ? p.replace(/[^a-zA-Z0-9]/g, \"\")\n        : `${p.charAt(0).toUpperCase()}${p.slice(1)}`\n    )\n    .join(\"\");\n}\n\nexport function getPackageDependencies(): string[] {\n  // Try the current working directory first\n  let pkg: any;\n  try {\n    pkg = getPackage(process.cwd()) as any;\n  } catch {\n    pkg = undefined;\n  }\n\n  // If no dependencies found in cwd, try the package next to this source file (fallback for tests)\n  try {\n    const hasDeps =\n      pkg &&\n      (Object.keys(pkg.dependencies || {}).length > 0 ||\n        Object.keys(pkg.devDependencies || {}).length > 0 ||\n        Object.keys(pkg.peerDependencies || {}).length > 0);\n    if (!hasDeps) {\n      const fallbackDir = path.resolve(__dirname, \"../../..\");\n      try {\n        pkg = getPackage(fallbackDir) as any;\n      } catch {\n        // ignore and keep pkg as-is\n      }\n    }\n  } catch {\n    // ignore\n  }\n\n  const deps = Object.keys((pkg && pkg.dependencies) || {});\n  const peer = Object.keys((pkg && pkg.peerDependencies) || {});\n  const dev = Object.keys((pkg && pkg.devDependencies) || {});\n  return Array.from(new Set([...deps, ...peer, ...dev]));\n}\n\nconst VERSION_STRING = \"##VERSION##\";\nconst PACKAGE_STRING = \"##PACKAGE##\";\n\nenum Modes {\n  CJS = \"commonjs\",\n  ESM = \"es2022\",\n}\n\nenum BuildMode {\n  BUILD = \"build\",\n  BUNDLE = \"bundle\",\n  ALL = \"all\",\n}\n\nconst options = {\n  prod: {\n    type: \"boolean\",\n    default: false,\n  },\n  dev: {\n    type: \"boolean\",\n    default: false,\n  },\n  buildMode: {\n    type: \"string\",\n    default: BuildMode.ALL,\n  },\n  includes: {\n    type: \"string\",\n    default: \"\",\n  },\n  externals: {\n    type: \"string\",\n    default: \"\",\n  },\n  docs: {\n    type: \"boolean\",\n    default: false,\n  },\n  commands: {\n    type: \"boolean\",\n    default: false,\n  },\n  banner: {\n    type: \"boolean\",\n    default: false,\n  },\n};\n\nconst cjs2Transformer = (ext = \".cjs\") => {\n  const log = BuildScripts.log.for(cjs2Transformer);\n  const resolutionCache = new Map<string, string>();\n\n  return (transformationContext: ts.TransformationContext) => {\n    return (sourceFile: ts.SourceFile) => {\n      const sourceDir = path.dirname(sourceFile.fileName);\n\n      function resolvePath(importPath: string) {\n        const cacheKey = JSON.stringify([sourceDir, importPath]);\n        const cachedValue = resolutionCache.get(cacheKey);\n        if (cachedValue != null) return cachedValue;\n\n        let resolvedPath = importPath;\n        try {\n          resolvedPath = path.resolve(sourceDir, resolvedPath + \".ts\");\n        } catch (error: unknown) {\n          throw new Error(`Failed to resolve path ${importPath}: ${error}`);\n        }\n        let stat;\n        try {\n          stat = fs.statSync(resolvedPath);\n        } catch (e: unknown) {\n          try {\n            log.verbose(\n              `Testing existence of path ${resolvedPath} as a folder defaulting to index file`\n            );\n            stat = fs.statSync(resolvedPath.replace(/\\.ts$/gm, \"\"));\n          } catch (e2: unknown) {\n            throw new Error(\n              `Failed to resolve path ${importPath}: ${e}, ${e2}`\n            );\n          }\n        }\n        if (stat.isDirectory())\n          resolvedPath = resolvedPath.replace(/\\.ts$/gm, \"/index.ts\");\n\n        if (path.isAbsolute(resolvedPath)) {\n          const extension =\n            (/\\.tsx?$/.exec(path.basename(resolvedPath)) || [])[0] || void 0;\n\n          resolvedPath =\n            \"./\" +\n            path.relative(\n              sourceDir,\n              path.resolve(\n                path.dirname(resolvedPath),\n                path.basename(resolvedPath, extension) + ext\n              )\n            );\n        }\n\n        resolutionCache.set(cacheKey, resolvedPath);\n        return resolvedPath;\n      }\n\n      function visitNode(node: ts.Node): ts.VisitResult<ts.Node> {\n        if (shouldMutateModuleSpecifier(node)) {\n          if (ts.isImportDeclaration(node)) {\n            const resolvedPath = resolvePath(node.moduleSpecifier.text);\n            const newModuleSpecifier =\n              transformationContext.factory.createStringLiteral(resolvedPath);\n            return transformationContext.factory.updateImportDeclaration(\n              node,\n              node.modifiers,\n              node.importClause,\n              newModuleSpecifier,\n              undefined\n            );\n          } else if (ts.isExportDeclaration(node)) {\n            const resolvedPath = resolvePath(node.moduleSpecifier.text);\n            const newModuleSpecifier =\n              transformationContext.factory.createStringLiteral(resolvedPath);\n            return transformationContext.factory.updateExportDeclaration(\n              node,\n              node.modifiers,\n              node.isTypeOnly,\n              node.exportClause,\n              newModuleSpecifier,\n              undefined\n            );\n          }\n        }\n\n        return ts.visitEachChild(node, visitNode, transformationContext);\n      }\n\n      function shouldMutateModuleSpecifier(node: ts.Node): node is (\n        | ts.ImportDeclaration\n        | ts.ExportDeclaration\n      ) & {\n        moduleSpecifier: ts.StringLiteral;\n      } {\n        if (!ts.isImportDeclaration(node) && !ts.isExportDeclaration(node))\n          return false;\n\n        if (node.moduleSpecifier === undefined) return false;\n        // only when module specifier is valid\n        if (!ts.isStringLiteral(node.moduleSpecifier)) return false;\n        // only when path is relative\n        if (\n          !node.moduleSpecifier.text.startsWith(\"./\") &&\n          !node.moduleSpecifier.text.startsWith(\"../\")\n        )\n          return false;\n        // only when module specifier has no extension\n        if (path.extname(node.moduleSpecifier.text) !== \"\") return false;\n        return true;\n      }\n\n      return ts.visitNode(sourceFile, visitNode) as SourceFile;\n    };\n  };\n};\n\nexport class BuildScripts extends Command<\n  CommandOptions<typeof options>,\n  void\n> {\n  private replacements: Record<string, string> = {};\n  private readonly pkgVersion: string;\n  private readonly pkgName: string;\n\n  constructor() {\n    super(\n      \"BuildScripts\",\n      Object.assign({}, DefaultCommandOptions, options) as CommandOptions<\n        typeof options\n      >\n    );\n    const pkg = getPackage() as { name: string; version: string };\n    const { name, version } = pkg;\n    this.pkgName = name.includes(\"@\") ? name.split(\"/\")[1] : name;\n    this.pkgVersion = version;\n    this.replacements[VERSION_STRING] = this.pkgVersion;\n    this.replacements[PACKAGE_STRING] = name;\n  }\n\n  patchFiles(p: string) {\n    const log = this.log.for(this.patchFiles);\n    const { name, version } = getPackage() as any;\n    log.info(`Patching ${name} ${version} module in ${p}...`);\n    const stat = fs.statSync(p);\n    if (stat.isDirectory())\n      fs.readdirSync(p, { withFileTypes: true, recursive: true })\n        .filter((p) => p.isFile())\n        .forEach((file) =>\n          patchFile(path.join(file.parentPath, file.name), this.replacements)\n        );\n    log.verbose(`Module ${name} ${version} patched in ${p}...`);\n  }\n\n  private reportDiagnostics(\n    diagnostics: Diagnostic[],\n    logLevel: LogLevel\n  ): string {\n    const msg = this.formatDiagnostics(diagnostics);\n    if (!Object.values(LogLevel).includes(logLevel))\n      throw new Error(`Invalid LogLevel ${logLevel}`);\n    try {\n      this.log[logLevel](msg);\n    } catch (e: unknown) {\n      console.warn(`Failed to get logger for ${logLevel}`);\n      throw e;\n    }\n    return msg;\n  }\n\n  // Format diagnostics into a single string for throwing or logging\n  private formatDiagnostics(diagnostics: Diagnostic[]): string {\n    return diagnostics\n      .map((diagnostic) => {\n        let message = \"\";\n        if (diagnostic.file && diagnostic.start) {\n          const { line, character } =\n            diagnostic.file.getLineAndCharacterOfPosition(diagnostic.start);\n          message += `${diagnostic.file.fileName} (${line + 1},${character + 1})`;\n        }\n        message +=\n          \": \" + ts.flattenDiagnosticMessageText(diagnostic.messageText, \"\\n\");\n        return message;\n      })\n      .join(\"\\n\");\n  }\n\n  private readConfigFile(configFileName: string) {\n    // Read config file\n    const configFileText = fs.readFileSync(configFileName).toString();\n\n    // Parse JSON, after removing comments. Just fancier JSON.parse\n    const result = ts.parseConfigFileTextToJson(configFileName, configFileText);\n    const configObject = result.config;\n    if (!configObject) {\n      this.reportDiagnostics([result.error!], LogLevel.error);\n    }\n\n    // Extract config infromation\n    const configParseResult = ts.parseJsonConfigFileContent(\n      configObject,\n      ts.sys,\n      path.dirname(configFileName)\n    );\n    if (configParseResult.errors.length > 0)\n      this.reportDiagnostics(configParseResult.errors, LogLevel.error);\n\n    return configParseResult;\n  }\n\n  private evalDiagnostics(diagnostics: Diagnostic[]) {\n    if (diagnostics && diagnostics.length > 0) {\n      const errors = diagnostics.filter(\n        (d) => d.category === ts.DiagnosticCategory.Error\n      );\n      const warnings = diagnostics.filter(\n        (d) => d.category === ts.DiagnosticCategory.Warning\n      );\n      const suggestions = diagnostics.filter(\n        (d) => d.category === ts.DiagnosticCategory.Suggestion\n      );\n      const messages = diagnostics.filter(\n        (d) => d.category === ts.DiagnosticCategory.Message\n      );\n      // Log diagnostics to console\n\n      if (warnings.length) this.reportDiagnostics(warnings, LogLevel.info);\n      if (errors.length) {\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        const formatted = this.reportDiagnostics(\n          diagnostics as Diagnostic[],\n          LogLevel.error\n        );\n        this.log.info(\n          `TypeScript reported ${diagnostics.length} diagnostic(s) during check; aborting.`\n        );\n        // throw new Error(\n        //   `TypeScript reported ${diagnostics.length} diagnostic(s) during check; aborting.`\n        // );\n      }\n      if (suggestions.length)\n        this.reportDiagnostics(suggestions, LogLevel.info);\n      if (messages.length) this.reportDiagnostics(messages, LogLevel.info);\n    }\n  }\n\n  private preCheckDiagnostics(program: ts.Program) {\n    const diagnostics = ts.getPreEmitDiagnostics(program);\n    this.evalDiagnostics(diagnostics as any);\n  }\n\n  // Create a TypeScript program for the current tsconfig and fail if there are any error diagnostics.\n  private async checkTsDiagnostics(\n    isDev: boolean,\n    mode: Modes,\n    bundle = false\n  ) {\n    const log = this.log.for(this.checkTsDiagnostics);\n    let tsConfig;\n    try {\n      tsConfig = this.readConfigFile(\"./tsconfig.json\");\n    } catch (e: unknown) {\n      throw new Error(`Failed to parse tsconfig.json: ${e}`);\n    }\n\n    if (bundle) {\n      tsConfig.options.module = ModuleKind.AMD;\n      tsConfig.options.outDir = \"dist\";\n      tsConfig.options.isolatedModules = false;\n      tsConfig.options.outFile = this.pkgName;\n    } else {\n      tsConfig.options.outDir = `lib${mode === Modes.ESM ? \"/esm\" : \"\"}`;\n      tsConfig.options.module =\n        mode === Modes.ESM ? ModuleKind.ES2022 : ModuleKind.CommonJS;\n    }\n\n    if (isDev) {\n      tsConfig.options.inlineSourceMap = true;\n      tsConfig.options.sourceMap = false;\n    } else {\n      tsConfig.options.sourceMap = false;\n    }\n\n    const program = ts.createProgram(tsConfig.fileNames, tsConfig.options);\n    this.preCheckDiagnostics(program);\n    log.verbose(\n      `TypeScript checks passed (${bundle ? \"bundle\" : \"normal\"} mode).`\n    );\n  }\n\n  private async buildTs(isDev: boolean, mode: Modes, bundle = false) {\n    const log = this.log.for(this.buildTs);\n    log.info(\n      `Building ${this.pkgName} ${this.pkgVersion} module (${mode}) in ${isDev ? \"dev\" : \"prod\"} mode...`\n    );\n    let tsConfig;\n    try {\n      tsConfig = this.readConfigFile(\"./tsconfig.json\");\n    } catch (e: unknown) {\n      throw new Error(`Failed to parse tsconfig.json: ${e}`);\n    }\n\n    if (bundle) {\n      tsConfig.options.module = ModuleKind.AMD;\n      tsConfig.options.outDir = \"dist\";\n      tsConfig.options.isolatedModules = false;\n      tsConfig.options.outFile = this.pkgName;\n    } else {\n      tsConfig.options.outDir = `lib${mode === Modes.ESM ? \"/esm\" : \"\"}`;\n      tsConfig.options.module =\n        mode === Modes.ESM ? ModuleKind.ES2022 : ModuleKind.CommonJS;\n    }\n\n    if (isDev) {\n      tsConfig.options.inlineSourceMap = true;\n      tsConfig.options.sourceMap = false;\n    } else {\n      tsConfig.options.sourceMap = false;\n    }\n\n    const program = ts.createProgram(tsConfig.fileNames, tsConfig.options);\n\n    const transformations: { before?: any[] } = {};\n    if (mode === Modes.CJS) {\n      transformations.before = [cjs2Transformer(\".cjs\")];\n    } else if (mode === Modes.ESM) {\n      transformations.before = [cjs2Transformer(\".js\")];\n    }\n\n    const emitResult: EmitResult = program.emit(\n      undefined,\n      undefined,\n      undefined,\n      undefined,\n      transformations\n    );\n\n    const allDiagnostics = ts\n      .getPreEmitDiagnostics(program)\n      .concat(emitResult.diagnostics);\n\n    this.evalDiagnostics(allDiagnostics);\n  }\n\n  private async build(isDev: boolean, mode: Modes, bundle = false) {\n    const log = this.log.for(this.build);\n    await this.buildTs(isDev, mode, bundle);\n\n    log.verbose(\n      `Module ${this.pkgName} ${this.pkgVersion} (${mode}) built in ${isDev ? \"dev\" : \"prod\"} mode...`\n    );\n    if (mode === Modes.CJS && !bundle) {\n      const files = getAllFiles(\n        \"lib\",\n        (file) => file.endsWith(\".js\") && !file.includes(\"/esm/\")\n      );\n\n      for (const file of files) {\n        log.verbose(`Patching ${file}'s cjs imports...`);\n        const f = file.replace(\".js\", \".cjs\");\n        await renameFile(file, f);\n      }\n    }\n  }\n\n  copyAssets(mode: Modes) {\n    const log = this.log.for(this.copyAssets);\n    let hasAssets = false;\n    try {\n      hasAssets = fs.statSync(\"./src/assets\").isDirectory();\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      return log.verbose(`No assets found in ./src/assets to copy`);\n    }\n    if (hasAssets)\n      copyFile(\n        \"./src/assets\",\n        `./${mode === Modes.CJS ? \"lib\" : \"dist\"}/assets`\n      );\n  }\n\n  async bundle(\n    mode: Modes,\n    isDev: boolean,\n    isLib: boolean,\n    entryFile: string = \"src/index.ts\",\n    nameOverride: string = this.pkgName,\n    externalsArg?: string | string[],\n    includeArg: string | string[] = [\n      \"prompts\",\n      \"styled-string-builder\",\n      \"typed-object-accumulator\",\n      \"@decaf-ts/logging\",\n    ]\n  ) {\n    // Run a TypeScript-only diagnostic check for the bundling configuration and fail fast on any errors.\n    await this.checkTsDiagnostics(isDev, mode, true);\n    const isEsm = mode === Modes.ESM;\n    const pkgName = this.pkgName;\n\n    // normalize include and externals\n    const include = Array.from(\n      new Set([...(parseList(includeArg) as string[])])\n    );\n    let externalsList = parseList(externalsArg);\n    if (externalsList.length === 0) {\n      // if no externals specified, include package.json dependencies to avoid rollup treating them as resolvable\n      externalsList = getPackageDependencies();\n    }\n\n    const ext = Array.from(\n      new Set([\n        // builtins and always external runtime deps\n        ...(function builtinList(): string[] {\n          try {\n            return (\n              Array.isArray(builtinModules) ? builtinModules : []\n            ) as string[];\n          } catch {\n            // fallback to a reasonable subset if `builtinModules` is unavailable\n            return [\n              \"fs\",\n              \"path\",\n              \"process\",\n              \"child_process\",\n              \"util\",\n              \"https\",\n              \"http\",\n              \"os\",\n              \"stream\",\n              \"crypto\",\n              \"zlib\",\n              \"net\",\n              \"tls\",\n              \"url\",\n              \"querystring\",\n              \"assert\",\n              \"events\",\n              \"tty\",\n              \"dns\",\n              \"querystring\",\n            ];\n          }\n        })(),\n        ...externalsList,\n      ])\n    );\n\n    const plugins = [\n      typescript({\n        compilerOptions: {\n          module: \"esnext\",\n          declaration: false,\n          outDir: isLib ? \"bin\" : \"dist\",\n        },\n        include: [\"src/**/*.ts\"],\n        exclude: [\"node_modules\", \"**/*.spec.ts\"],\n        tsconfig: \"./tsconfig.json\",\n      }),\n      json(),\n    ];\n\n    // production minification\n    if (!isDev) {\n      // terser is optional at runtime; import lazily inside bundle to avoid test-time resolution errors\n      try {\n        const terserMod: any = await import(\"@rollup/plugin-terser\");\n        const terserFn =\n          (terserMod && terserMod.terser) || terserMod.default || terserMod;\n        plugins.push(terserFn());\n      } catch {\n        // if terser isn't available, ignore\n      }\n    }\n\n    if (isLib) {\n      plugins.push(\n        commonjs({\n          include: [],\n          exclude: externalsList,\n        }),\n        nodeResolve({\n          resolveOnly: include,\n        })\n      );\n    }\n\n    const input: InputOptions = {\n      input: entryFile,\n      plugins: plugins,\n      external: ext,\n    };\n\n    // prepare output globals mapping for externals\n    const globals: Record<string, string> = {};\n    // include all externals and builtins (ext) so Rollup won't guess names for builtins\n    ext.forEach((e) => {\n      globals[e] = packageToGlobal(e);\n    });\n\n    const outputs: OutputOptions[] = [\n      {\n        file: `${isLib ? \"bin/\" : \"dist/\"}${nameOverride ? nameOverride : `.bundle.${!isDev ? \"min\" : \"\"}`}${isEsm ? \".esm\" : \"\"}.cjs`,\n        format: isLib ? \"cjs\" : isEsm ? \"esm\" : \"umd\",\n        name: pkgName,\n        esModule: isEsm,\n        sourcemap: isDev ? \"inline\" : false,\n        globals: globals,\n        exports: \"auto\",\n      },\n    ];\n\n    try {\n      const bundle = await rollup(input);\n      console.log(bundle.watchFiles);\n      async function generateOutputs(bundle: RollupBuild) {\n        for (const outputOptions of outputs) {\n          await bundle.write(outputOptions);\n        }\n      }\n\n      await generateOutputs(bundle);\n    } catch (e: unknown) {\n      throw new Error(`Failed to bundle: ${e}`);\n    }\n  }\n\n  private async buildByEnv(\n    isDev: boolean,\n    mode: BuildMode = BuildMode.ALL,\n    includesArg?: string | string[],\n    externalsArg?: string | string[]\n  ) {\n    // note: includes and externals will be passed through from run() into this method by callers\n    try {\n      deletePath(\"lib\");\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      // do nothing\n    }\n    try {\n      deletePath(\"dist\");\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      // do nothing\n    }\n    fs.mkdirSync(\"lib\");\n    fs.mkdirSync(\"dist\");\n\n    if ([BuildMode.ALL, BuildMode.BUILD].includes(mode)) {\n      await this.build(isDev, Modes.ESM);\n      await this.build(isDev, Modes.CJS);\n      this.patchFiles(\"lib\");\n    }\n\n    if ([BuildMode.ALL, BuildMode.BUNDLE].includes(mode)) {\n      await this.bundle(\n        Modes.ESM,\n        isDev,\n        false,\n        \"src/index.ts\",\n        this.pkgName,\n        externalsArg,\n        includesArg\n      );\n      await this.bundle(\n        Modes.CJS,\n        isDev,\n        false,\n        \"src/index.ts\",\n        this.pkgName,\n        externalsArg,\n        includesArg\n      );\n      this.patchFiles(\"dist\");\n    }\n\n    this.copyAssets(Modes.CJS);\n    this.copyAssets(Modes.ESM);\n  }\n\n  async buildDev(\n    mode: BuildMode = BuildMode.ALL,\n    includesArg?: string | string[],\n    externalsArg?: string | string[]\n  ) {\n    return this.buildByEnv(true, mode, includesArg, externalsArg);\n  }\n\n  async buildProd(\n    mode: BuildMode = BuildMode.ALL,\n    includesArg?: string | string[],\n    externalsArg?: string | string[]\n  ) {\n    return this.buildByEnv(false, mode, includesArg, externalsArg);\n  }\n\n  async buildDocs() {\n    await runCommand(`npm install better-docs taffydb`).promise;\n    await runCommand(`npx markdown-include ./workdocs/readme-md.json`).promise;\n    await runCommand(\n      `npx jsdoc -c ./workdocs/jsdocs.json -t ./node_modules/better-docs`\n    ).promise;\n    await runCommand(`npm remove better-docs taffydb`).promise;\n    [\n      {\n        src: \"workdocs/assets\",\n        dest: \"./docs/workdocs/assets\",\n      },\n      {\n        src: \"workdocs/reports/coverage\",\n        dest: \"./docs/workdocs/reports/coverage\",\n      },\n      {\n        src: \"workdocs/reports/html\",\n        dest: \"./docs/workdocs/reports/html\",\n      },\n      {\n        src: \"workdocs/resources\",\n        dest: \"./docs/workdocs/resources\",\n      },\n      {\n        src: \"LICENSE.md\",\n        dest: \"./docs/LICENSE.md\",\n      },\n    ].forEach((f) => {\n      const { src, dest } = f;\n      copyFile(src, dest);\n    });\n  }\n\n  protected async run<R>(\n    answers: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof options]: unknown }\n  ): Promise<string | void | R> {\n    const { dev, prod, docs, buildMode, includes, externals } = answers as any;\n    if (dev) {\n      return await this.buildDev(buildMode as BuildMode, includes, externals);\n    }\n    if (prod) {\n      return await this.buildProd(buildMode as BuildMode, includes, externals);\n    }\n    if (docs) {\n      return await this.buildDocs();\n    }\n  }\n}\n"]}