@xylabs/ts-scripts-yarn3 7.0.0 → 7.0.2

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.
Files changed (53) hide show
  1. package/dist/actions/deplint/checkPackage/checkPackage.mjs +11 -1
  2. package/dist/actions/deplint/checkPackage/checkPackage.mjs.map +1 -1
  3. package/dist/actions/deplint/checkPackage/index.mjs +11 -1
  4. package/dist/actions/deplint/checkPackage/index.mjs.map +1 -1
  5. package/dist/actions/deplint/deplint.mjs +33 -21
  6. package/dist/actions/deplint/deplint.mjs.map +1 -1
  7. package/dist/actions/deplint/index.mjs +33 -21
  8. package/dist/actions/deplint/index.mjs.map +1 -1
  9. package/dist/actions/index.mjs +132 -108
  10. package/dist/actions/index.mjs.map +1 -1
  11. package/dist/actions/package/compile/compile.mjs +25 -74
  12. package/dist/actions/package/compile/compile.mjs.map +1 -1
  13. package/dist/actions/package/compile/index.mjs +25 -74
  14. package/dist/actions/package/compile/index.mjs.map +1 -1
  15. package/dist/actions/package/compile/packageCompileTsc.mjs.map +1 -1
  16. package/dist/actions/package/compile/packageCompileTsup.mjs.map +1 -1
  17. package/dist/actions/package/gen-docs.mjs +1 -1
  18. package/dist/actions/package/gen-docs.mjs.map +1 -1
  19. package/dist/actions/package/index.mjs +96 -84
  20. package/dist/actions/package/index.mjs.map +1 -1
  21. package/dist/actions/package/publint.mjs +27 -10
  22. package/dist/actions/package/publint.mjs.map +1 -1
  23. package/dist/actions/package/recompile.mjs +25 -74
  24. package/dist/actions/package/recompile.mjs.map +1 -1
  25. package/dist/actions/publint.mjs +3 -3
  26. package/dist/actions/publint.mjs.map +1 -1
  27. package/dist/bin/package/build-only.mjs +27 -76
  28. package/dist/bin/package/build-only.mjs.map +1 -1
  29. package/dist/bin/package/build.mjs +27 -76
  30. package/dist/bin/package/build.mjs.map +1 -1
  31. package/dist/bin/package/compile-only.mjs +27 -76
  32. package/dist/bin/package/compile-only.mjs.map +1 -1
  33. package/dist/bin/package/compile-tsup.mjs.map +1 -1
  34. package/dist/bin/package/compile.mjs +27 -76
  35. package/dist/bin/package/compile.mjs.map +1 -1
  36. package/dist/bin/package/gen-docs.mjs +1 -1
  37. package/dist/bin/package/gen-docs.mjs.map +1 -1
  38. package/dist/bin/package/publint.mjs +27 -10
  39. package/dist/bin/package/publint.mjs.map +1 -1
  40. package/dist/bin/package/recompile.mjs +27 -76
  41. package/dist/bin/package/recompile.mjs.map +1 -1
  42. package/dist/bin/xy.mjs +38 -25
  43. package/dist/bin/xy.mjs.map +1 -1
  44. package/dist/index.d.ts +125 -96
  45. package/dist/index.mjs +134 -109
  46. package/dist/index.mjs.map +1 -1
  47. package/dist/xy/index.mjs +38 -25
  48. package/dist/xy/index.mjs.map +1 -1
  49. package/dist/xy/xy.mjs +38 -25
  50. package/dist/xy/xy.mjs.map +1 -1
  51. package/dist/xy/xyLintCommands.mjs +38 -25
  52. package/dist/xy/xyLintCommands.mjs.map +1 -1
  53. package/package.json +12 -14
@@ -87,58 +87,14 @@ var packageClean = /* @__PURE__ */ __name(async () => {
87
87
  }, "packageClean");
88
88
 
89
89
  // src/actions/package/compile/compile.ts
90
- import chalk9 from "chalk";
91
-
92
- // src/actions/package/publint.ts
93
- import { promises as fs2 } from "fs";
94
- import chalk4 from "chalk";
95
- import sortPackageJson from "sort-package-json";
96
- var packagePublint = /* @__PURE__ */ __name(async (params) => {
97
- const pkgDir = process.env.INIT_CWD;
98
- const sortedPkg = sortPackageJson(await fs2.readFile(`${pkgDir}/package.json`, "utf8"));
99
- await fs2.writeFile(`${pkgDir}/package.json`, sortedPkg);
100
- const pkg = JSON.parse(await fs2.readFile(`${pkgDir}/package.json`, "utf8"));
101
- console.log(chalk4.green(`Publint: ${pkg.name}`));
102
- console.log(chalk4.gray(pkgDir));
103
- const { publint } = await import("publint");
104
- const { messages } = await publint({
105
- level: "suggestion",
106
- pkgDir,
107
- strict: true
108
- });
109
- const { formatMessage } = await import("publint/utils");
110
- const validMessage = /* @__PURE__ */ __name((_message) => {
111
- return true;
112
- }, "validMessage");
113
- const validMessages = messages.filter(validMessage);
114
- for (const message of validMessages) {
115
- switch (message.type) {
116
- case "error": {
117
- console.error(chalk4.red(`[${message.code}] ${formatMessage(message, pkg)}`));
118
- break;
119
- }
120
- case "warning": {
121
- console.warn(chalk4.yellow(`[${message.code}] ${formatMessage(message, pkg)}`));
122
- break;
123
- }
124
- default: {
125
- console.log(chalk4.white(`[${message.code}] ${formatMessage(message, pkg)}`));
126
- break;
127
- }
128
- }
129
- }
130
- if (params?.verbose) {
131
- console.log(chalk4.gray(`Publint [Finish]: ${pkgDir} [${validMessages.length}]`));
132
- }
133
- return validMessages.filter((message) => message.type === "error").length;
134
- }, "packagePublint");
90
+ import chalk8 from "chalk";
135
91
 
136
92
  // src/actions/package/compile/packageCompileTsup.ts
137
- import chalk8 from "chalk";
93
+ import chalk7 from "chalk";
138
94
  import { build, defineConfig } from "tsup";
139
95
 
140
96
  // src/actions/package/compile/inputs.ts
141
- import chalk5 from "chalk";
97
+ import chalk4 from "chalk";
142
98
  import { glob as glob2 } from "glob";
143
99
  var getAllInputs = /* @__PURE__ */ __name((srcDir, verbose = false) => {
144
100
  return [
@@ -147,7 +103,7 @@ var getAllInputs = /* @__PURE__ */ __name((srcDir, verbose = false) => {
147
103
  }).map((file) => {
148
104
  const result = file.slice(Math.max(0, srcDir.length + 1));
149
105
  if (verbose) {
150
- console.log(chalk5.gray(`getAllInputs: ${JSON.stringify(result, null, 2)}`));
106
+ console.log(chalk4.gray(`getAllInputs: ${JSON.stringify(result, null, 2)}`));
151
107
  }
152
108
  return result;
153
109
  }),
@@ -156,7 +112,7 @@ var getAllInputs = /* @__PURE__ */ __name((srcDir, verbose = false) => {
156
112
  }).map((file) => {
157
113
  const result = file.slice(Math.max(0, srcDir.length + 1));
158
114
  if (verbose) {
159
- console.log(chalk5.gray(`getAllInputs: ${JSON.stringify(result, null, 2)}`));
115
+ console.log(chalk4.gray(`getAllInputs: ${JSON.stringify(result, null, 2)}`));
160
116
  }
161
117
  return result;
162
118
  })
@@ -223,7 +179,7 @@ __name(deepMergeObjects, "deepMergeObjects");
223
179
 
224
180
  // src/actions/package/compile/packageCompileTsc.ts
225
181
  import { cwd as cwd2 } from "process";
226
- import chalk6 from "chalk";
182
+ import chalk5 from "chalk";
227
183
  import { createProgramFromConfig } from "tsc-prog";
228
184
  import ts, { DiagnosticCategory, formatDiagnosticsWithColorAndContext, getPreEmitDiagnostics, sys } from "typescript";
229
185
 
@@ -240,7 +196,7 @@ var getCompilerOptions = /* @__PURE__ */ __name((options = {}, fileName = "tscon
240
196
  var packageCompileTsc = /* @__PURE__ */ __name((platform, entries, srcDir = "src", outDir = "dist", compilerOptionsParam, verbose = false) => {
241
197
  const pkg = process.env.INIT_CWD ?? cwd2();
242
198
  if (verbose) {
243
- console.log(chalk6.cyan(`Validating code START: ${entries.length} files to ${outDir} from ${srcDir}`));
199
+ console.log(chalk5.cyan(`Validating code START: ${entries.length} files to ${outDir} from ${srcDir}`));
244
200
  }
245
201
  const configFilePath = ts.findConfigFile("./", ts.sys.fileExists, "tsconfig.json");
246
202
  if (configFilePath === void 0) {
@@ -258,10 +214,10 @@ var packageCompileTsc = /* @__PURE__ */ __name((platform, entries, srcDir = "src
258
214
  emitDeclarationOnly: true,
259
215
  noEmit: false
260
216
  };
261
- console.log(chalk6.cyan(`Validating Files: ${entries.length}`));
217
+ console.log(chalk5.cyan(`Validating Files: ${entries.length}`));
262
218
  if (verbose) {
263
219
  for (const entry of entries) {
264
- console.log(chalk6.grey(`Validating: ${entry}`));
220
+ console.log(chalk5.grey(`Validating: ${entry}`));
265
221
  }
266
222
  }
267
223
  try {
@@ -290,7 +246,7 @@ var packageCompileTsc = /* @__PURE__ */ __name((platform, entries, srcDir = "src
290
246
  return 0;
291
247
  } finally {
292
248
  if (verbose) {
293
- console.log(chalk6.cyan(`Validating code FINISH: ${entries.length} files to ${outDir} from ${srcDir}`));
249
+ console.log(chalk5.cyan(`Validating code FINISH: ${entries.length} files to ${outDir} from ${srcDir}`));
294
250
  }
295
251
  }
296
252
  }, "packageCompileTsc");
@@ -298,7 +254,7 @@ var packageCompileTsc = /* @__PURE__ */ __name((platform, entries, srcDir = "src
298
254
  // src/actions/package/compile/packageCompileTscTypes.ts
299
255
  import path3 from "path";
300
256
  import { cwd as cwd3 } from "process";
301
- import chalk7 from "chalk";
257
+ import chalk6 from "chalk";
302
258
  import { rollup } from "rollup";
303
259
  import dts from "rollup-plugin-dts";
304
260
  import nodeExternals from "rollup-plugin-node-externals";
@@ -331,8 +287,8 @@ async function bundleDts(inputPath, outputPath, platform, options, verbose = fal
331
287
  if (ignoredWarningCodes.has(warning.code ?? "")) {
332
288
  return;
333
289
  }
334
- console.warn(chalk7.yellow(`[${warning.code}] ${warning.message}`));
335
- console.warn(chalk7.gray(inputPath));
290
+ console.warn(chalk6.yellow(`[${warning.code}] ${warning.message}`));
291
+ console.warn(chalk6.gray(inputPath));
336
292
  warn(warning);
337
293
  }
338
294
  });
@@ -342,8 +298,8 @@ async function bundleDts(inputPath, outputPath, platform, options, verbose = fal
342
298
  });
343
299
  } catch (ex) {
344
300
  const error = ex;
345
- console.warn(chalk7.red(error));
346
- console.warn(chalk7.gray(inputPath));
301
+ console.warn(chalk6.red(error));
302
+ console.warn(chalk6.gray(inputPath));
347
303
  }
348
304
  if (verbose) {
349
305
  console.log(`Bundled declarations written to ${outputPath}`);
@@ -352,7 +308,7 @@ async function bundleDts(inputPath, outputPath, platform, options, verbose = fal
352
308
  __name(bundleDts, "bundleDts");
353
309
  var packageCompileTscTypes = /* @__PURE__ */ __name(async (entries, outDir, platform, srcDir = "build", verbose = false) => {
354
310
  if (verbose) {
355
- console.log(chalk7.cyan(`Compiling Types START [${platform}]: ${entries.length} files to ${outDir} from ${srcDir}`));
311
+ console.log(chalk6.cyan(`Compiling Types START [${platform}]: ${entries.length} files to ${outDir} from ${srcDir}`));
356
312
  console.log(`Entries: ${entries.join(", ")}`);
357
313
  }
358
314
  const pkg = process.env.INIT_CWD ?? cwd3();
@@ -381,7 +337,7 @@ var packageCompileTscTypes = /* @__PURE__ */ __name(async (entries, outDir, plat
381
337
  }, verbose);
382
338
  }));
383
339
  if (verbose) {
384
- console.log(chalk7.cyan(`Compiling Types FINISH: ${entries.length} files to ${outDir} from ${srcDir}`));
340
+ console.log(chalk6.cyan(`Compiling Types FINISH: ${entries.length} files to ${outDir} from ${srcDir}`));
385
341
  }
386
342
  return 0;
387
343
  }, "packageCompileTscTypes");
@@ -393,15 +349,15 @@ var compileFolder = /* @__PURE__ */ __name(async (srcDir, entries, buildDir, opt
393
349
  console.log(`compileFolder [${srcDir}, ${options?.outDir}]`);
394
350
  }
395
351
  if (entries.length === 0) {
396
- console.warn(chalk8.yellow(`No entries found in ${srcDir} to compile`));
352
+ console.warn(chalk7.yellow(`No entries found in ${srcDir} to compile`));
397
353
  return 0;
398
354
  }
399
355
  if (verbose) {
400
- console.log(chalk8.gray(`buildDir [${buildDir}]`));
356
+ console.log(chalk7.gray(`buildDir [${buildDir}]`));
401
357
  }
402
358
  const validationResult = packageCompileTsc(options?.platform ?? "neutral", entries, srcDir, buildDir, void 0, verbose);
403
359
  if (validationResult !== 0) {
404
- console.error(chalk8.red(`Compile:Validation had ${validationResult} errors`));
360
+ console.error(chalk7.red(`Compile:Validation had ${validationResult} errors`));
405
361
  return validationResult;
406
362
  }
407
363
  const optionsParams = tsupOptions([
@@ -434,12 +390,12 @@ var compileFolder = /* @__PURE__ */ __name(async (srcDir, entries, buildDir, opt
434
390
  ];
435
391
  }))).flat();
436
392
  if (verbose) {
437
- console.log(chalk8.cyan(`TSUP:build:start [${srcDir}]`));
438
- console.log(chalk8.gray(`TSUP:build:options [${JSON.stringify(optionsList, null, 2)}]`));
393
+ console.log(chalk7.cyan(`TSUP:build:start [${srcDir}]`));
394
+ console.log(chalk7.gray(`TSUP:build:options [${JSON.stringify(optionsList, null, 2)}]`));
439
395
  }
440
396
  await Promise.all(optionsList.map((options2) => build(options2)));
441
397
  if (verbose) {
442
- console.log(chalk8.cyan(`TSUP:build:stop [${srcDir}]`));
398
+ console.log(chalk7.cyan(`TSUP:build:stop [${srcDir}]`));
443
399
  }
444
400
  if (bundleTypes) {
445
401
  await packageCompileTscTypes(entries, outDir, options?.platform ?? "neutral", buildDir, verbose);
@@ -547,14 +503,9 @@ var packageCompileTsup = /* @__PURE__ */ __name(async (config2) => {
547
503
  // src/actions/package/compile/compile.ts
548
504
  var packageCompile = /* @__PURE__ */ __name(async (inConfig = {}) => {
549
505
  const pkg = process.env.INIT_CWD;
550
- console.log(chalk9.green(`Compiling ${pkg}`));
506
+ console.log(chalk8.green(`Compiling ${pkg}`));
551
507
  const config2 = await loadConfig(inConfig);
552
- const publint = config2.publint;
553
- const tsupResults = await packageCompileTsup(config2);
554
- if (tsupResults > 0) {
555
- return tsupResults;
556
- }
557
- return publint ? await packagePublint(config2) : 0;
508
+ return await packageCompileTsup(config2);
558
509
  }, "packageCompile");
559
510
 
560
511
  // src/actions/package/recompile.ts
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/actions/package/clean-outputs.ts","../../../src/lib/deleteGlob.ts","../../../src/lib/loadConfig.ts","../../../src/actions/package/clean-typescript.ts","../../../src/actions/package/clean.ts","../../../src/actions/package/compile/compile.ts","../../../src/actions/package/publint.ts","../../../src/actions/package/compile/packageCompileTsup.ts","../../../src/actions/package/compile/inputs.ts","../../../src/actions/package/compile/buildEntries.ts","../../../src/actions/package/compile/deepMerge.ts","../../../src/actions/package/compile/packageCompileTsc.ts","../../../src/actions/package/compile/getCompilerOptions.ts","../../../src/actions/package/compile/packageCompileTscTypes.ts","../../../src/actions/package/recompile.ts"],"sourcesContent":["import path from 'node:path'\n\nimport chalk from 'chalk'\n\nimport { deleteGlob } from '../../lib/index.ts'\n\nexport const packageCleanOutputs = () => {\n const pkg = process.env.INIT_CWD ?? '.'\n const pkgName = process.env.npm_package_name\n const folders: string[] = [path.join(pkg, 'dist'), path.join(pkg, 'build'), path.join(pkg, 'docs')]\n console.log(chalk.green(`Cleaning Outputs [${pkgName}]`))\n\n for (let folder of folders) {\n deleteGlob(folder)\n }\n\n return 0\n}\n","import fs from 'node:fs'\n\nimport { glob } from 'glob'\n\nexport const deleteGlob = (globPath: string) => {\n // Find all files matching the glob pattern\n const files = glob.sync(globPath)\n\n // Remove each file or directory\n for (const file of files) {\n fs.rmSync(file, { recursive: true, force: true })\n }\n}\n","import chalk from 'chalk'\nimport { cosmiconfig } from 'cosmiconfig'\nimport { TypeScriptLoader } from 'cosmiconfig-typescript-loader'\nimport deepmerge from 'deepmerge'\n\nlet config: Record<string, unknown>\n\nexport const loadConfig = async <T extends object>(params?: T): Promise<T> => {\n if (config === undefined) {\n const cosmicConfigResult = await cosmiconfig('xy', { cache: true, loaders: { '.ts': TypeScriptLoader() } }).search()\n config = cosmicConfigResult?.config\n const configFilePath = cosmicConfigResult?.filepath\n if (configFilePath !== undefined) {\n console.log(chalk.green(`Loaded config from ${configFilePath}`))\n if (config.verbose) {\n console.log(chalk.gray(`${JSON.stringify(config, null, 2)}`))\n }\n }\n }\n return deepmerge(config, params ?? {}) as T\n}\n","import path from 'node:path'\n\nimport chalk from 'chalk'\n\nimport { deleteGlob } from '../../lib/index.ts'\n\nexport const packageCleanTypescript = () => {\n const pkg = process.env.INIT_CWD ?? '.'\n const pkgName = process.env.npm_package_name\n console.log(chalk.green(`Cleaning Typescript [${pkgName}]`))\n const files: string[] = [path.join(pkg, '*.tsbuildinfo'), path.join(pkg, '.tsconfig.*'), path.join(pkg, '.eslintcache')]\n\n for (let file of files) {\n deleteGlob(file)\n }\n\n return 0\n}\n","import { packageCleanOutputs } from './clean-outputs.ts'\nimport { packageCleanTypescript } from './clean-typescript.ts'\n\nexport const packageClean = async () => {\n return (await Promise.all([packageCleanOutputs(), packageCleanTypescript()])).reduce((prev, value) => prev + value, 0)\n}\n","import chalk from 'chalk'\n\nimport { loadConfig } from '../../../lib/index.ts'\nimport { packagePublint } from '../publint.ts'\nimport { packageCompileTsup } from './packageCompileTsup.ts'\nimport type { XyConfig } from './XyConfig.ts'\n\nexport const packageCompile = async (inConfig: XyConfig = {}): Promise<number> => {\n const pkg = process.env.INIT_CWD\n console.log(chalk.green(`Compiling ${pkg}`))\n const config = await loadConfig(inConfig)\n const publint = config.publint\n\n const tsupResults = await packageCompileTsup(config)\n\n if (tsupResults > 0) {\n return tsupResults\n }\n\n return (publint ? await packagePublint(config) : 0)\n}\n","import { promises as fs } from 'node:fs'\n\nimport chalk from 'chalk'\nimport type { Message } from 'publint'\nimport sortPackageJson from 'sort-package-json'\n\nexport interface PackagePublintParams { verbose?: boolean }\n\nexport const packagePublint = async (params?: PackagePublintParams) => {\n const pkgDir = process.env.INIT_CWD\n\n const sortedPkg = sortPackageJson(await fs.readFile(`${pkgDir}/package.json`, 'utf8'))\n await fs.writeFile(`${pkgDir}/package.json`, sortedPkg)\n\n const pkg = JSON.parse(await fs.readFile(`${pkgDir}/package.json`, 'utf8'))\n\n console.log(chalk.green(`Publint: ${pkg.name}`))\n console.log(chalk.gray(pkgDir))\n\n const { publint } = await import('publint')\n\n const { messages } = await publint({\n level: 'suggestion',\n pkgDir,\n strict: true,\n })\n\n // eslint-disable-next-line import-x/no-internal-modules\n const { formatMessage } = await import('publint/utils')\n\n const validMessage = (_message: Message): boolean => {\n return true\n /* try {\n const value = getValueFromPath(pkg, message.path)\n switch (message.code) {\n case 'FILE_INVALID_FORMAT':\n return !message.args?.actualFilePath?.includes('dist/browser') && !value?.includes('dist/browser')\n case 'EXPORT_TYPES_INVALID_FORMAT':\n return !`${value}`.includes('dist/browser')\n default:\n return true\n }\n } catch (ex) {\n const error = ex as Error\n console.error(chalk.red(`validMessage Excepted: ${error.message}`))\n console.error(chalk.gray(JSON.stringify(error.stack)))\n return true\n } */\n }\n\n // we filter out invalid file formats for the esm folder since it is intentionally done\n const validMessages = messages.filter(validMessage)\n for (const message of validMessages) {\n switch (message.type) {\n case 'error': {\n console.error(chalk.red(`[${message.code}] ${formatMessage(message, pkg)}`))\n break\n }\n case 'warning': {\n console.warn(chalk.yellow(`[${message.code}] ${formatMessage(message, pkg)}`))\n break\n }\n default: {\n console.log(chalk.white(`[${message.code}] ${formatMessage(message, pkg)}`))\n break\n }\n }\n }\n\n if (params?.verbose) {\n console.log(chalk.gray(`Publint [Finish]: ${pkgDir} [${validMessages.length}]`))\n }\n\n return validMessages.filter(message => message.type === 'error').length\n}\n","import chalk from 'chalk'\nimport type { Loader } from 'esbuild'\nimport type { Options } from 'tsup'\nimport { build, defineConfig } from 'tsup'\n\nimport { buildEntries } from './buildEntries.ts'\nimport { deepMergeObjects } from './deepMerge.ts'\nimport { packageCompileTsc } from './packageCompileTsc.ts'\nimport { packageCompileTscTypes } from './packageCompileTscTypes.ts'\nimport type { XyTsupConfig } from './XyConfig.ts'\n\nconst compileFolder = async (\n srcDir: string,\n entries: string[],\n buildDir: string,\n options?: Options,\n bundleTypes = false,\n verbose?: boolean,\n): Promise<number> => {\n const outDir = options?.outDir ?? 'dist'\n\n if (verbose) {\n console.log(`compileFolder [${srcDir}, ${options?.outDir}]`)\n }\n\n if (entries.length === 0) {\n console.warn(chalk.yellow(`No entries found in ${srcDir} to compile`))\n return 0\n }\n\n if (verbose) {\n console.log(chalk.gray(`buildDir [${buildDir}]`))\n }\n\n const validationResult = packageCompileTsc(options?.platform ?? 'neutral', entries, srcDir, buildDir, undefined, verbose)\n if (validationResult !== 0) {\n console.error(chalk.red(`Compile:Validation had ${validationResult} errors`))\n return validationResult\n }\n\n const optionsParams: Options = tsupOptions([{\n bundle: true,\n cjsInterop: true,\n clean: false,\n dts: false,\n format: ['esm'],\n outDir,\n silent: true,\n sourcemap: true,\n splitting: false,\n tsconfig: 'tsconfig.json',\n ...options,\n entry: entries.map(entry => `${srcDir}/${entry}`),\n }])\n\n const optionsResult = defineConfig(optionsParams)\n\n const optionsList = (\n await Promise.all(\n (Array.isArray(optionsResult) ? optionsResult : [optionsResult]).flatMap<Promise<Options[]>>(async (options) => {\n const result = typeof options === 'function' ? await options({}) : [options]\n return Array.isArray(result) ? result : [result]\n }),\n )\n ).flat()\n\n if (verbose) {\n console.log(chalk.cyan(`TSUP:build:start [${srcDir}]`))\n console.log(chalk.gray(`TSUP:build:options [${JSON.stringify(optionsList, null, 2)}]`))\n }\n\n await Promise.all(optionsList.map(options => build(options)))\n\n if (verbose) {\n console.log(chalk.cyan(`TSUP:build:stop [${srcDir}]`))\n }\n if (bundleTypes) {\n await packageCompileTscTypes(entries, outDir, options?.platform ?? 'neutral', buildDir, verbose)\n }\n\n return 0\n}\n\nexport const tsupOptions = (options: Options[] = []): Options => {\n const standardLoaders: Record<string, Loader> = {\n '.gif': 'copy', '.html': 'copy', '.jpg': 'copy', '.json': 'json', '.png': 'copy', '.svg': 'text', '.webp': 'copy',\n }\n\n const standardOptions: Options = {\n bundle: true,\n format: ['esm'],\n loader: standardLoaders,\n outExtension: ({ format }) => (format === 'esm' ? { js: '.mjs' } : { js: '.cjs' }),\n skipNodeModulesBundle: true,\n sourcemap: true,\n target: 'esnext',\n }\n\n return deepMergeObjects([standardOptions, ...options])\n}\n\nexport const packageCompileTsup = async (config?: XyTsupConfig) => {\n const compile = config?.compile\n const verbose = config?.verbose ?? false\n const outDirAsBuildDir = compile?.outDirAsBuildDir ?? true\n const bundleTypes = compile?.bundleTypes ?? false\n if (verbose) {\n console.log('Compiling with TSUP')\n }\n\n const compileForNode = compile?.node ?? { src: {} }\n const compileForBrowser = compile?.browser ?? { src: {} }\n const compileForNeutral = compile?.neutral ?? { src: {} }\n\n return (\n (\n await Promise.all(\n Object.entries(compileForNode).map(async ([srcDir, options]) => {\n const optionsObject: Options = typeof options === 'object' ? options : {}\n const inEsBuildOptions = typeof compile?.node?.esbuildOptions === 'object' ? compile?.node?.esbuildOptions : {}\n const entry = buildEntries(srcDir, compile?.entryMode, options, true, verbose)\n const platform = 'node'\n const rootOutDir = (optionsObject.outDir ?? 'dist')\n const outDir = rootOutDir + '/' + platform\n return typeof srcDir === 'string'\n ? await compileFolder(\n srcDir,\n entry,\n outDirAsBuildDir ? rootOutDir : 'build',\n tsupOptions([inEsBuildOptions,\n compile?.tsup?.options ?? {},\n (typeof options === 'object' ? options : {}),\n { platform: 'node', outDir }]),\n bundleTypes,\n verbose,\n )\n : 0\n }),\n )\n ).reduce((prev, value) => prev + value, 0)\n + (\n await Promise.all(\n Object.entries(compileForBrowser).map(async ([srcDir, options]) => {\n const optionsObject: Options = typeof options === 'object' ? options : {}\n const inEsBuildOptions = typeof compile?.browser?.esbuildOptions === 'object' ? compile?.browser?.esbuildOptions : {}\n const entry = buildEntries(srcDir, compile?.entryMode, options, true, verbose)\n const platform = 'browser'\n const rootOutDir = (optionsObject.outDir ?? 'dist')\n const outDir = rootOutDir + '/' + platform\n return typeof srcDir === 'string'\n ? await compileFolder(\n srcDir,\n entry,\n outDirAsBuildDir ? rootOutDir : 'build',\n tsupOptions([inEsBuildOptions,\n compile?.tsup?.options ?? {},\n (typeof options === 'object' ? options : {}),\n { platform: 'browser', outDir }]),\n bundleTypes,\n verbose,\n )\n : 0\n }),\n )\n ).reduce((prev, value) => prev + value, 0)\n + (\n await Promise.all(\n Object.entries(compileForNeutral).map(async ([srcDir, options]) => {\n const optionsObject: Options = typeof options === 'object' ? options : {}\n const inEsBuildOptions = typeof compile?.neutral?.esbuildOptions === 'object' ? compile?.neutral?.esbuildOptions : {}\n const entry = buildEntries(srcDir, compile?.entryMode, options, true, verbose)\n const platform = 'neutral'\n const rootOutDir = (optionsObject.outDir ?? 'dist')\n const outDir = rootOutDir + '/' + platform\n return typeof srcDir === 'string'\n ? await compileFolder(\n srcDir,\n entry,\n outDirAsBuildDir ? rootOutDir : 'build',\n tsupOptions([inEsBuildOptions,\n compile?.tsup?.options ?? {},\n (typeof options === 'object' ? options : {}),\n { platform: 'neutral', outDir }]),\n bundleTypes,\n verbose,\n )\n : 0\n }),\n )\n ).reduce((prev, value) => prev + value, 0)\n + 0\n )\n}\n","import chalk from 'chalk'\nimport { glob } from 'glob'\n\nexport const getAllInputs = (srcDir: string, verbose = false) => {\n /* tsup wants posix paths */\n return [...glob.sync(`${srcDir}/**/*.ts`, { posix: true }).map((file) => {\n const result = file.slice(Math.max(0, srcDir.length + 1)) // Remove the folder prefix\n if (verbose) {\n console.log(chalk.gray(`getAllInputs: ${JSON.stringify(result, null, 2)}`))\n }\n return result\n }), ...glob.sync(`${srcDir}/**/*.tsx`, { posix: true }).map((file) => {\n const result = file.slice(Math.max(0, srcDir.length + 1)) // Remove the folder prefix\n if (verbose) {\n console.log(chalk.gray(`getAllInputs: ${JSON.stringify(result, null, 2)}`))\n }\n return result\n })]\n}\n","import type { Options } from 'tsup'\n\nimport { getAllInputs } from './inputs.ts'\nimport type { EntryMode } from './XyConfig.ts'\n\nexport const buildEntries = (srcDir: string, entryMode: EntryMode = 'single', options?: Options | boolean, excludeSpecAndStories = true, verbose = false) => {\n let entries: string[] = []\n switch (entryMode) {\n case 'platform': {\n entries = ['index-node.ts', 'index-browser.ts']\n break\n }\n case 'all': {\n entries = (excludeSpecAndStories\n ? getAllInputs(srcDir).filter(entry => !entry.includes('.spec.') && !entry.includes('.stories.'))\n : getAllInputs(srcDir)).filter(entry => !entry.endsWith('.d.ts'))\n break\n }\n case 'custom': {\n entries = []\n break\n }\n default: {\n entries = ['index.ts']\n break\n }\n }\n\n if (typeof options !== 'boolean' && Array.isArray(options?.entry)) {\n entries.push(...options.entry)\n }\n\n if (verbose) console.log(`buildEntries [${entryMode}] ${entries.length}`)\n return entries\n}\n","// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype AnyObject = Record<any, any>\n\nfunction deepMerge<T extends AnyObject>(target: AnyObject, source: AnyObject): T {\n if (!source || typeof source !== 'object') return target\n\n for (const key of Object.keys(source)) {\n if (\n typeof source[key] === 'object'\n && source[key] !== null\n && !Array.isArray(source[key])\n ) {\n // Recursively merge nested objects\n if (!target[key] || typeof target[key] !== 'object') {\n target[key] = {} as T[typeof key]\n }\n deepMerge(target[key], source[key])\n } else {\n // Overwrite with non-object values\n target[key] = source[key]\n }\n }\n\n return target\n}\n\nexport function deepMergeObjects<T extends AnyObject>(objects: T[]): T {\n const result = {} as T\n for (const obj of objects) {\n deepMerge(result, obj)\n }\n return result\n}\n","import path from 'node:path'\nimport { cwd } from 'node:process'\n\nimport chalk from 'chalk'\nimport type { TsConfigCompilerOptions } from 'tsc-prog'\nimport { createProgramFromConfig } from 'tsc-prog'\nimport type { CompilerOptions } from 'typescript'\nimport ts, {\n DiagnosticCategory, formatDiagnosticsWithColorAndContext, getPreEmitDiagnostics, sys,\n} from 'typescript'\n\nimport { getCompilerOptions } from './getCompilerOptions.ts'\n\nexport const packageCompileTsc = (\n platform: 'browser' | 'neutral' | 'node',\n entries: string[],\n srcDir: string = 'src',\n outDir: string = 'dist',\n compilerOptionsParam?: CompilerOptions,\n verbose: boolean = false,\n): number => {\n const pkg = process.env.INIT_CWD ?? cwd()\n\n if (verbose) {\n console.log(chalk.cyan(`Validating code START: ${entries.length} files to ${outDir} from ${srcDir}`))\n }\n\n const configFilePath = ts.findConfigFile(\n './', // search path\n ts.sys.fileExists,\n 'tsconfig.json',\n )\n\n if (configFilePath === undefined) {\n throw new Error('Could not find tsconfig.json')\n }\n\n const compilerOptions = {\n ...(getCompilerOptions({\n removeComments: false,\n skipDefaultLibCheck: true,\n skipLibCheck: true,\n sourceMap: false,\n })),\n ...compilerOptionsParam,\n outDir: `${outDir}/${platform}`,\n emitDeclarationOnly: true,\n noEmit: false,\n } as TsConfigCompilerOptions\n\n console.log(chalk.cyan(`Validating Files: ${entries.length}`))\n if (verbose) {\n for (const entry of entries) {\n console.log(chalk.grey(`Validating: ${entry}`))\n }\n }\n\n try {\n if (entries.length > 0) {\n const program = createProgramFromConfig({\n configFilePath,\n basePath: pkg ?? cwd(),\n compilerOptions,\n files: entries.map(entry => `${srcDir}/${entry}`),\n include: [`${srcDir}/**/*.*`],\n })\n\n const diagnostics = getPreEmitDiagnostics(program)\n\n if (diagnostics.length > 0) {\n const formattedDiagnostics = formatDiagnosticsWithColorAndContext(\n diagnostics,\n {\n getCanonicalFileName: fileName => fileName,\n getCurrentDirectory: () => srcDir,\n getNewLine: () => sys.newLine,\n },\n )\n console.error(formattedDiagnostics)\n }\n\n program.emit()\n return diagnostics.reduce((acc, diag) => acc + (diag.category === DiagnosticCategory.Error ? 1 : 0), 0)\n }\n return 0\n } finally {\n if (verbose) {\n console.log(chalk.cyan(`Validating code FINISH: ${entries.length} files to ${outDir} from ${srcDir}`))\n }\n }\n}\n","import { cwd } from 'node:process'\n\nimport deepmerge from 'deepmerge'\nimport { getTsconfig } from 'get-tsconfig'\nimport type { CompilerOptions } from 'typescript'\n\nexport const getCompilerOptions = (options: CompilerOptions = {}, fileName: string = 'tsconfig.json'): CompilerOptions => {\n const resolvedTsConfigCompilerOptions = getTsconfig(cwd(), fileName)?.config?.compilerOptions ?? {}\n\n return deepmerge(resolvedTsConfigCompilerOptions, options)\n}\n","import path from 'node:path'\nimport { cwd } from 'node:process'\n\nimport chalk from 'chalk'\nimport { rollup } from 'rollup'\nimport type { Options } from 'rollup-plugin-dts'\nimport dts from 'rollup-plugin-dts'\nimport nodeExternals from 'rollup-plugin-node-externals'\n\nimport { getCompilerOptions } from './getCompilerOptions.ts'\n\nconst ignoredWarningCodes = new Set(['EMPTY_BUNDLE', 'UNRESOLVED_IMPORT'])\n\nexport async function bundleDts(inputPath: string, outputPath: string, platform: 'node' | 'browser' | 'neutral', options?: Options, verbose = false) {\n // Find the tsconfig.json path\n const pkg = process.env.INIT_CWD ?? cwd()\n const tsconfigPath = path.resolve(pkg, 'tsconfig.json')\n\n const nodePlugIns = platform === 'node' ? [nodeExternals()] : []\n try {\n const bundle = await rollup({\n input: inputPath,\n\n plugins: [dts({\n ...options,\n tsconfig: tsconfigPath,\n compilerOptions: {\n emitDeclarationOnly: true, noEmit: false, declarationMap: true,\n },\n\n }), ...nodePlugIns],\n onwarn(warning, warn) {\n if (ignoredWarningCodes.has(warning.code ?? '')) {\n return\n }\n console.warn(chalk.yellow(`[${warning.code}] ${warning.message}`))\n console.warn(chalk.gray(inputPath))\n warn(warning)\n },\n })\n await bundle.write({\n file: outputPath,\n format: 'es',\n })\n } catch (ex) {\n const error = ex as Error\n console.warn(chalk.red(error))\n console.warn(chalk.gray(inputPath))\n }\n\n if (verbose) {\n console.log(`Bundled declarations written to ${outputPath}`)\n }\n}\n\nexport const packageCompileTscTypes = async (\n entries: string[],\n outDir: string,\n platform: 'node' | 'browser' | 'neutral',\n srcDir: string = 'build',\n verbose = false,\n): Promise<number> => {\n if (verbose) {\n console.log(chalk.cyan(`Compiling Types START [${platform}]: ${entries.length} files to ${outDir} from ${srcDir}`))\n console.log(`Entries: ${entries.join(', ')}`)\n }\n const pkg = process.env.INIT_CWD ?? cwd()\n const srcRoot = `${pkg}/${srcDir}/${platform}`\n\n const entryNameToTypeName = (entry: string): string => {\n const splitEntryName = entry.split('.')\n const newEntryExtension = 'd.' + splitEntryName.at(-1)\n return [...splitEntryName.slice(0, -1), newEntryExtension].join('.')\n }\n\n const compilerOptions = getCompilerOptions({\n removeComments: false,\n skipDefaultLibCheck: true,\n skipLibCheck: true,\n declarationMap: true,\n emitDeclarationOnly: true,\n noEmit: true,\n })\n\n const entryNames = entries.map(entry => entry.split(`${srcDir}/`).at(-1) ?? entry)\n\n await Promise.all(entryNames.map(async (entryName) => {\n const entryTypeName = entryNameToTypeName(entryName)\n await bundleDts(`${srcRoot}/${entryTypeName}`, `${outDir}/${entryTypeName}`, platform, { compilerOptions }, verbose)\n }))\n\n if (verbose) {\n console.log(chalk.cyan(`Compiling Types FINISH: ${entries.length} files to ${outDir} from ${srcDir}`))\n }\n\n return 0\n}\n","import { packageClean } from './clean.ts'\nimport { packageCompile } from './compile/index.ts'\n\nexport const packageRecompile = async () => {\n return await packageClean() || await packageCompile()\n}\n"],"mappings":"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","names":["path","chalk","fs","glob","deleteGlob","globPath","files","glob","sync","file","fs","rmSync","recursive","force","chalk","cosmiconfig","TypeScriptLoader","deepmerge","config","loadConfig","params","undefined","cosmicConfigResult","cosmiconfig","cache","loaders","TypeScriptLoader","search","configFilePath","filepath","console","log","chalk","green","verbose","gray","JSON","stringify","deepmerge","packageCleanOutputs","pkg","process","env","INIT_CWD","pkgName","npm_package_name","folders","path","join","console","log","chalk","green","folder","deleteGlob","path","chalk","packageCleanTypescript","pkg","process","env","INIT_CWD","pkgName","npm_package_name","console","log","chalk","green","files","path","join","file","deleteGlob","packageClean","Promise","all","packageCleanOutputs","packageCleanTypescript","reduce","prev","value","chalk","promises","fs","chalk","sortPackageJson","packagePublint","params","pkgDir","process","env","INIT_CWD","sortedPkg","sortPackageJson","fs","readFile","writeFile","pkg","JSON","parse","console","log","chalk","green","name","gray","publint","messages","level","strict","formatMessage","validMessage","_message","validMessages","filter","message","type","error","red","code","warn","yellow","white","verbose","length","chalk","build","defineConfig","chalk","glob","getAllInputs","srcDir","verbose","glob","sync","posix","map","file","result","slice","Math","max","length","console","log","chalk","gray","JSON","stringify","buildEntries","srcDir","entryMode","options","excludeSpecAndStories","verbose","entries","getAllInputs","filter","entry","includes","endsWith","Array","isArray","push","console","log","length","deepMerge","target","source","key","Object","keys","Array","isArray","deepMergeObjects","objects","result","obj","cwd","chalk","createProgramFromConfig","ts","DiagnosticCategory","formatDiagnosticsWithColorAndContext","getPreEmitDiagnostics","sys","cwd","deepmerge","getTsconfig","getCompilerOptions","options","fileName","resolvedTsConfigCompilerOptions","getTsconfig","cwd","config","compilerOptions","deepmerge","packageCompileTsc","platform","entries","srcDir","outDir","compilerOptionsParam","verbose","pkg","process","env","INIT_CWD","cwd","console","log","chalk","cyan","length","configFilePath","ts","findConfigFile","sys","fileExists","undefined","Error","compilerOptions","getCompilerOptions","removeComments","skipDefaultLibCheck","skipLibCheck","sourceMap","emitDeclarationOnly","noEmit","entry","grey","program","createProgramFromConfig","basePath","files","map","include","diagnostics","getPreEmitDiagnostics","formattedDiagnostics","formatDiagnosticsWithColorAndContext","getCanonicalFileName","fileName","getCurrentDirectory","getNewLine","newLine","error","emit","reduce","acc","diag","category","DiagnosticCategory","path","cwd","chalk","rollup","dts","nodeExternals","ignoredWarningCodes","Set","bundleDts","inputPath","outputPath","platform","options","verbose","pkg","process","env","INIT_CWD","cwd","tsconfigPath","path","resolve","nodePlugIns","nodeExternals","bundle","rollup","input","plugins","dts","tsconfig","compilerOptions","emitDeclarationOnly","noEmit","declarationMap","onwarn","warning","warn","has","code","console","chalk","yellow","message","gray","write","file","format","ex","error","red","log","packageCompileTscTypes","entries","outDir","srcDir","cyan","length","join","srcRoot","entryNameToTypeName","entry","splitEntryName","split","newEntryExtension","at","slice","getCompilerOptions","removeComments","skipDefaultLibCheck","skipLibCheck","entryNames","map","Promise","all","entryName","entryTypeName","compileFolder","srcDir","entries","buildDir","options","bundleTypes","verbose","outDir","console","log","length","warn","chalk","yellow","gray","validationResult","packageCompileTsc","platform","undefined","error","red","optionsParams","tsupOptions","bundle","cjsInterop","clean","dts","format","silent","sourcemap","splitting","tsconfig","entry","map","optionsResult","defineConfig","optionsList","Promise","all","Array","isArray","flatMap","result","flat","cyan","JSON","stringify","build","packageCompileTscTypes","standardLoaders","standardOptions","loader","outExtension","js","skipNodeModulesBundle","target","deepMergeObjects","packageCompileTsup","config","compile","outDirAsBuildDir","compileForNode","node","src","compileForBrowser","browser","compileForNeutral","neutral","Object","optionsObject","inEsBuildOptions","esbuildOptions","buildEntries","entryMode","rootOutDir","tsup","reduce","prev","value","packageCompile","inConfig","pkg","process","env","INIT_CWD","console","log","chalk","green","config","loadConfig","publint","tsupResults","packageCompileTsup","packagePublint","packageRecompile","packageClean","packageCompile"]}
1
+ {"version":3,"sources":["../../../src/actions/package/clean-outputs.ts","../../../src/lib/deleteGlob.ts","../../../src/lib/loadConfig.ts","../../../src/actions/package/clean-typescript.ts","../../../src/actions/package/clean.ts","../../../src/actions/package/compile/compile.ts","../../../src/actions/package/compile/packageCompileTsup.ts","../../../src/actions/package/compile/inputs.ts","../../../src/actions/package/compile/buildEntries.ts","../../../src/actions/package/compile/deepMerge.ts","../../../src/actions/package/compile/packageCompileTsc.ts","../../../src/actions/package/compile/getCompilerOptions.ts","../../../src/actions/package/compile/packageCompileTscTypes.ts","../../../src/actions/package/recompile.ts"],"sourcesContent":["import path from 'node:path'\n\nimport chalk from 'chalk'\n\nimport { deleteGlob } from '../../lib/index.ts'\n\nexport const packageCleanOutputs = () => {\n const pkg = process.env.INIT_CWD ?? '.'\n const pkgName = process.env.npm_package_name\n const folders: string[] = [path.join(pkg, 'dist'), path.join(pkg, 'build'), path.join(pkg, 'docs')]\n console.log(chalk.green(`Cleaning Outputs [${pkgName}]`))\n\n for (let folder of folders) {\n deleteGlob(folder)\n }\n\n return 0\n}\n","import fs from 'node:fs'\n\nimport { glob } from 'glob'\n\nexport const deleteGlob = (globPath: string) => {\n // Find all files matching the glob pattern\n const files = glob.sync(globPath)\n\n // Remove each file or directory\n for (const file of files) {\n fs.rmSync(file, { recursive: true, force: true })\n }\n}\n","import chalk from 'chalk'\nimport { cosmiconfig } from 'cosmiconfig'\nimport { TypeScriptLoader } from 'cosmiconfig-typescript-loader'\nimport deepmerge from 'deepmerge'\n\nlet config: Record<string, unknown>\n\nexport const loadConfig = async <T extends object>(params?: T): Promise<T> => {\n if (config === undefined) {\n const cosmicConfigResult = await cosmiconfig('xy', { cache: true, loaders: { '.ts': TypeScriptLoader() } }).search()\n config = cosmicConfigResult?.config\n const configFilePath = cosmicConfigResult?.filepath\n if (configFilePath !== undefined) {\n console.log(chalk.green(`Loaded config from ${configFilePath}`))\n if (config.verbose) {\n console.log(chalk.gray(`${JSON.stringify(config, null, 2)}`))\n }\n }\n }\n return deepmerge(config, params ?? {}) as T\n}\n","import path from 'node:path'\n\nimport chalk from 'chalk'\n\nimport { deleteGlob } from '../../lib/index.ts'\n\nexport const packageCleanTypescript = () => {\n const pkg = process.env.INIT_CWD ?? '.'\n const pkgName = process.env.npm_package_name\n console.log(chalk.green(`Cleaning Typescript [${pkgName}]`))\n const files: string[] = [path.join(pkg, '*.tsbuildinfo'), path.join(pkg, '.tsconfig.*'), path.join(pkg, '.eslintcache')]\n\n for (let file of files) {\n deleteGlob(file)\n }\n\n return 0\n}\n","import { packageCleanOutputs } from './clean-outputs.ts'\nimport { packageCleanTypescript } from './clean-typescript.ts'\n\nexport const packageClean = async () => {\n return (await Promise.all([packageCleanOutputs(), packageCleanTypescript()])).reduce((prev, value) => prev + value, 0)\n}\n","import chalk from 'chalk'\n\nimport { loadConfig } from '../../../lib/index.ts'\nimport { packageCompileTsup } from './packageCompileTsup.ts'\nimport type { XyConfig } from './XyConfig.ts'\n\nexport const packageCompile = async (inConfig: XyConfig = {}): Promise<number> => {\n const pkg = process.env.INIT_CWD\n console.log(chalk.green(`Compiling ${pkg}`))\n const config = await loadConfig(inConfig)\n\n return await packageCompileTsup(config)\n}\n","import chalk from 'chalk'\nimport type { Loader } from 'esbuild'\nimport type { Options } from 'tsup'\nimport { build, defineConfig } from 'tsup'\n\nimport { buildEntries } from './buildEntries.ts'\nimport { deepMergeObjects } from './deepMerge.ts'\nimport { packageCompileTsc } from './packageCompileTsc.ts'\nimport { packageCompileTscTypes } from './packageCompileTscTypes.ts'\nimport type { XyTsupConfig } from './XyConfig.ts'\n\nconst compileFolder = async (\n srcDir: string,\n entries: string[],\n buildDir: string,\n options?: Options,\n bundleTypes = false,\n verbose?: boolean,\n): Promise<number> => {\n const outDir = options?.outDir ?? 'dist'\n\n if (verbose) {\n console.log(`compileFolder [${srcDir}, ${options?.outDir}]`)\n }\n\n if (entries.length === 0) {\n console.warn(chalk.yellow(`No entries found in ${srcDir} to compile`))\n return 0\n }\n\n if (verbose) {\n console.log(chalk.gray(`buildDir [${buildDir}]`))\n }\n\n const validationResult = packageCompileTsc(options?.platform ?? 'neutral', entries, srcDir, buildDir, undefined, verbose)\n if (validationResult !== 0) {\n console.error(chalk.red(`Compile:Validation had ${validationResult} errors`))\n return validationResult\n }\n\n const optionsParams: Options = tsupOptions([{\n bundle: true,\n cjsInterop: true,\n clean: false,\n dts: false,\n format: ['esm'],\n outDir,\n silent: true,\n sourcemap: true,\n splitting: false,\n tsconfig: 'tsconfig.json',\n ...options,\n entry: entries.map(entry => `${srcDir}/${entry}`),\n }])\n\n const optionsResult = defineConfig(optionsParams)\n\n const optionsList = (\n await Promise.all(\n (Array.isArray(optionsResult) ? optionsResult : [optionsResult]).flatMap<Promise<Options[]>>(async (options) => {\n const result = typeof options === 'function' ? await options({}) : [options]\n return Array.isArray(result) ? result : [result]\n }),\n )\n ).flat()\n\n if (verbose) {\n console.log(chalk.cyan(`TSUP:build:start [${srcDir}]`))\n console.log(chalk.gray(`TSUP:build:options [${JSON.stringify(optionsList, null, 2)}]`))\n }\n\n await Promise.all(optionsList.map(options => build(options)))\n\n if (verbose) {\n console.log(chalk.cyan(`TSUP:build:stop [${srcDir}]`))\n }\n if (bundleTypes) {\n await packageCompileTscTypes(entries, outDir, options?.platform ?? 'neutral', buildDir, verbose)\n }\n\n return 0\n}\n\nexport const tsupOptions = (options: Options[] = []): Options => {\n const standardLoaders: Record<string, Loader> = {\n '.gif': 'copy', '.html': 'copy', '.jpg': 'copy', '.json': 'json', '.png': 'copy', '.svg': 'text', '.webp': 'copy',\n }\n\n const standardOptions: Options = {\n bundle: true,\n format: ['esm'],\n loader: standardLoaders,\n outExtension: ({ format }) => (format === 'esm' ? { js: '.mjs' } : { js: '.cjs' }),\n skipNodeModulesBundle: true,\n sourcemap: true,\n target: 'esnext',\n }\n\n return deepMergeObjects([standardOptions, ...options])\n}\n\nexport const packageCompileTsup = async (config?: XyTsupConfig) => {\n const compile = config?.compile\n const verbose = config?.verbose ?? false\n const outDirAsBuildDir = compile?.outDirAsBuildDir ?? true\n const bundleTypes = compile?.bundleTypes ?? false\n if (verbose) {\n console.log('Compiling with TSUP')\n }\n\n const compileForNode = compile?.node ?? { src: {} }\n const compileForBrowser = compile?.browser ?? { src: {} }\n const compileForNeutral = compile?.neutral ?? { src: {} }\n\n return (\n (\n await Promise.all(\n Object.entries(compileForNode).map(async ([srcDir, options]) => {\n const optionsObject: Options = typeof options === 'object' ? options : {}\n const inEsBuildOptions = typeof compile?.node?.esbuildOptions === 'object' ? compile?.node?.esbuildOptions : {}\n const entry = buildEntries(srcDir, compile?.entryMode, options, true, verbose)\n const platform = 'node'\n const rootOutDir = (optionsObject.outDir ?? 'dist')\n const outDir = rootOutDir + '/' + platform\n return typeof srcDir === 'string'\n ? await compileFolder(\n srcDir,\n entry,\n outDirAsBuildDir ? rootOutDir : 'build',\n tsupOptions([inEsBuildOptions,\n compile?.tsup?.options ?? {},\n (typeof options === 'object' ? options : {}),\n { platform: 'node', outDir }]),\n bundleTypes,\n verbose,\n )\n : 0\n }),\n )\n ).reduce((prev, value) => prev + value, 0)\n + (\n await Promise.all(\n Object.entries(compileForBrowser).map(async ([srcDir, options]) => {\n const optionsObject: Options = typeof options === 'object' ? options : {}\n const inEsBuildOptions = typeof compile?.browser?.esbuildOptions === 'object' ? compile?.browser?.esbuildOptions : {}\n const entry = buildEntries(srcDir, compile?.entryMode, options, true, verbose)\n const platform = 'browser'\n const rootOutDir = (optionsObject.outDir ?? 'dist')\n const outDir = rootOutDir + '/' + platform\n return typeof srcDir === 'string'\n ? await compileFolder(\n srcDir,\n entry,\n outDirAsBuildDir ? rootOutDir : 'build',\n tsupOptions([inEsBuildOptions,\n compile?.tsup?.options ?? {},\n (typeof options === 'object' ? options : {}),\n { platform: 'browser', outDir }]),\n bundleTypes,\n verbose,\n )\n : 0\n }),\n )\n ).reduce((prev, value) => prev + value, 0)\n + (\n await Promise.all(\n Object.entries(compileForNeutral).map(async ([srcDir, options]) => {\n const optionsObject: Options = typeof options === 'object' ? options : {}\n const inEsBuildOptions = typeof compile?.neutral?.esbuildOptions === 'object' ? compile?.neutral?.esbuildOptions : {}\n const entry = buildEntries(srcDir, compile?.entryMode, options, true, verbose)\n const platform = 'neutral'\n const rootOutDir = (optionsObject.outDir ?? 'dist')\n const outDir = rootOutDir + '/' + platform\n return typeof srcDir === 'string'\n ? await compileFolder(\n srcDir,\n entry,\n outDirAsBuildDir ? rootOutDir : 'build',\n tsupOptions([inEsBuildOptions,\n compile?.tsup?.options ?? {},\n (typeof options === 'object' ? options : {}),\n { platform: 'neutral', outDir }]),\n bundleTypes,\n verbose,\n )\n : 0\n }),\n )\n ).reduce((prev, value) => prev + value, 0)\n + 0\n )\n}\n","import chalk from 'chalk'\nimport { glob } from 'glob'\n\nexport const getAllInputs = (srcDir: string, verbose = false) => {\n /* tsup wants posix paths */\n return [...glob.sync(`${srcDir}/**/*.ts`, { posix: true }).map((file) => {\n const result = file.slice(Math.max(0, srcDir.length + 1)) // Remove the folder prefix\n if (verbose) {\n console.log(chalk.gray(`getAllInputs: ${JSON.stringify(result, null, 2)}`))\n }\n return result\n }), ...glob.sync(`${srcDir}/**/*.tsx`, { posix: true }).map((file) => {\n const result = file.slice(Math.max(0, srcDir.length + 1)) // Remove the folder prefix\n if (verbose) {\n console.log(chalk.gray(`getAllInputs: ${JSON.stringify(result, null, 2)}`))\n }\n return result\n })]\n}\n","import type { Options } from 'tsup'\n\nimport { getAllInputs } from './inputs.ts'\nimport type { EntryMode } from './XyConfig.ts'\n\nexport const buildEntries = (srcDir: string, entryMode: EntryMode = 'single', options?: Options | boolean, excludeSpecAndStories = true, verbose = false) => {\n let entries: string[] = []\n switch (entryMode) {\n case 'platform': {\n entries = ['index-node.ts', 'index-browser.ts']\n break\n }\n case 'all': {\n entries = (excludeSpecAndStories\n ? getAllInputs(srcDir).filter(entry => !entry.includes('.spec.') && !entry.includes('.stories.'))\n : getAllInputs(srcDir)).filter(entry => !entry.endsWith('.d.ts'))\n break\n }\n case 'custom': {\n entries = []\n break\n }\n default: {\n entries = ['index.ts']\n break\n }\n }\n\n if (typeof options !== 'boolean' && Array.isArray(options?.entry)) {\n entries.push(...options.entry)\n }\n\n if (verbose) console.log(`buildEntries [${entryMode}] ${entries.length}`)\n return entries\n}\n","// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype AnyObject = Record<any, any>\n\nfunction deepMerge<T extends AnyObject>(target: AnyObject, source: AnyObject): T {\n if (!source || typeof source !== 'object') return target\n\n for (const key of Object.keys(source)) {\n if (\n typeof source[key] === 'object'\n && source[key] !== null\n && !Array.isArray(source[key])\n ) {\n // Recursively merge nested objects\n if (!target[key] || typeof target[key] !== 'object') {\n target[key] = {} as T[typeof key]\n }\n deepMerge(target[key], source[key])\n } else {\n // Overwrite with non-object values\n target[key] = source[key]\n }\n }\n\n return target\n}\n\nexport function deepMergeObjects<T extends AnyObject>(objects: T[]): T {\n const result = {} as T\n for (const obj of objects) {\n deepMerge(result, obj)\n }\n return result\n}\n","import { cwd } from 'node:process'\n\nimport chalk from 'chalk'\nimport type { TsConfigCompilerOptions } from 'tsc-prog'\nimport { createProgramFromConfig } from 'tsc-prog'\nimport type { CompilerOptions } from 'typescript'\nimport ts, {\n DiagnosticCategory, formatDiagnosticsWithColorAndContext, getPreEmitDiagnostics, sys,\n} from 'typescript'\n\nimport { getCompilerOptions } from './getCompilerOptions.ts'\n\nexport const packageCompileTsc = (\n platform: 'browser' | 'neutral' | 'node',\n entries: string[],\n srcDir: string = 'src',\n outDir: string = 'dist',\n compilerOptionsParam?: CompilerOptions,\n verbose: boolean = false,\n): number => {\n const pkg = process.env.INIT_CWD ?? cwd()\n\n if (verbose) {\n console.log(chalk.cyan(`Validating code START: ${entries.length} files to ${outDir} from ${srcDir}`))\n }\n\n const configFilePath = ts.findConfigFile(\n './', // search path\n ts.sys.fileExists,\n 'tsconfig.json',\n )\n\n if (configFilePath === undefined) {\n throw new Error('Could not find tsconfig.json')\n }\n\n const compilerOptions = {\n ...(getCompilerOptions({\n removeComments: false,\n skipDefaultLibCheck: true,\n skipLibCheck: true,\n sourceMap: false,\n })),\n ...compilerOptionsParam,\n outDir: `${outDir}/${platform}`,\n emitDeclarationOnly: true,\n noEmit: false,\n } as TsConfigCompilerOptions\n\n console.log(chalk.cyan(`Validating Files: ${entries.length}`))\n if (verbose) {\n for (const entry of entries) {\n console.log(chalk.grey(`Validating: ${entry}`))\n }\n }\n\n try {\n if (entries.length > 0) {\n const program = createProgramFromConfig({\n configFilePath,\n basePath: pkg ?? cwd(),\n compilerOptions,\n files: entries.map(entry => `${srcDir}/${entry}`),\n include: [`${srcDir}/**/*.*`],\n })\n\n const diagnostics = getPreEmitDiagnostics(program)\n\n if (diagnostics.length > 0) {\n const formattedDiagnostics = formatDiagnosticsWithColorAndContext(\n diagnostics,\n {\n getCanonicalFileName: fileName => fileName,\n getCurrentDirectory: () => srcDir,\n getNewLine: () => sys.newLine,\n },\n )\n console.error(formattedDiagnostics)\n }\n\n program.emit()\n return diagnostics.reduce((acc, diag) => acc + (diag.category === DiagnosticCategory.Error ? 1 : 0), 0)\n }\n return 0\n } finally {\n if (verbose) {\n console.log(chalk.cyan(`Validating code FINISH: ${entries.length} files to ${outDir} from ${srcDir}`))\n }\n }\n}\n","import { cwd } from 'node:process'\n\nimport deepmerge from 'deepmerge'\nimport { getTsconfig } from 'get-tsconfig'\nimport type { CompilerOptions } from 'typescript'\n\nexport const getCompilerOptions = (options: CompilerOptions = {}, fileName: string = 'tsconfig.json'): CompilerOptions => {\n const resolvedTsConfigCompilerOptions = getTsconfig(cwd(), fileName)?.config?.compilerOptions ?? {}\n\n return deepmerge(resolvedTsConfigCompilerOptions, options)\n}\n","import path from 'node:path'\nimport { cwd } from 'node:process'\n\nimport chalk from 'chalk'\nimport { rollup } from 'rollup'\nimport type { Options } from 'rollup-plugin-dts'\nimport dts from 'rollup-plugin-dts'\nimport nodeExternals from 'rollup-plugin-node-externals'\n\nimport { getCompilerOptions } from './getCompilerOptions.ts'\n\nconst ignoredWarningCodes = new Set(['EMPTY_BUNDLE', 'UNRESOLVED_IMPORT'])\n\nexport async function bundleDts(inputPath: string, outputPath: string, platform: 'node' | 'browser' | 'neutral', options?: Options, verbose = false) {\n // Find the tsconfig.json path\n const pkg = process.env.INIT_CWD ?? cwd()\n const tsconfigPath = path.resolve(pkg, 'tsconfig.json')\n\n const nodePlugIns = platform === 'node' ? [nodeExternals()] : []\n try {\n const bundle = await rollup({\n input: inputPath,\n\n plugins: [dts({\n ...options,\n tsconfig: tsconfigPath,\n compilerOptions: {\n emitDeclarationOnly: true, noEmit: false, declarationMap: true,\n },\n\n }), ...nodePlugIns],\n onwarn(warning, warn) {\n if (ignoredWarningCodes.has(warning.code ?? '')) {\n return\n }\n console.warn(chalk.yellow(`[${warning.code}] ${warning.message}`))\n console.warn(chalk.gray(inputPath))\n warn(warning)\n },\n })\n await bundle.write({\n file: outputPath,\n format: 'es',\n })\n } catch (ex) {\n const error = ex as Error\n console.warn(chalk.red(error))\n console.warn(chalk.gray(inputPath))\n }\n\n if (verbose) {\n console.log(`Bundled declarations written to ${outputPath}`)\n }\n}\n\nexport const packageCompileTscTypes = async (\n entries: string[],\n outDir: string,\n platform: 'node' | 'browser' | 'neutral',\n srcDir: string = 'build',\n verbose = false,\n): Promise<number> => {\n if (verbose) {\n console.log(chalk.cyan(`Compiling Types START [${platform}]: ${entries.length} files to ${outDir} from ${srcDir}`))\n console.log(`Entries: ${entries.join(', ')}`)\n }\n const pkg = process.env.INIT_CWD ?? cwd()\n const srcRoot = `${pkg}/${srcDir}/${platform}`\n\n const entryNameToTypeName = (entry: string): string => {\n const splitEntryName = entry.split('.')\n const newEntryExtension = 'd.' + splitEntryName.at(-1)\n return [...splitEntryName.slice(0, -1), newEntryExtension].join('.')\n }\n\n const compilerOptions = getCompilerOptions({\n removeComments: false,\n skipDefaultLibCheck: true,\n skipLibCheck: true,\n declarationMap: true,\n emitDeclarationOnly: true,\n noEmit: true,\n })\n\n const entryNames = entries.map(entry => entry.split(`${srcDir}/`).at(-1) ?? entry)\n\n await Promise.all(entryNames.map(async (entryName) => {\n const entryTypeName = entryNameToTypeName(entryName)\n await bundleDts(`${srcRoot}/${entryTypeName}`, `${outDir}/${entryTypeName}`, platform, { compilerOptions }, verbose)\n }))\n\n if (verbose) {\n console.log(chalk.cyan(`Compiling Types FINISH: ${entries.length} files to ${outDir} from ${srcDir}`))\n }\n\n return 0\n}\n","import { packageClean } from './clean.ts'\nimport { packageCompile } from './compile/index.ts'\n\nexport const packageRecompile = async () => {\n return await packageClean() || await packageCompile()\n}\n"],"mappings":"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","names":["path","chalk","fs","glob","deleteGlob","globPath","files","glob","sync","file","fs","rmSync","recursive","force","chalk","cosmiconfig","TypeScriptLoader","deepmerge","config","loadConfig","params","undefined","cosmicConfigResult","cosmiconfig","cache","loaders","TypeScriptLoader","search","configFilePath","filepath","console","log","chalk","green","verbose","gray","JSON","stringify","deepmerge","packageCleanOutputs","pkg","process","env","INIT_CWD","pkgName","npm_package_name","folders","path","join","console","log","chalk","green","folder","deleteGlob","path","chalk","packageCleanTypescript","pkg","process","env","INIT_CWD","pkgName","npm_package_name","console","log","chalk","green","files","path","join","file","deleteGlob","packageClean","Promise","all","packageCleanOutputs","packageCleanTypescript","reduce","prev","value","chalk","chalk","build","defineConfig","chalk","glob","getAllInputs","srcDir","verbose","glob","sync","posix","map","file","result","slice","Math","max","length","console","log","chalk","gray","JSON","stringify","buildEntries","srcDir","entryMode","options","excludeSpecAndStories","verbose","entries","getAllInputs","filter","entry","includes","endsWith","Array","isArray","push","console","log","length","deepMerge","target","source","key","Object","keys","Array","isArray","deepMergeObjects","objects","result","obj","cwd","chalk","createProgramFromConfig","ts","DiagnosticCategory","formatDiagnosticsWithColorAndContext","getPreEmitDiagnostics","sys","cwd","deepmerge","getTsconfig","getCompilerOptions","options","fileName","resolvedTsConfigCompilerOptions","getTsconfig","cwd","config","compilerOptions","deepmerge","packageCompileTsc","platform","entries","srcDir","outDir","compilerOptionsParam","verbose","pkg","process","env","INIT_CWD","cwd","console","log","chalk","cyan","length","configFilePath","ts","findConfigFile","sys","fileExists","undefined","Error","compilerOptions","getCompilerOptions","removeComments","skipDefaultLibCheck","skipLibCheck","sourceMap","emitDeclarationOnly","noEmit","entry","grey","program","createProgramFromConfig","basePath","files","map","include","diagnostics","getPreEmitDiagnostics","formattedDiagnostics","formatDiagnosticsWithColorAndContext","getCanonicalFileName","fileName","getCurrentDirectory","getNewLine","newLine","error","emit","reduce","acc","diag","category","DiagnosticCategory","path","cwd","chalk","rollup","dts","nodeExternals","ignoredWarningCodes","Set","bundleDts","inputPath","outputPath","platform","options","verbose","pkg","process","env","INIT_CWD","cwd","tsconfigPath","path","resolve","nodePlugIns","nodeExternals","bundle","rollup","input","plugins","dts","tsconfig","compilerOptions","emitDeclarationOnly","noEmit","declarationMap","onwarn","warning","warn","has","code","console","chalk","yellow","message","gray","write","file","format","ex","error","red","log","packageCompileTscTypes","entries","outDir","srcDir","cyan","length","join","srcRoot","entryNameToTypeName","entry","splitEntryName","split","newEntryExtension","at","slice","getCompilerOptions","removeComments","skipDefaultLibCheck","skipLibCheck","entryNames","map","Promise","all","entryName","entryTypeName","compileFolder","srcDir","entries","buildDir","options","bundleTypes","verbose","outDir","console","log","length","warn","chalk","yellow","gray","validationResult","packageCompileTsc","platform","undefined","error","red","optionsParams","tsupOptions","bundle","cjsInterop","clean","dts","format","silent","sourcemap","splitting","tsconfig","entry","map","optionsResult","defineConfig","optionsList","Promise","all","Array","isArray","flatMap","result","flat","cyan","JSON","stringify","build","packageCompileTscTypes","standardLoaders","standardOptions","loader","outExtension","js","skipNodeModulesBundle","target","deepMergeObjects","packageCompileTsup","config","compile","outDirAsBuildDir","compileForNode","node","src","compileForBrowser","browser","compileForNeutral","neutral","Object","optionsObject","inEsBuildOptions","esbuildOptions","buildEntries","entryMode","rootOutDir","tsup","reduce","prev","value","packageCompile","inConfig","pkg","process","env","INIT_CWD","console","log","chalk","green","config","loadConfig","packageCompileTsup","packageRecompile","packageClean","packageCompile"]}
@@ -152,10 +152,10 @@ var runStepsAsync = /* @__PURE__ */ __name(async (name, steps, exitOnFail = true
152
152
 
153
153
  // src/actions/publint.ts
154
154
  var publint = /* @__PURE__ */ __name(async ({ verbose, pkg }) => {
155
- return pkg ? await publintPackage({
156
- pkg,
155
+ return pkg === void 0 ? publintAll({
157
156
  verbose
158
- }) : publintAll({
157
+ }) : await publintPackage({
158
+ pkg,
159
159
  verbose
160
160
  });
161
161
  }, "publint");
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/lib/checkResult.ts","../../src/lib/processEx.ts","../../src/lib/withError.ts","../../src/lib/withErrnoException.ts","../../src/lib/safeExit.ts","../../src/lib/runSteps.ts","../../src/lib/runStepsAsync.ts","../../src/actions/publint.ts"],"sourcesContent":["import chalk from 'chalk'\n\nexport const checkResult = (name: string, result: number, level: 'error' | 'warn' = 'error', exitOnFail = false) => {\n if (result) {\n const exiting = exitOnFail ? '[Exiting Process]' : '[Continuing]'\n const chalkFunc = level === 'error' ? chalk.red : chalk.yellow\n console[level](chalkFunc(`${name} had ${result} failures ${exiting}`))\n if (exitOnFail) {\n process.exit(result)\n }\n }\n}\n","import chalk from 'chalk'\n\nimport { withErrnoException } from './withErrnoException.ts'\nimport { withError } from './withError.ts'\n\nexport const processEx = (ex: unknown) => {\n const error = typeof ex === 'string' ? new Error(ex) : ex\n const exitCode\n = withErrnoException(error, (error) => {\n if (error.code === 'ENOENT') {\n console.error(chalk.red(`'${error.path}' not found.`))\n } else {\n console.error(chalk.red(`Errno: ${error.code}`))\n }\n return error.errno ?? -1\n })\n ?? withError(error, (error) => {\n console.error(chalk.red(`${error.name}: ${error.message}`))\n return -1\n })\n ?? (() => {\n console.error(chalk.red(`Unexpected Error: ${JSON.stringify(ex, null, 2)}`))\n return -1\n })()\n // This allows us to use a previously set exit code\n process.exit(process.exitCode ?? exitCode)\n}\n","export const withError = <T extends Error = Error>(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ex: any,\n closure: (error: T) => number,\n predicate = (ex: T) => (!!ex.name && !!ex.message),\n) => {\n return predicate(ex as T) ? closure(ex as T) : undefined\n}\n","import { withError } from './withError.ts'\n\nexport const withErrnoException = <T extends NodeJS.ErrnoException = NodeJS.ErrnoException>(\n ex: unknown, closure: (error: T) => number,\n) => {\n return withError<T>(ex, closure, (ex: unknown) => (ex as NodeJS.ErrnoException).errno !== undefined)\n}\n","/** Catch child process a crash and returns the code */\n\nimport { processEx } from './processEx.ts'\n\nconst safeExit = (func: () => number, exitOnFail = true): number => {\n try {\n const result = func()\n if (result && exitOnFail) {\n process.exit(result)\n }\n return result\n } catch (ex) {\n return processEx(ex)\n }\n}\n\nconst safeExitAsync = async (func: () => Promise<number>, exitOnFail = true): Promise<number> => {\n try {\n const result = await func()\n if (result && exitOnFail) {\n process.exit(result)\n }\n return result\n } catch (ex) {\n return processEx(ex)\n }\n}\n\nexport { safeExit, safeExitAsync }\n","import type { SpawnSyncOptionsWithBufferEncoding } from 'node:child_process'\nimport { spawnSync } from 'node:child_process'\nimport { existsSync } from 'node:fs'\n\nimport chalk from 'chalk'\n\nimport { checkResult } from './checkResult.ts'\nimport { safeExit } from './safeExit.ts'\n\nexport type ScriptStep\n = | [/* command */ 'yarn' | 'node' | 'ts-node-script' | 'tsc' | 'jest', /* arg */ string | string[]]\n | [/* command */ string, /* arg */ string | string[], /* config */ SpawnSyncOptionsWithBufferEncoding]\n\nexport const runSteps = (name: string, steps: ScriptStep[], exitOnFail = true, messages?: string[]): number => {\n return safeExit(() => {\n const pkgName = process.env.npm_package_name\n console.log(chalk.green(`${name} [${pkgName}]`))\n let totalStatus = 0\n for (const [i, [command, args, config]] of steps.entries()) {\n if (messages?.[i]) {\n console.log(chalk.gray(messages?.[i]))\n }\n const argList = Array.isArray(args) ? args : args.split(' ')\n if (command === 'node' && !existsSync(argList[0])) {\n throw new Error(`File not found [${argList[0]}]`)\n }\n const status\n = spawnSync(command, Array.isArray(args) ? args : args.split(' '), {\n ...config,\n encoding: 'utf8',\n env: { FORCE_COLOR: '3', ...process.env },\n shell: true,\n stdio: 'inherit',\n }).status ?? 0\n checkResult(name, status, 'error', exitOnFail)\n totalStatus += status ?? 0\n }\n return totalStatus\n }, !!exitOnFail)\n}\n","import { spawn } from 'node:child_process'\nimport { existsSync } from 'node:fs'\n\nimport chalk from 'chalk'\n\nimport { checkResult } from './checkResult.ts'\nimport type { ScriptStep } from './runSteps.ts'\nimport { safeExitAsync } from './safeExit.ts'\n\nexport const runStepAsync = (name: string, step: ScriptStep, exitOnFail = true, message?: string) => {\n return new Promise<number>((resolve) => {\n const [command, args, config] = step\n if (message) {\n console.log(chalk.gray(message))\n }\n const argList = Array.isArray(args) ? args : args.split(' ')\n if (command === 'node' && !existsSync(argList[0])) {\n throw new Error(`File not found [${argList[0]}]`)\n }\n spawn(command, Array.isArray(args) ? args : args.split(' '), {\n ...config,\n env: { FORCE_COLOR: '3', ...process.env },\n shell: true,\n stdio: 'inherit',\n }).on('close', (code) => {\n if (code) {\n console.error(\n chalk.red(\n `Command Exited With Non-Zero Result [${chalk.gray(code)}] | ${chalk.yellow(command)} ${chalk.white(\n Array.isArray(args) ? args.join(' ') : args,\n )}`,\n ),\n )\n checkResult(name, code, 'error', exitOnFail)\n resolve(code)\n } else {\n resolve(0)\n }\n })\n })\n}\n\nexport const runStepsAsync = async (name: string, steps: ScriptStep[], exitOnFail = true, messages?: string[]) => {\n return await safeExitAsync(async () => {\n const pkgName = process.env.npm_package_name\n console.log(chalk.green(`${name} [${pkgName}]`))\n let result = 0\n for (const [i, step] of steps.entries()) {\n result += await runStepAsync(name, step, exitOnFail, messages?.[i])\n }\n return result\n })\n}\n","import { runSteps, runStepsAsync } from '../lib/index.ts'\n\nexport interface PublintParams {\n pkg?: string\n verbose?: boolean\n}\n\nexport interface PublintPackageParams {\n pkg: string\n verbose?: boolean\n}\n\nexport const publint = async ({ verbose, pkg }: PublintParams) => {\n return pkg\n ? await publintPackage({ pkg, verbose })\n : publintAll({ verbose })\n}\n\nexport const publintPackage = ({ pkg }: PublintPackageParams) => {\n return runStepsAsync(`Publint [${pkg}]`, [['yarn', ['workspace', pkg, 'run', 'package-publint']]])\n}\n\nexport const publintAll = ({ verbose }: PublintParams) => {\n const verboseOptions = verbose ? ['--verbose'] : ['--no-verbose']\n return runSteps('Publint', [['yarn', ['workspaces', 'foreach', '-pA', ...verboseOptions, 'run', 'package-publint']]])\n}\n"],"mappings":"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","names":["chalk","checkResult","name","result","level","exitOnFail","exiting","chalkFunc","chalk","red","yellow","console","process","exit","chalk","withError","ex","closure","predicate","name","message","undefined","withErrnoException","ex","closure","withError","errno","undefined","processEx","ex","error","Error","exitCode","withErrnoException","code","console","chalk","red","path","errno","withError","name","message","JSON","stringify","process","exit","safeExit","func","exitOnFail","result","process","exit","ex","processEx","safeExitAsync","spawnSync","existsSync","chalk","runSteps","name","steps","exitOnFail","messages","safeExit","pkgName","process","env","npm_package_name","console","log","chalk","green","totalStatus","i","command","args","config","entries","gray","argList","Array","isArray","split","existsSync","Error","status","spawnSync","encoding","FORCE_COLOR","shell","stdio","checkResult","spawn","existsSync","chalk","runStepAsync","name","step","exitOnFail","message","Promise","resolve","command","args","config","console","log","chalk","gray","argList","Array","isArray","split","existsSync","Error","spawn","env","FORCE_COLOR","process","shell","stdio","on","code","error","red","yellow","white","join","checkResult","runStepsAsync","steps","messages","safeExitAsync","pkgName","npm_package_name","green","result","i","entries","publint","verbose","pkg","publintPackage","publintAll","runStepsAsync","verboseOptions","runSteps"]}
1
+ {"version":3,"sources":["../../src/lib/checkResult.ts","../../src/lib/processEx.ts","../../src/lib/withError.ts","../../src/lib/withErrnoException.ts","../../src/lib/safeExit.ts","../../src/lib/runSteps.ts","../../src/lib/runStepsAsync.ts","../../src/actions/publint.ts"],"sourcesContent":["import chalk from 'chalk'\n\nexport const checkResult = (name: string, result: number, level: 'error' | 'warn' = 'error', exitOnFail = false) => {\n if (result) {\n const exiting = exitOnFail ? '[Exiting Process]' : '[Continuing]'\n const chalkFunc = level === 'error' ? chalk.red : chalk.yellow\n console[level](chalkFunc(`${name} had ${result} failures ${exiting}`))\n if (exitOnFail) {\n process.exit(result)\n }\n }\n}\n","import chalk from 'chalk'\n\nimport { withErrnoException } from './withErrnoException.ts'\nimport { withError } from './withError.ts'\n\nexport const processEx = (ex: unknown) => {\n const error = typeof ex === 'string' ? new Error(ex) : ex\n const exitCode\n = withErrnoException(error, (error) => {\n if (error.code === 'ENOENT') {\n console.error(chalk.red(`'${error.path}' not found.`))\n } else {\n console.error(chalk.red(`Errno: ${error.code}`))\n }\n return error.errno ?? -1\n })\n ?? withError(error, (error) => {\n console.error(chalk.red(`${error.name}: ${error.message}`))\n return -1\n })\n ?? (() => {\n console.error(chalk.red(`Unexpected Error: ${JSON.stringify(ex, null, 2)}`))\n return -1\n })()\n // This allows us to use a previously set exit code\n process.exit(process.exitCode ?? exitCode)\n}\n","export const withError = <T extends Error = Error>(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ex: any,\n closure: (error: T) => number,\n predicate = (ex: T) => (!!ex.name && !!ex.message),\n) => {\n return predicate(ex as T) ? closure(ex as T) : undefined\n}\n","import { withError } from './withError.ts'\n\nexport const withErrnoException = <T extends NodeJS.ErrnoException = NodeJS.ErrnoException>(\n ex: unknown, closure: (error: T) => number,\n) => {\n return withError<T>(ex, closure, (ex: unknown) => (ex as NodeJS.ErrnoException).errno !== undefined)\n}\n","/** Catch child process a crash and returns the code */\n\nimport { processEx } from './processEx.ts'\n\nconst safeExit = (func: () => number, exitOnFail = true): number => {\n try {\n const result = func()\n if (result && exitOnFail) {\n process.exit(result)\n }\n return result\n } catch (ex) {\n return processEx(ex)\n }\n}\n\nconst safeExitAsync = async (func: () => Promise<number>, exitOnFail = true): Promise<number> => {\n try {\n const result = await func()\n if (result && exitOnFail) {\n process.exit(result)\n }\n return result\n } catch (ex) {\n return processEx(ex)\n }\n}\n\nexport { safeExit, safeExitAsync }\n","import type { SpawnSyncOptionsWithBufferEncoding } from 'node:child_process'\nimport { spawnSync } from 'node:child_process'\nimport { existsSync } from 'node:fs'\n\nimport chalk from 'chalk'\n\nimport { checkResult } from './checkResult.ts'\nimport { safeExit } from './safeExit.ts'\n\nexport type ScriptStep\n = | [/* command */ 'yarn' | 'node' | 'ts-node-script' | 'tsc' | 'jest', /* arg */ string | string[]]\n | [/* command */ string, /* arg */ string | string[], /* config */ SpawnSyncOptionsWithBufferEncoding]\n\nexport const runSteps = (name: string, steps: ScriptStep[], exitOnFail = true, messages?: string[]): number => {\n return safeExit(() => {\n const pkgName = process.env.npm_package_name\n console.log(chalk.green(`${name} [${pkgName}]`))\n let totalStatus = 0\n for (const [i, [command, args, config]] of steps.entries()) {\n if (messages?.[i]) {\n console.log(chalk.gray(messages?.[i]))\n }\n const argList = Array.isArray(args) ? args : args.split(' ')\n if (command === 'node' && !existsSync(argList[0])) {\n throw new Error(`File not found [${argList[0]}]`)\n }\n const status\n = spawnSync(command, Array.isArray(args) ? args : args.split(' '), {\n ...config,\n encoding: 'utf8',\n env: { FORCE_COLOR: '3', ...process.env },\n shell: true,\n stdio: 'inherit',\n }).status ?? 0\n checkResult(name, status, 'error', exitOnFail)\n totalStatus += status ?? 0\n }\n return totalStatus\n }, !!exitOnFail)\n}\n","import { spawn } from 'node:child_process'\nimport { existsSync } from 'node:fs'\n\nimport chalk from 'chalk'\n\nimport { checkResult } from './checkResult.ts'\nimport type { ScriptStep } from './runSteps.ts'\nimport { safeExitAsync } from './safeExit.ts'\n\nexport const runStepAsync = (name: string, step: ScriptStep, exitOnFail = true, message?: string) => {\n return new Promise<number>((resolve) => {\n const [command, args, config] = step\n if (message) {\n console.log(chalk.gray(message))\n }\n const argList = Array.isArray(args) ? args : args.split(' ')\n if (command === 'node' && !existsSync(argList[0])) {\n throw new Error(`File not found [${argList[0]}]`)\n }\n spawn(command, Array.isArray(args) ? args : args.split(' '), {\n ...config,\n env: { FORCE_COLOR: '3', ...process.env },\n shell: true,\n stdio: 'inherit',\n }).on('close', (code) => {\n if (code) {\n console.error(\n chalk.red(\n `Command Exited With Non-Zero Result [${chalk.gray(code)}] | ${chalk.yellow(command)} ${chalk.white(\n Array.isArray(args) ? args.join(' ') : args,\n )}`,\n ),\n )\n checkResult(name, code, 'error', exitOnFail)\n resolve(code)\n } else {\n resolve(0)\n }\n })\n })\n}\n\nexport const runStepsAsync = async (name: string, steps: ScriptStep[], exitOnFail = true, messages?: string[]) => {\n return await safeExitAsync(async () => {\n const pkgName = process.env.npm_package_name\n console.log(chalk.green(`${name} [${pkgName}]`))\n let result = 0\n for (const [i, step] of steps.entries()) {\n result += await runStepAsync(name, step, exitOnFail, messages?.[i])\n }\n return result\n })\n}\n","import { runSteps, runStepsAsync } from '../lib/index.ts'\n\nexport interface PublintParams {\n pkg?: string\n verbose?: boolean\n}\n\nexport interface PublintPackageParams {\n pkg: string\n verbose?: boolean\n}\n\nexport const publint = async ({ verbose, pkg }: PublintParams) => {\n return pkg === undefined\n ? publintAll({ verbose })\n : await publintPackage({ pkg, verbose })\n}\n\nexport const publintPackage = ({ pkg }: PublintPackageParams) => {\n return runStepsAsync(`Publint [${pkg}]`, [['yarn', ['workspace', pkg, 'run', 'package-publint']]])\n}\n\nexport const publintAll = ({ verbose }: PublintParams) => {\n const verboseOptions = verbose ? ['--verbose'] : ['--no-verbose']\n return runSteps('Publint', [['yarn', ['workspaces', 'foreach', '-pA', ...verboseOptions, 'run', 'package-publint']]])\n}\n"],"mappings":";;;;AAAA,OAAOA,WAAW;AAEX,IAAMC,cAAc,wBAACC,MAAcC,QAAgBC,QAA0B,SAASC,aAAa,UAAK;AAC7G,MAAIF,QAAQ;AACV,UAAMG,UAAUD,aAAa,sBAAsB;AACnD,UAAME,YAAYH,UAAU,UAAUI,MAAMC,MAAMD,MAAME;AACxDC,YAAQP,KAAAA,EAAOG,UAAU,GAAGL,IAAAA,QAAYC,MAAAA,aAAmBG,OAAAA,EAAS,CAAA;AACpE,QAAID,YAAY;AACdO,cAAQC,KAAKV,MAAAA;IACf;EACF;AACF,GAT2B;;;ACF3B,OAAOW,YAAW;;;ACAX,IAAMC,YAAY,wBAEvBC,IACAC,SACAC,YAAY,CAACF,QAAW,CAAC,CAACA,IAAGG,QAAQ,CAAC,CAACH,IAAGI,YAAQ;AAElD,SAAOF,UAAUF,EAAAA,IAAWC,QAAQD,EAAAA,IAAWK;AACjD,GAPyB;;;ACElB,IAAMC,qBAAqB,wBAChCC,IAAaC,YAAAA;AAEb,SAAOC,UAAaF,IAAIC,SAAS,CAACD,QAAiBA,IAA6BG,UAAUC,MAAAA;AAC5F,GAJkC;;;AFG3B,IAAMC,YAAY,wBAACC,OAAAA;AACxB,QAAMC,QAAQ,OAAOD,OAAO,WAAW,IAAIE,MAAMF,EAAAA,IAAMA;AACvD,QAAMG,WACFC,mBAAmBH,OAAO,CAACA,WAAAA;AAC3B,QAAIA,OAAMI,SAAS,UAAU;AAC3BC,cAAQL,MAAMM,OAAMC,IAAI,IAAIP,OAAMQ,IAAI,cAAc,CAAA;IACtD,OAAO;AACLH,cAAQL,MAAMM,OAAMC,IAAI,UAAUP,OAAMI,IAAI,EAAE,CAAA;IAChD;AACA,WAAOJ,OAAMS,SAAS;EACxB,CAAA,KACGC,UAAUV,OAAO,CAACA,WAAAA;AACnBK,YAAQL,MAAMM,OAAMC,IAAI,GAAGP,OAAMW,IAAI,KAAKX,OAAMY,OAAO,EAAE,CAAA;AACzD,WAAO;EACT,CAAA,MACI,MAAA;AACFP,YAAQL,MAAMM,OAAMC,IAAI,qBAAqBM,KAAKC,UAAUf,IAAI,MAAM,CAAA,CAAA,EAAI,CAAA;AAC1E,WAAO;EACT,GAAA;AAEFgB,UAAQC,KAAKD,QAAQb,YAAYA,QAAAA;AACnC,GArByB;;;AGDzB,IAAMe,WAAW,wBAACC,MAAoBC,aAAa,SAAI;AACrD,MAAI;AACF,UAAMC,SAASF,KAAAA;AACf,QAAIE,UAAUD,YAAY;AACxBE,cAAQC,KAAKF,MAAAA;IACf;AACA,WAAOA;EACT,SAASG,IAAI;AACX,WAAOC,UAAUD,EAAAA;EACnB;AACF,GAViB;AAYjB,IAAME,gBAAgB,8BAAOP,MAA6BC,aAAa,SAAI;AACzE,MAAI;AACF,UAAMC,SAAS,MAAMF,KAAAA;AACrB,QAAIE,UAAUD,YAAY;AACxBE,cAAQC,KAAKF,MAAAA;IACf;AACA,WAAOA;EACT,SAASG,IAAI;AACX,WAAOC,UAAUD,EAAAA;EACnB;AACF,GAVsB;;;ACftB,SAASG,iBAAiB;AAC1B,SAASC,kBAAkB;AAE3B,OAAOC,YAAW;AASX,IAAMC,WAAW,wBAACC,MAAcC,OAAqBC,aAAa,MAAMC,aAAAA;AAC7E,SAAOC,SAAS,MAAA;AACd,UAAMC,UAAUC,QAAQC,IAAIC;AAC5BC,YAAQC,IAAIC,OAAMC,MAAM,GAAGZ,IAAAA,KAASK,OAAAA,GAAU,CAAA;AAC9C,QAAIQ,cAAc;AAClB,eAAW,CAACC,GAAG,CAACC,SAASC,MAAMC,MAAAA,CAAO,KAAKhB,MAAMiB,QAAO,GAAI;AAC1D,UAAIf,WAAWW,CAAAA,GAAI;AACjBL,gBAAQC,IAAIC,OAAMQ,KAAKhB,WAAWW,CAAAA,CAAE,CAAA;MACtC;AACA,YAAMM,UAAUC,MAAMC,QAAQN,IAAAA,IAAQA,OAAOA,KAAKO,MAAM,GAAA;AACxD,UAAIR,YAAY,UAAU,CAACS,WAAWJ,QAAQ,CAAA,CAAE,GAAG;AACjD,cAAM,IAAIK,MAAM,mBAAmBL,QAAQ,CAAA,CAAE,GAAG;MAClD;AACA,YAAMM,SACFC,UAAUZ,SAASM,MAAMC,QAAQN,IAAAA,IAAQA,OAAOA,KAAKO,MAAM,GAAA,GAAM;QACjE,GAAGN;QACHW,UAAU;QACVrB,KAAK;UAAEsB,aAAa;UAAK,GAAGvB,QAAQC;QAAI;QACxCuB,OAAO;QACPC,OAAO;MACT,CAAA,EAAGL,UAAU;AACfM,kBAAYhC,MAAM0B,QAAQ,SAASxB,UAAAA;AACnCW,qBAAea,UAAU;IAC3B;AACA,WAAOb;EACT,GAAG,CAAC,CAACX,UAAAA;AACP,GA1BwB;;;ACbxB,SAAS+B,aAAa;AACtB,SAASC,cAAAA,mBAAkB;AAE3B,OAAOC,YAAW;AAMX,IAAMC,eAAe,wBAACC,MAAcC,MAAkBC,aAAa,MAAMC,YAAAA;AAC9E,SAAO,IAAIC,QAAgB,CAACC,YAAAA;AAC1B,UAAM,CAACC,SAASC,MAAMC,MAAAA,IAAUP;AAChC,QAAIE,SAAS;AACXM,cAAQC,IAAIC,OAAMC,KAAKT,OAAAA,CAAAA;IACzB;AACA,UAAMU,UAAUC,MAAMC,QAAQR,IAAAA,IAAQA,OAAOA,KAAKS,MAAM,GAAA;AACxD,QAAIV,YAAY,UAAU,CAACW,YAAWJ,QAAQ,CAAA,CAAE,GAAG;AACjD,YAAM,IAAIK,MAAM,mBAAmBL,QAAQ,CAAA,CAAE,GAAG;IAClD;AACAM,UAAMb,SAASQ,MAAMC,QAAQR,IAAAA,IAAQA,OAAOA,KAAKS,MAAM,GAAA,GAAM;MAC3D,GAAGR;MACHY,KAAK;QAAEC,aAAa;QAAK,GAAGC,QAAQF;MAAI;MACxCG,OAAO;MACPC,OAAO;IACT,CAAA,EAAGC,GAAG,SAAS,CAACC,SAAAA;AACd,UAAIA,MAAM;AACRjB,gBAAQkB,MACNhB,OAAMiB,IACJ,wCAAwCjB,OAAMC,KAAKc,IAAAA,CAAAA,OAAYf,OAAMkB,OAAOvB,OAAAA,CAAAA,IAAYK,OAAMmB,MAC5FhB,MAAMC,QAAQR,IAAAA,IAAQA,KAAKwB,KAAK,GAAA,IAAOxB,IAAAA,CAAAA,EACtC,CAAA;AAGPyB,oBAAYhC,MAAM0B,MAAM,SAASxB,UAAAA;AACjCG,gBAAQqB,IAAAA;MACV,OAAO;AACLrB,gBAAQ,CAAA;MACV;IACF,CAAA;EACF,CAAA;AACF,GA/B4B;AAiCrB,IAAM4B,gBAAgB,8BAAOjC,MAAckC,OAAqBhC,aAAa,MAAMiC,aAAAA;AACxF,SAAO,MAAMC,cAAc,YAAA;AACzB,UAAMC,UAAUf,QAAQF,IAAIkB;AAC5B7B,YAAQC,IAAIC,OAAM4B,MAAM,GAAGvC,IAAAA,KAASqC,OAAAA,GAAU,CAAA;AAC9C,QAAIG,SAAS;AACb,eAAW,CAACC,GAAGxC,IAAAA,KAASiC,MAAMQ,QAAO,GAAI;AACvCF,gBAAU,MAAMzC,aAAaC,MAAMC,MAAMC,YAAYiC,WAAWM,CAAAA,CAAE;IACpE;AACA,WAAOD;EACT,CAAA;AACF,GAV6B;;;AC9BtB,IAAMG,UAAU,8BAAO,EAAEC,SAASC,IAAG,MAAiB;AAC3D,SAAOA,QAAQC,SACXC,WAAW;IAAEH;EAAQ,CAAA,IACrB,MAAMI,eAAe;IAAEH;IAAKD;EAAQ,CAAA;AAC1C,GAJuB;AAMhB,IAAMI,iBAAiB,wBAAC,EAAEH,IAAG,MAAwB;AAC1D,SAAOI,cAAc,YAAYJ,GAAAA,KAAQ;IAAC;MAAC;MAAQ;QAAC;QAAaA;QAAK;QAAO;;;GAAoB;AACnG,GAF8B;AAIvB,IAAME,aAAa,wBAAC,EAAEH,QAAO,MAAiB;AACnD,QAAMM,iBAAiBN,UAAU;IAAC;MAAe;IAAC;;AAClD,SAAOO,SAAS,WAAW;IAAC;MAAC;MAAQ;QAAC;QAAc;QAAW;WAAUD;QAAgB;QAAO;;;GAAoB;AACtH,GAH0B;","names":["chalk","checkResult","name","result","level","exitOnFail","exiting","chalkFunc","chalk","red","yellow","console","process","exit","chalk","withError","ex","closure","predicate","name","message","undefined","withErrnoException","ex","closure","withError","errno","undefined","processEx","ex","error","Error","exitCode","withErrnoException","code","console","chalk","red","path","errno","withError","name","message","JSON","stringify","process","exit","safeExit","func","exitOnFail","result","process","exit","ex","processEx","safeExitAsync","spawnSync","existsSync","chalk","runSteps","name","steps","exitOnFail","messages","safeExit","pkgName","process","env","npm_package_name","console","log","chalk","green","totalStatus","i","command","args","config","entries","gray","argList","Array","isArray","split","existsSync","Error","status","spawnSync","encoding","FORCE_COLOR","shell","stdio","checkResult","spawn","existsSync","chalk","runStepAsync","name","step","exitOnFail","message","Promise","resolve","command","args","config","console","log","chalk","gray","argList","Array","isArray","split","existsSync","Error","spawn","env","FORCE_COLOR","process","shell","stdio","on","code","error","red","yellow","white","join","checkResult","runStepsAsync","steps","messages","safeExitAsync","pkgName","npm_package_name","green","result","i","entries","publint","verbose","pkg","undefined","publintAll","publintPackage","runStepsAsync","verboseOptions","runSteps"]}