@xylabs/ts-scripts-yarn3 6.1.16 → 6.2.0

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.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xylabs/ts-scripts-yarn3",
3
- "version": "6.1.16",
3
+ "version": "6.2.0",
4
4
  "description": "TypeScript project scripts",
5
5
  "keywords": [
6
6
  "xylabs",
@@ -42,7 +42,6 @@
42
42
  "package-compile-types": "dist/bin/package/compile-types.mjs",
43
43
  "package-copy-assets-cjs": "dist/bin/package/copy-assets-cjs.mjs",
44
44
  "package-copy-assets-esm": "dist/bin/package/copy-assets-esm.mjs",
45
- "package-deps": "dist/bin/package/deps.mjs",
46
45
  "package-fix": "dist/bin/package/fix.mjs",
47
46
  "package-gen-docs": "dist/bin/package/gen-docs.mjs",
48
47
  "package-lint": "dist/bin/package/lint.mjs",
@@ -68,15 +67,14 @@
68
67
  "@swc/core": "^1.11.13",
69
68
  "@types/node": "^22.13.14",
70
69
  "@types/yargs": "^17.0.33",
71
- "@xylabs/tsconfig": "^6.1.16",
72
- "@xylabs/tsconfig-dom": "^6.1.16",
70
+ "@xylabs/tsconfig": "^6.2.0",
71
+ "@xylabs/tsconfig-dom": "^6.2.0",
73
72
  "async-mutex": "^0.5.0",
74
73
  "chalk": "^5.4.1",
75
74
  "cosmiconfig": "^9.0.0",
76
75
  "cosmiconfig-typescript-loader": "^6.1.0",
77
76
  "cpy": "^11.1.0",
78
77
  "deepmerge": "^4.3.1",
79
- "depcheck": "^1.4.7",
80
78
  "esbuild": "0.25.2",
81
79
  "eslint": "^9.23.0",
82
80
  "find-up": "^7.0.0",
@@ -86,8 +84,6 @@
86
84
  "license-checker": "^25.0.1",
87
85
  "node-cmd": "^5.0.0",
88
86
  "npm-check-updates": "^17.1.16",
89
- "npm-package-json-lint": "^8.0.0",
90
- "npm-package-json-lint-config-default": "^7.0.1",
91
87
  "parse-git-config": "^3.0.0",
92
88
  "picomatch": "^4.0.2",
93
89
  "publint": "^0.3.9",
@@ -112,7 +108,7 @@
112
108
  "@types/license-checker": "^25.0.6",
113
109
  "@types/parse-git-config": "^3.0.4",
114
110
  "@types/picomatch": "^3.0.2",
115
- "@xylabs/tsconfig": "^6.1.16",
111
+ "@xylabs/tsconfig": "^6.2.0",
116
112
  "publint": "^0.3.9",
117
113
  "rimraf": "^6.0.1",
118
114
  "typescript": "^5.8.2"
@@ -1,170 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
- // src/actions/deps.ts
5
- import chalk4 from "chalk";
6
-
7
- // src/lib/checkResult.ts
8
- import chalk from "chalk";
9
- var checkResult = /* @__PURE__ */ __name((name, result, level = "error", exitOnFail = false) => {
10
- if (result) {
11
- const exiting = exitOnFail ? "[Exiting Process]" : "[Continuing]";
12
- const chalkFunc = level === "error" ? chalk.red : chalk.yellow;
13
- console[level](chalkFunc(`${name} had ${result} failures ${exiting}`));
14
- if (exitOnFail) {
15
- process.exit(result);
16
- }
17
- }
18
- }, "checkResult");
19
-
20
- // src/lib/processEx.ts
21
- import chalk2 from "chalk";
22
-
23
- // src/lib/withError.ts
24
- var withError = /* @__PURE__ */ __name((ex, closure, predicate = (ex2) => !!ex2.name && !!ex2.message) => {
25
- return predicate(ex) ? closure(ex) : void 0;
26
- }, "withError");
27
-
28
- // src/lib/withErrnoException.ts
29
- var withErrnoException = /* @__PURE__ */ __name((ex, closure) => {
30
- return withError(ex, closure, (ex2) => ex2.errno !== void 0);
31
- }, "withErrnoException");
32
-
33
- // src/lib/processEx.ts
34
- var processEx = /* @__PURE__ */ __name((ex) => {
35
- const error = typeof ex === "string" ? new Error(ex) : ex;
36
- const exitCode = withErrnoException(error, (error2) => {
37
- if (error2.code === "ENOENT") {
38
- console.error(chalk2.red(`'${error2.path}' not found.`));
39
- } else {
40
- console.error(chalk2.red(`Errno: ${error2.code}`));
41
- }
42
- return error2.errno ?? -1;
43
- }) ?? withError(error, (error2) => {
44
- console.error(chalk2.red(`${error2.name}: ${error2.message}`));
45
- return -1;
46
- }) ?? (() => {
47
- console.error(chalk2.red(`Unexpected Error: ${JSON.stringify(ex, null, 2)}`));
48
- return -1;
49
- })();
50
- process.exit(process.exitCode ?? exitCode);
51
- }, "processEx");
52
-
53
- // src/lib/safeExit.ts
54
- var safeExit = /* @__PURE__ */ __name((func, exitOnFail = true) => {
55
- try {
56
- const result = func();
57
- if (result && exitOnFail) {
58
- process.exit(result);
59
- }
60
- return result;
61
- } catch (ex) {
62
- return processEx(ex);
63
- }
64
- }, "safeExit");
65
-
66
- // src/lib/runSteps.ts
67
- import { spawnSync } from "node:child_process";
68
- import { existsSync } from "node:fs";
69
- import chalk3 from "chalk";
70
- var runSteps = /* @__PURE__ */ __name((name, steps, exitOnFail = true, messages) => {
71
- return safeExit(() => {
72
- const pkgName = process.env.npm_package_name;
73
- console.log(chalk3.green(`${name} [${pkgName}]`));
74
- let totalStatus = 0;
75
- for (const [i, [command, args, config]] of steps.entries()) {
76
- if (messages?.[i]) {
77
- console.log(chalk3.gray(messages?.[i]));
78
- }
79
- const argList = Array.isArray(args) ? args : args.split(" ");
80
- if (command === "node" && !existsSync(argList[0])) {
81
- throw new Error(`File not found [${argList[0]}]`);
82
- }
83
- const status = spawnSync(command, Array.isArray(args) ? args : args.split(" "), {
84
- ...config,
85
- encoding: "utf8",
86
- env: {
87
- FORCE_COLOR: "3",
88
- ...process.env
89
- },
90
- shell: true,
91
- stdio: "inherit"
92
- }).status ?? 0;
93
- checkResult(name, status, "error", exitOnFail);
94
- totalStatus += status ?? 0;
95
- }
96
- return totalStatus;
97
- }, !!exitOnFail);
98
- }, "runSteps");
99
-
100
- // src/actions/deps.ts
101
- var deps = /* @__PURE__ */ __name(({ pkg, incremental }) => {
102
- pkg ? depsPackage({
103
- pkg
104
- }) : depsAll({
105
- incremental
106
- });
107
- return 0;
108
- }, "deps");
109
- var depsPackage = /* @__PURE__ */ __name(({ pkg }) => {
110
- const steps = [
111
- [
112
- "yarn",
113
- [
114
- "workspace",
115
- pkg,
116
- "run",
117
- "package-deps"
118
- ]
119
- ]
120
- ];
121
- return runSteps(`Deps [${pkg}]`, [
122
- ...steps
123
- ]);
124
- }, "depsPackage");
125
- var depsAll = /* @__PURE__ */ __name(({ incremental, jobs, verbose }) => {
126
- const start = Date.now();
127
- const jobsOptions = jobs ? [
128
- "-j",
129
- `${jobs}`
130
- ] : [];
131
- const verboseOptions = verbose ? [
132
- "--verbose"
133
- ] : [
134
- "--no-verbose"
135
- ];
136
- if (jobs) {
137
- console.log(chalk4.blue(`Jobs set to [${jobs}]`));
138
- }
139
- const incrementalOptions = incremental ? [
140
- "--since",
141
- "-pA"
142
- ] : [
143
- "-pA"
144
- ];
145
- const steps = [
146
- [
147
- "yarn",
148
- [
149
- "workspaces",
150
- "foreach",
151
- ...jobsOptions,
152
- ...incrementalOptions,
153
- ...verboseOptions,
154
- "run",
155
- "package-deps"
156
- ]
157
- ]
158
- ];
159
- const result = runSteps(`Deps${incremental ? "-Incremental" : ""} [All]`, [
160
- ...steps
161
- ]);
162
- console.log(`${chalk4.gray("Dep checked in")} [${chalk4.magenta(((Date.now() - start) / 1e3).toFixed(2))}] ${chalk4.gray("seconds")}`);
163
- return result;
164
- }, "depsAll");
165
- export {
166
- deps,
167
- depsAll,
168
- depsPackage
169
- };
170
- //# sourceMappingURL=deps.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/actions/deps.ts","../../src/lib/checkResult.ts","../../src/lib/processEx.ts","../../src/lib/withError.ts","../../src/lib/withErrnoException.ts","../../src/lib/safeExit.ts","../../src/lib/runSteps.ts"],"sourcesContent":["import chalk from 'chalk'\n\nimport type { ScriptStep } from '../lib/index.ts'\nimport { runSteps } from '../lib/index.ts'\n\nexport interface DepsParams {\n incremental?: boolean\n jobs?: number\n pkg?: string\n verbose?: boolean\n}\n\nexport interface DepsPackageParams { pkg: string }\n\nexport const deps = ({ pkg, incremental }: DepsParams) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n pkg ? depsPackage({ pkg }) : depsAll({ incremental })\n // returning 0 here since we never wants deps to be fatal\n return 0\n}\n\nexport const depsPackage = ({ pkg }: DepsPackageParams) => {\n const steps: ScriptStep[] = [['yarn', ['workspace', pkg, 'run', 'package-deps']]]\n\n return runSteps(`Deps [${pkg}]`, [...steps])\n}\n\nexport const depsAll = ({\n incremental, jobs, verbose,\n}: DepsParams) => {\n const start = Date.now()\n const jobsOptions = jobs ? ['-j', `${jobs}`] : []\n const verboseOptions = verbose ? ['--verbose'] : ['--no-verbose']\n if (jobs) {\n console.log(chalk.blue(`Jobs set to [${jobs}]`))\n }\n const incrementalOptions = incremental ? ['--since', '-pA'] : ['-pA']\n const steps: ScriptStep[] = [['yarn', ['workspaces', 'foreach', ...jobsOptions, ...incrementalOptions, ...verboseOptions, 'run', 'package-deps']]]\n\n const result = runSteps(`Deps${incremental ? '-Incremental' : ''} [All]`, [...steps])\n console.log(`${chalk.gray('Dep checked in')} [${chalk.magenta(((Date.now() - start) / 1000).toFixed(2))}] ${chalk.gray('seconds')}`)\n return result\n}\n","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"],"mappings":"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","names":["chalk","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","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","deps","pkg","incremental","depsPackage","depsAll","steps","runSteps","jobs","verbose","start","Date","now","jobsOptions","verboseOptions","console","log","chalk","blue","incrementalOptions","result","gray","magenta","toFixed"]}
@@ -1,180 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
- // src/actions/package/deps.ts
5
- import { existsSync, readFileSync } from "node:fs";
6
- import { cwd } from "node:process";
7
- import chalk2 from "chalk";
8
- import depcheck from "depcheck";
9
-
10
- // src/lib/checkResult.ts
11
- import chalk from "chalk";
12
- var checkResult = /* @__PURE__ */ __name((name, result, level = "error", exitOnFail = false) => {
13
- if (result) {
14
- const exiting = exitOnFail ? "[Exiting Process]" : "[Continuing]";
15
- const chalkFunc = level === "error" ? chalk.red : chalk.yellow;
16
- console[level](chalkFunc(`${name} had ${result} failures ${exiting}`));
17
- if (exitOnFail) {
18
- process.exit(result);
19
- }
20
- }
21
- }, "checkResult");
22
-
23
- // src/actions/package/deps.ts
24
- var special = depcheck.special;
25
- var defaultIgnorePatterns = [
26
- "*.d.ts",
27
- "dist",
28
- ".*",
29
- "node_modules"
30
- ];
31
- var defaultIgnoreDevDeps = [
32
- "@xylabs/ts-scripts-yarn3",
33
- "@xylabs/tsconfig",
34
- "@xylabs/tsconfig-dom",
35
- "@xylabs/tsconfig-react",
36
- "typescript"
37
- ];
38
- var defaultIgnoreDevPatterns = [
39
- "*.stories.*",
40
- "*.spec.*",
41
- "spec",
42
- "stories",
43
- "tsconfig.json"
44
- ];
45
- var reportUnused = /* @__PURE__ */ __name((name, unused) => {
46
- if (unused.length > 0) {
47
- const message = [
48
- chalk2.yellow(`${unused.length} Unused ${name}`)
49
- ];
50
- for (const value of unused) message.push(chalk2.gray(` ${value}`));
51
- console.log(message.join("\n"));
52
- }
53
- }, "reportUnused");
54
- var reportMissing = /* @__PURE__ */ __name((name, missing) => {
55
- if (Object.keys(missing).length > 0) {
56
- const message = [
57
- chalk2.yellow(`${Object.entries(missing).length} Missing ${name}`)
58
- ];
59
- for (const [key, value] of Object.entries(missing)) {
60
- message.push(`${key}`, chalk2.gray(` ${value.at(0)}`));
61
- }
62
- console.log(chalk2.yellow(message.join("\n")));
63
- }
64
- }, "reportMissing");
65
- var analyzeDeps = /* @__PURE__ */ __name(async (pkg, ignoreMatches) => {
66
- const packageContent = existsSync(`${pkg}/package.json`) ? JSON.parse(readFileSync(`${pkg}/package.json`, {
67
- encoding: "utf8"
68
- })) : void 0;
69
- const [srcUnused, allUnused] = await Promise.all([
70
- depcheck(`${pkg}/src`, {
71
- ignoreMatches,
72
- ignorePatterns: [
73
- ...defaultIgnoreDevPatterns,
74
- ...defaultIgnorePatterns
75
- ],
76
- package: packageContent
77
- }),
78
- depcheck(`${pkg}/.`, {
79
- ignoreMatches: [
80
- ...ignoreMatches,
81
- ...defaultIgnoreDevDeps
82
- ],
83
- ignorePatterns: [
84
- ...defaultIgnorePatterns
85
- ],
86
- package: packageContent,
87
- specials: [
88
- special.eslint,
89
- special.babel,
90
- special.bin,
91
- special.prettier,
92
- special.jest,
93
- special.mocha
94
- ]
95
- })
96
- ]);
97
- const unusedDeps = srcUnused.dependencies;
98
- const unusedDevDeps = allUnused.devDependencies;
99
- const usedDeps = srcUnused.using;
100
- const usedDevDeps = allUnused.using;
101
- const missing = {
102
- ...srcUnused.missing,
103
- ...allUnused.missing
104
- };
105
- const { invalidDirs, invalidFiles } = allUnused;
106
- return {
107
- invalidDirs,
108
- invalidFiles,
109
- missing,
110
- unusedDeps,
111
- unusedDevDeps,
112
- usedDeps,
113
- usedDevDeps
114
- };
115
- }, "analyzeDeps");
116
- var packageDeps = /* @__PURE__ */ __name(async () => {
117
- const pkg = process.env.INIT_CWD ?? cwd();
118
- const pkgName = process.env.npm_package_name;
119
- const packageContent = existsSync(`${pkg}/package.json`) ? JSON.parse(readFileSync(`${pkg}/package.json`, {
120
- encoding: "utf8"
121
- })) : void 0;
122
- const rawIgnore = existsSync(`${pkg}/.depcheckrc`) ? readFileSync(`${pkg}/.depcheckrc`, {
123
- encoding: "utf8"
124
- }).replace("ignores:", '"ignores":') : void 0;
125
- let ignoreMatches = [];
126
- try {
127
- ignoreMatches = rawIgnore ? JSON.parse(`{${rawIgnore}}`).ignores : [];
128
- } catch (ex) {
129
- const error = ex;
130
- console.log(`${pkgName} [${error.message}] Failed to parse .depcheckrc [${rawIgnore}]`);
131
- }
132
- const { invalidDirs, invalidFiles, unusedDeps, unusedDevDeps, usedDeps, usedDevDeps, missing } = await analyzeDeps(pkg, ignoreMatches);
133
- const declaredDeps = Object.keys(packageContent.dependencies ?? {});
134
- const declaredPeerDeps = Object.keys(packageContent.peerDependencies ?? {});
135
- const declaredDevDeps = Object.keys(packageContent.devDependencies ?? {});
136
- const missingDeps = Object.keys(usedDeps).filter((key) => !declaredDeps.includes(key) && !declaredPeerDeps.includes(key) && !key.startsWith("@types/"));
137
- const missingDevDeps = Object.keys(usedDevDeps).filter((key) => !declaredDevDeps.includes(key) && !declaredDeps.includes(key));
138
- const missingDepsObject = {};
139
- for (const key of missingDeps) {
140
- missingDepsObject[key] = missing[key] ?? [
141
- `devDep should be dep [${key}]`
142
- ];
143
- }
144
- const missingDevDepsObject = {};
145
- for (const key of missingDevDeps) {
146
- if (missing[key]) {
147
- missingDevDepsObject[key] = missing[key];
148
- }
149
- }
150
- const errorCounts = [
151
- unusedDeps.length,
152
- unusedDevDeps.length,
153
- Object.entries(invalidDirs).length,
154
- Object.entries(invalidFiles).length,
155
- Object.entries(missingDepsObject).length,
156
- Object.entries(missingDevDepsObject).length
157
- ];
158
- const errorCount = errorCounts.reduce((prev, count) => prev + count, 0);
159
- if (errorCount > 0) {
160
- console.log(`Deps [${pkgName}] = (${JSON.stringify(errorCounts)})`);
161
- } else {
162
- console.log(`Deps [${pkgName}] - Ok`);
163
- }
164
- reportUnused("dependencies", unusedDeps);
165
- reportUnused("devDependencies", unusedDevDeps);
166
- if (Object.entries(invalidDirs).length > 0) {
167
- for (const [key, value] of Object.entries(invalidDirs)) console.warn(chalk2.gray(`Invalid Dir: ${key}: ${value}`));
168
- }
169
- if (Object.entries(invalidFiles).length > 0) {
170
- for (const [key, value] of Object.entries(invalidFiles)) console.warn(chalk2.gray(`Invalid File: ${key}: ${value}`));
171
- }
172
- reportMissing("dependencies", missingDepsObject);
173
- reportMissing("devDependencies", missingDevDepsObject);
174
- checkResult(`Deps [${pkgName}]`, errorCount, "warn", false);
175
- return 0;
176
- }, "packageDeps");
177
- export {
178
- packageDeps
179
- };
180
- //# sourceMappingURL=deps.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/actions/package/deps.ts","../../../src/lib/checkResult.ts"],"sourcesContent":["/* eslint-disable max-statements */\nimport { existsSync, readFileSync } from 'node:fs'\nimport { cwd } from 'node:process'\n\nimport chalk from 'chalk'\nimport depcheck from 'depcheck'\nconst special = depcheck.special\n\nimport { checkResult } from '../../lib/index.ts'\n\nconst defaultIgnorePatterns = ['*.d.ts', 'dist', '.*', 'node_modules']\nconst defaultIgnoreDevDeps = [\n '@xylabs/ts-scripts-yarn3',\n '@xylabs/tsconfig',\n '@xylabs/tsconfig-dom',\n '@xylabs/tsconfig-react',\n 'typescript',\n]\nconst defaultIgnoreDevPatterns = ['*.stories.*', '*.spec.*', 'spec', 'stories', 'tsconfig.json']\n\nconst reportUnused = (name: string, unused: depcheck.Results['dependencies']) => {\n if (unused.length > 0) {\n const message = [chalk.yellow(`${unused.length} Unused ${name}`)]\n for (const value of unused) message.push(chalk.gray(` ${value}`))\n console.log(message.join('\\n'))\n }\n}\n\nconst reportMissing = (name: string, missing: depcheck.Results['missing']) => {\n if (Object.keys(missing).length > 0) {\n const message = [chalk.yellow(`${Object.entries(missing).length} Missing ${name}`)]\n for (const [key, value] of Object.entries(missing)) {\n message.push(`${key}`, chalk.gray(` ${value.at(0)}`))\n }\n console.log(chalk.yellow(message.join('\\n')))\n }\n}\n\nconst analyzeDeps = async (pkg: string, ignoreMatches: string[]) => {\n const packageContent = existsSync(`${pkg}/package.json`) ? JSON.parse(readFileSync(`${pkg}/package.json`, { encoding: 'utf8' })) : undefined\n const [srcUnused, allUnused] = await Promise.all([\n depcheck(`${pkg}/src`, {\n ignoreMatches,\n ignorePatterns: [...defaultIgnoreDevPatterns, ...defaultIgnorePatterns],\n package: packageContent,\n }),\n depcheck(`${pkg}/.`, {\n ignoreMatches: [...ignoreMatches, ...defaultIgnoreDevDeps],\n ignorePatterns: [...defaultIgnorePatterns],\n package: packageContent,\n specials: [special.eslint, special.babel, special.bin, special.prettier, special.jest, special.mocha],\n }),\n ])\n\n const unusedDeps = srcUnused.dependencies\n const unusedDevDeps = allUnused.devDependencies\n const usedDeps = srcUnused.using\n const usedDevDeps = allUnused.using\n const missing = { ...srcUnused.missing, ...allUnused.missing }\n const { invalidDirs, invalidFiles } = allUnused\n\n return {\n invalidDirs, invalidFiles, missing, unusedDeps, unusedDevDeps, usedDeps, usedDevDeps,\n }\n}\n\nexport const packageDeps = async () => {\n const pkg = process.env.INIT_CWD ?? cwd()\n const pkgName = process.env.npm_package_name\n\n const packageContent = existsSync(`${pkg}/package.json`) ? JSON.parse(readFileSync(`${pkg}/package.json`, { encoding: 'utf8' })) : undefined\n\n const rawIgnore\n = existsSync(`${pkg}/.depcheckrc`) ? readFileSync(`${pkg}/.depcheckrc`, { encoding: 'utf8' }).replace('ignores:', '\"ignores\":') : undefined\n let ignoreMatches: string[] = []\n try {\n ignoreMatches = rawIgnore ? (JSON.parse(`{${rawIgnore}}`).ignores as string[]) : []\n } catch (ex) {\n const error = ex as Error\n console.log(`${pkgName} [${error.message}] Failed to parse .depcheckrc [${rawIgnore}]`)\n }\n\n const {\n invalidDirs, invalidFiles, unusedDeps, unusedDevDeps, usedDeps, usedDevDeps, missing,\n } = await analyzeDeps(pkg, ignoreMatches)\n\n const declaredDeps = Object.keys(packageContent.dependencies ?? {})\n const declaredPeerDeps = Object.keys(packageContent.peerDependencies ?? {})\n const declaredDevDeps = Object.keys(packageContent.devDependencies ?? {})\n\n const missingDeps = Object.keys(usedDeps).filter(\n key => !declaredDeps.includes(key) && !declaredPeerDeps.includes(key) && !key.startsWith('@types/'),\n )\n\n const missingDevDeps = Object.keys(usedDevDeps).filter(key => !declaredDevDeps.includes(key) && !declaredDeps.includes(key))\n\n const missingDepsObject: Record<string, string[]> = {}\n for (const key of missingDeps) {\n missingDepsObject[key] = missing[key] ?? [`devDep should be dep [${key}]`]\n }\n\n const missingDevDepsObject: Record<string, string[]> = {}\n for (const key of missingDevDeps) {\n if (missing[key]) {\n missingDevDepsObject[key] = missing[key]\n }\n }\n\n const errorCounts = [\n unusedDeps.length,\n unusedDevDeps.length,\n Object.entries(invalidDirs).length,\n Object.entries(invalidFiles).length,\n Object.entries(missingDepsObject).length,\n Object.entries(missingDevDepsObject).length,\n ]\n\n const errorCount = errorCounts.reduce((prev, count) => prev + count, 0)\n\n if (errorCount > 0) {\n console.log(`Deps [${pkgName}] = (${JSON.stringify(errorCounts)})`)\n } else {\n console.log(`Deps [${pkgName}] - Ok`)\n }\n\n reportUnused('dependencies', unusedDeps)\n reportUnused('devDependencies', unusedDevDeps)\n\n if (Object.entries(invalidDirs).length > 0) {\n for (const [key, value] of Object.entries(invalidDirs)) console.warn(chalk.gray(`Invalid Dir: ${key}: ${value}`))\n }\n\n if (Object.entries(invalidFiles).length > 0) {\n for (const [key, value] of Object.entries(invalidFiles)) console.warn(chalk.gray(`Invalid File: ${key}: ${value}`))\n }\n\n reportMissing('dependencies', missingDepsObject)\n reportMissing('devDependencies', missingDevDepsObject)\n\n checkResult(`Deps [${pkgName}]`, errorCount, 'warn', false)\n\n // returning 0 here since we never want deps to be fatal\n return 0\n}\n","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"],"mappings":"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","names":["existsSync","readFileSync","cwd","chalk","depcheck","chalk","checkResult","name","result","level","exitOnFail","exiting","chalkFunc","chalk","red","yellow","console","process","exit","special","depcheck","defaultIgnorePatterns","defaultIgnoreDevDeps","defaultIgnoreDevPatterns","reportUnused","name","unused","length","message","chalk","yellow","value","push","gray","console","log","join","reportMissing","missing","Object","keys","entries","key","at","analyzeDeps","pkg","ignoreMatches","packageContent","existsSync","JSON","parse","readFileSync","encoding","undefined","srcUnused","allUnused","Promise","all","ignorePatterns","package","specials","eslint","babel","bin","prettier","jest","mocha","unusedDeps","dependencies","unusedDevDeps","devDependencies","usedDeps","using","usedDevDeps","invalidDirs","invalidFiles","packageDeps","process","env","INIT_CWD","cwd","pkgName","npm_package_name","rawIgnore","replace","ignores","ex","error","declaredDeps","declaredPeerDeps","peerDependencies","declaredDevDeps","missingDeps","filter","includes","startsWith","missingDevDeps","missingDepsObject","missingDevDepsObject","errorCounts","errorCount","reduce","prev","count","stringify","warn","checkResult"]}
@@ -1,185 +0,0 @@
1
- #!/usr/bin/env node
2
- var __defProp = Object.defineProperty;
3
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
4
-
5
- // src/bin/package/deps.ts
6
- import chalk3 from "chalk";
7
-
8
- // src/lib/checkResult.ts
9
- import chalk from "chalk";
10
- var checkResult = /* @__PURE__ */ __name((name, result, level = "error", exitOnFail = false) => {
11
- if (result) {
12
- const exiting = exitOnFail ? "[Exiting Process]" : "[Continuing]";
13
- const chalkFunc = level === "error" ? chalk.red : chalk.yellow;
14
- console[level](chalkFunc(`${name} had ${result} failures ${exiting}`));
15
- if (exitOnFail) {
16
- process.exit(result);
17
- }
18
- }
19
- }, "checkResult");
20
-
21
- // src/actions/package/deps.ts
22
- import { existsSync, readFileSync } from "node:fs";
23
- import { cwd } from "node:process";
24
- import chalk2 from "chalk";
25
- import depcheck from "depcheck";
26
- var special = depcheck.special;
27
- var defaultIgnorePatterns = [
28
- "*.d.ts",
29
- "dist",
30
- ".*",
31
- "node_modules"
32
- ];
33
- var defaultIgnoreDevDeps = [
34
- "@xylabs/ts-scripts-yarn3",
35
- "@xylabs/tsconfig",
36
- "@xylabs/tsconfig-dom",
37
- "@xylabs/tsconfig-react",
38
- "typescript"
39
- ];
40
- var defaultIgnoreDevPatterns = [
41
- "*.stories.*",
42
- "*.spec.*",
43
- "spec",
44
- "stories",
45
- "tsconfig.json"
46
- ];
47
- var reportUnused = /* @__PURE__ */ __name((name, unused) => {
48
- if (unused.length > 0) {
49
- const message = [
50
- chalk2.yellow(`${unused.length} Unused ${name}`)
51
- ];
52
- for (const value of unused) message.push(chalk2.gray(` ${value}`));
53
- console.log(message.join("\n"));
54
- }
55
- }, "reportUnused");
56
- var reportMissing = /* @__PURE__ */ __name((name, missing) => {
57
- if (Object.keys(missing).length > 0) {
58
- const message = [
59
- chalk2.yellow(`${Object.entries(missing).length} Missing ${name}`)
60
- ];
61
- for (const [key, value] of Object.entries(missing)) {
62
- message.push(`${key}`, chalk2.gray(` ${value.at(0)}`));
63
- }
64
- console.log(chalk2.yellow(message.join("\n")));
65
- }
66
- }, "reportMissing");
67
- var analyzeDeps = /* @__PURE__ */ __name(async (pkg, ignoreMatches) => {
68
- const packageContent = existsSync(`${pkg}/package.json`) ? JSON.parse(readFileSync(`${pkg}/package.json`, {
69
- encoding: "utf8"
70
- })) : void 0;
71
- const [srcUnused, allUnused] = await Promise.all([
72
- depcheck(`${pkg}/src`, {
73
- ignoreMatches,
74
- ignorePatterns: [
75
- ...defaultIgnoreDevPatterns,
76
- ...defaultIgnorePatterns
77
- ],
78
- package: packageContent
79
- }),
80
- depcheck(`${pkg}/.`, {
81
- ignoreMatches: [
82
- ...ignoreMatches,
83
- ...defaultIgnoreDevDeps
84
- ],
85
- ignorePatterns: [
86
- ...defaultIgnorePatterns
87
- ],
88
- package: packageContent,
89
- specials: [
90
- special.eslint,
91
- special.babel,
92
- special.bin,
93
- special.prettier,
94
- special.jest,
95
- special.mocha
96
- ]
97
- })
98
- ]);
99
- const unusedDeps = srcUnused.dependencies;
100
- const unusedDevDeps = allUnused.devDependencies;
101
- const usedDeps = srcUnused.using;
102
- const usedDevDeps = allUnused.using;
103
- const missing = {
104
- ...srcUnused.missing,
105
- ...allUnused.missing
106
- };
107
- const { invalidDirs, invalidFiles } = allUnused;
108
- return {
109
- invalidDirs,
110
- invalidFiles,
111
- missing,
112
- unusedDeps,
113
- unusedDevDeps,
114
- usedDeps,
115
- usedDevDeps
116
- };
117
- }, "analyzeDeps");
118
- var packageDeps = /* @__PURE__ */ __name(async () => {
119
- const pkg = process.env.INIT_CWD ?? cwd();
120
- const pkgName = process.env.npm_package_name;
121
- const packageContent = existsSync(`${pkg}/package.json`) ? JSON.parse(readFileSync(`${pkg}/package.json`, {
122
- encoding: "utf8"
123
- })) : void 0;
124
- const rawIgnore = existsSync(`${pkg}/.depcheckrc`) ? readFileSync(`${pkg}/.depcheckrc`, {
125
- encoding: "utf8"
126
- }).replace("ignores:", '"ignores":') : void 0;
127
- let ignoreMatches = [];
128
- try {
129
- ignoreMatches = rawIgnore ? JSON.parse(`{${rawIgnore}}`).ignores : [];
130
- } catch (ex) {
131
- const error = ex;
132
- console.log(`${pkgName} [${error.message}] Failed to parse .depcheckrc [${rawIgnore}]`);
133
- }
134
- const { invalidDirs, invalidFiles, unusedDeps, unusedDevDeps, usedDeps, usedDevDeps, missing } = await analyzeDeps(pkg, ignoreMatches);
135
- const declaredDeps = Object.keys(packageContent.dependencies ?? {});
136
- const declaredPeerDeps = Object.keys(packageContent.peerDependencies ?? {});
137
- const declaredDevDeps = Object.keys(packageContent.devDependencies ?? {});
138
- const missingDeps = Object.keys(usedDeps).filter((key) => !declaredDeps.includes(key) && !declaredPeerDeps.includes(key) && !key.startsWith("@types/"));
139
- const missingDevDeps = Object.keys(usedDevDeps).filter((key) => !declaredDevDeps.includes(key) && !declaredDeps.includes(key));
140
- const missingDepsObject = {};
141
- for (const key of missingDeps) {
142
- missingDepsObject[key] = missing[key] ?? [
143
- `devDep should be dep [${key}]`
144
- ];
145
- }
146
- const missingDevDepsObject = {};
147
- for (const key of missingDevDeps) {
148
- if (missing[key]) {
149
- missingDevDepsObject[key] = missing[key];
150
- }
151
- }
152
- const errorCounts = [
153
- unusedDeps.length,
154
- unusedDevDeps.length,
155
- Object.entries(invalidDirs).length,
156
- Object.entries(invalidFiles).length,
157
- Object.entries(missingDepsObject).length,
158
- Object.entries(missingDevDepsObject).length
159
- ];
160
- const errorCount = errorCounts.reduce((prev, count) => prev + count, 0);
161
- if (errorCount > 0) {
162
- console.log(`Deps [${pkgName}] = (${JSON.stringify(errorCounts)})`);
163
- } else {
164
- console.log(`Deps [${pkgName}] - Ok`);
165
- }
166
- reportUnused("dependencies", unusedDeps);
167
- reportUnused("devDependencies", unusedDevDeps);
168
- if (Object.entries(invalidDirs).length > 0) {
169
- for (const [key, value] of Object.entries(invalidDirs)) console.warn(chalk2.gray(`Invalid Dir: ${key}: ${value}`));
170
- }
171
- if (Object.entries(invalidFiles).length > 0) {
172
- for (const [key, value] of Object.entries(invalidFiles)) console.warn(chalk2.gray(`Invalid File: ${key}: ${value}`));
173
- }
174
- reportMissing("dependencies", missingDepsObject);
175
- reportMissing("devDependencies", missingDevDepsObject);
176
- checkResult(`Deps [${pkgName}]`, errorCount, "warn", false);
177
- return 0;
178
- }, "packageDeps");
179
-
180
- // src/bin/package/deps.ts
181
- packageDeps().then((value) => process.exitCode = value).catch((ex) => {
182
- console.error(`Deps Failed: ${chalk3.red(ex)}`);
183
- process.exitCode = 0;
184
- });
185
- //# sourceMappingURL=deps.mjs.map