@nlabs/lex 1.46.1 → 1.47.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.
Files changed (72) hide show
  1. package/__mocks__/LexConfig.js +20 -0
  2. package/__mocks__/boxen.js +7 -0
  3. package/__mocks__/build.js +16 -0
  4. package/__mocks__/chalk.js +23 -0
  5. package/__mocks__/compile.js +8 -0
  6. package/__mocks__/execa.js +21 -0
  7. package/__mocks__/ora.js +17 -0
  8. package/__mocks__/versions.js +12 -0
  9. package/dist/LexConfig.js +72 -14
  10. package/dist/commands/ai/ai.js +303 -0
  11. package/dist/commands/ai/index.js +7 -0
  12. package/dist/commands/build/build.js +350 -0
  13. package/dist/commands/clean/clean.js +31 -0
  14. package/dist/commands/compile/compile.js +195 -0
  15. package/dist/commands/config/config.js +43 -0
  16. package/dist/commands/copy/copy.js +38 -0
  17. package/dist/commands/create/create.js +124 -0
  18. package/dist/commands/dev/dev.js +70 -0
  19. package/dist/commands/init/init.js +93 -0
  20. package/dist/commands/link/link.js +15 -0
  21. package/dist/commands/lint/lint.js +656 -0
  22. package/dist/commands/migrate/migrate.js +37 -0
  23. package/dist/commands/publish/publish.js +104 -0
  24. package/dist/commands/test/test.js +327 -0
  25. package/dist/commands/update/update.js +62 -0
  26. package/dist/commands/upgrade/upgrade.js +47 -0
  27. package/dist/commands/versions/versions.js +41 -0
  28. package/dist/create/changelog.js +3 -3
  29. package/dist/index.js +35 -0
  30. package/dist/jest.config.lex.d.ts +2 -0
  31. package/dist/lex.js +25 -22
  32. package/dist/types.js +1 -0
  33. package/dist/utils/aiService.js +290 -0
  34. package/dist/utils/app.js +4 -4
  35. package/dist/utils/file.js +1 -1
  36. package/dist/utils/log.js +2 -1
  37. package/dist/utils/reactShim.js +3 -3
  38. package/dist/webpack.config.d.ts +2 -0
  39. package/eslint.config.js +10 -0
  40. package/index.cjs +20 -0
  41. package/jest.config.cjs +31 -27
  42. package/jest.config.lex.js +90 -38
  43. package/jest.setup.js +5 -0
  44. package/lex.config.js +50 -0
  45. package/package.json +70 -50
  46. package/{.postcssrc.js → postcss.config.js} +21 -9
  47. package/tsconfig.build.json +7 -16
  48. package/tsconfig.json +2 -1
  49. package/webpack.config.js +136 -77
  50. package/.eslintrc +0 -45
  51. package/dist/commands/build.js +0 -265
  52. package/dist/commands/bulid.test.js +0 -317
  53. package/dist/commands/clean.js +0 -31
  54. package/dist/commands/clean.test.js +0 -63
  55. package/dist/commands/compile.js +0 -195
  56. package/dist/commands/compile.test.js +0 -93
  57. package/dist/commands/config.js +0 -43
  58. package/dist/commands/copy.js +0 -38
  59. package/dist/commands/create.js +0 -116
  60. package/dist/commands/dev.js +0 -70
  61. package/dist/commands/init.js +0 -93
  62. package/dist/commands/link.js +0 -15
  63. package/dist/commands/lint.js +0 -179
  64. package/dist/commands/migrate.js +0 -37
  65. package/dist/commands/publish.js +0 -104
  66. package/dist/commands/test.js +0 -190
  67. package/dist/commands/update.js +0 -64
  68. package/dist/commands/upgrade.js +0 -47
  69. package/dist/commands/versions.js +0 -41
  70. package/dist/commands/versions.test.js +0 -49
  71. package/dist/lint.js +0 -11
  72. package/jest.setup.ts +0 -3
@@ -1,104 +0,0 @@
1
- import { execa } from "execa";
2
- import semver from "semver";
3
- import { LexConfig } from "../LexConfig.js";
4
- import { createSpinner, getPackageJson, setPackageJson } from "../utils/app.js";
5
- import { log } from "../utils/log.js";
6
- const publish = async (cmd, callback = process.exit) => {
7
- const { bump, cliName = "Lex", newVersion, otp, packageManager: cmdPackageManager, private: accessPrivate, tag, quiet } = cmd;
8
- log(`${cliName} publishing npm module...`, "info", quiet);
9
- const spinner = createSpinner(quiet);
10
- await LexConfig.parseConfig(cmd);
11
- const { packageManager: configPackageManager } = LexConfig.config;
12
- const packageManager = cmdPackageManager || configPackageManager;
13
- const publishOptions = ["publish"];
14
- if (accessPrivate) {
15
- publishOptions.push("--access", "restricted");
16
- }
17
- if (otp) {
18
- publishOptions.push("--otp", otp);
19
- }
20
- if (tag) {
21
- publishOptions.push("--tag", tag);
22
- }
23
- let nextVersion;
24
- const packagePath = `${process.cwd()}/package.json`;
25
- let packageJson;
26
- let packageName;
27
- let prevVersion;
28
- try {
29
- packageJson = getPackageJson(packagePath);
30
- packageName = packageJson.name;
31
- prevVersion = packageJson.version;
32
- } catch (error) {
33
- log(`
34
- ${cliName} Error: The file, ${packagePath}, was not found or is malformed.
35
- `, "error", quiet);
36
- log(error.message, "error");
37
- callback(1);
38
- return 1;
39
- }
40
- if (newVersion) {
41
- nextVersion = newVersion;
42
- } else if (bump) {
43
- const formatBump = bump.toString().trim().toLowerCase();
44
- if (formatBump) {
45
- const validReleases = ["major", "minor", "patch"];
46
- const validPreReleases = ["alpha", "beta", "rc"];
47
- const packageVersion = semver.coerce(prevVersion);
48
- if (!semver.valid(packageVersion)) {
49
- log(`
50
- ${cliName} Error: Version is invalid in package.json`, "error", quiet);
51
- callback(1);
52
- return 1;
53
- }
54
- if (validReleases.includes(formatBump)) {
55
- nextVersion = semver.inc(packageVersion, formatBump);
56
- } else if (validPreReleases.includes(formatBump)) {
57
- nextVersion = semver.inc(packageVersion, "prerelease", formatBump);
58
- } else {
59
- log(`
60
- ${cliName} Error: Bump type is invalid. please make sure it is one of the following: ${validReleases.join(", ")}, ${validPreReleases.join(", ")}`, "error", quiet);
61
- callback(1);
62
- return 1;
63
- }
64
- } else {
65
- log(`
66
- ${cliName} Error: Bump type is missing.`, "error", quiet);
67
- callback(1);
68
- return 1;
69
- }
70
- }
71
- if (nextVersion && packageManager === "yarn") {
72
- publishOptions.push("--new-version", nextVersion);
73
- } else if (nextVersion && packageJson) {
74
- try {
75
- setPackageJson({ ...packageJson, version: nextVersion }, packagePath);
76
- } catch (error) {
77
- log(`
78
- ${cliName} Error: The file, ${packagePath}, was not found or is malformed. ${error.message}`, quiet);
79
- callback(1);
80
- return 1;
81
- }
82
- } else {
83
- nextVersion = prevVersion;
84
- }
85
- try {
86
- await execa(packageManager, publishOptions, {
87
- encoding: "utf8",
88
- stdio: "inherit"
89
- });
90
- spinner.succeed(`Successfully published npm package: ${packageName}!`);
91
- callback(0);
92
- return 0;
93
- } catch (error) {
94
- log(`
95
- ${cliName} Error: ${error.message}`, "error", quiet);
96
- spinner.fail("Publishing to npm has failed.");
97
- callback(1);
98
- return 1;
99
- }
100
- };
101
- export {
102
- publish
103
- };
104
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/publish.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport semver, {ReleaseType} from 'semver';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner, getPackageJson, setPackageJson} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const publish = async (cmd, callback: any = process.exit): Promise<number> => {\n  const {bump, cliName = 'Lex', newVersion, otp, packageManager: cmdPackageManager, private: accessPrivate, tag, quiet} = cmd;\n  log(`${cliName} publishing npm module...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n\n  const {packageManager: configPackageManager} = LexConfig.config;\n  const packageManager: string = cmdPackageManager || configPackageManager;\n  const publishOptions: string[] = ['publish'];\n\n  if(accessPrivate) {\n    publishOptions.push('--access', 'restricted');\n  }\n\n  if(otp) {\n    publishOptions.push('--otp', otp);\n  }\n\n  if(tag) {\n    publishOptions.push('--tag', tag);\n  }\n\n  // Get next version number\n  let nextVersion: string;\n  const packagePath: string = `${process.cwd()}/package.json`;\n  let packageJson;\n  let packageName: string;\n  let prevVersion: string;\n\n  // If not using yarn, we'll use npm and manually update the version number\n  try {\n    packageJson = getPackageJson(packagePath);\n    packageName = packageJson.name;\n    prevVersion = packageJson.version;\n  } catch(error) {\n    log(`\\n${cliName} Error: The file, ${packagePath}, was not found or is malformed.\\n`, 'error', quiet);\n    log(error.message, 'error');\n    callback(1);\n    return 1;\n  }\n\n  // Update package.json with the latest version\n  if(newVersion) {\n    // If using a specific version, we don't need to determine the next bump\n    nextVersion = newVersion;\n  } else if(bump) {\n    // Determine next version\n    const formatBump: ReleaseType = bump.toString()\n      .trim()\n      .toLowerCase();\n\n    if(formatBump) {\n      const validReleases: string[] = ['major', 'minor', 'patch'];\n      const validPreReleases: string[] = ['alpha', 'beta', 'rc'];\n\n      // Make sure the version in package.json is valid\n      const packageVersion = semver.coerce(prevVersion);\n\n      if(!semver.valid(packageVersion)) {\n        log(`\\n${cliName} Error: Version is invalid in package.json`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n\n      if(validReleases.includes(formatBump)) {\n        nextVersion = semver.inc(packageVersion, formatBump);\n      } else if(validPreReleases.includes(formatBump)) {\n        nextVersion = semver.inc(packageVersion, 'prerelease', formatBump);\n      } else {\n        log(`\\n${cliName} Error: Bump type is invalid. please make sure it is one of the following: ${validReleases.join(', ')}, ${validPreReleases.join(', ')}`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n    } else {\n      log(`\\n${cliName} Error: Bump type is missing.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  if(nextVersion && packageManager === 'yarn') {\n    publishOptions.push('--new-version', nextVersion);\n  } else if(nextVersion && packageJson) {\n    try {\n      // Save updated version\n      setPackageJson({...packageJson, version: nextVersion}, packagePath);\n    } catch(error) {\n      log(`\\n${cliName} Error: The file, ${packagePath}, was not found or is malformed. ${error.message}`, quiet);\n      callback(1);\n      return 1;\n    }\n  } else {\n    nextVersion = prevVersion;\n  }\n\n  try {\n    await execa(packageManager, publishOptions, {\n      encoding: 'utf8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed(`Successfully published npm package: ${packageName}!`);\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Publishing to npm has failed.');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -1,190 +0,0 @@
1
- import { execa } from "execa";
2
- import { resolve as pathResolve } from "path";
3
- import { URL } from "url";
4
- import { LexConfig } from "../LexConfig.js";
5
- import { createSpinner } from "../utils/app.js";
6
- import { relativeNodePath } from "../utils/file.js";
7
- import { log } from "../utils/log.js";
8
- const test = async (options, args, callback = process.exit) => {
9
- const {
10
- bail,
11
- changedFilesWithAncestor,
12
- changedSince,
13
- ci,
14
- cliName = "Lex",
15
- collectCoverageFrom,
16
- colors,
17
- config,
18
- debug,
19
- detectOpenHandles,
20
- env,
21
- errorOnDeprecated,
22
- expand,
23
- forceExit,
24
- json,
25
- lastCommit,
26
- listTests,
27
- logHeapUsage,
28
- maxWorkers,
29
- noStackTrace,
30
- notify,
31
- onlyChanged,
32
- outputFile,
33
- passWithNoTests,
34
- quiet,
35
- removeCache,
36
- runInBand,
37
- setup,
38
- showConfig,
39
- silent,
40
- testLocationInResults,
41
- testNamePattern,
42
- testPathPattern,
43
- update,
44
- useStderr,
45
- verbose,
46
- watch,
47
- watchAll
48
- } = options;
49
- log(`${cliName} testing...`, "info", quiet);
50
- const spinner = createSpinner(quiet);
51
- await LexConfig.parseConfig(options);
52
- const { jest, useTypescript } = LexConfig.config;
53
- if (useTypescript) {
54
- LexConfig.checkTypescriptConfig();
55
- }
56
- const dirName = new URL(".", import.meta.url).pathname;
57
- const dirPath = pathResolve(dirName, "../..");
58
- const jestPath = relativeNodePath("jest-cli/bin/jest.js", dirPath);
59
- const jestConfigFile = config || pathResolve(dirName, "../../jest.config.lex.js");
60
- const jestSetupFile = setup || "";
61
- const jestOptions = ["--config", jestConfigFile, "--no-cache"];
62
- if (bail) {
63
- jestOptions.push("--bail");
64
- }
65
- if (changedFilesWithAncestor) {
66
- jestOptions.push("--changedFilesWithAncestor");
67
- }
68
- if (changedSince) {
69
- jestOptions.push("--changedSince");
70
- }
71
- if (ci) {
72
- jestOptions.push("--ci");
73
- }
74
- if (collectCoverageFrom) {
75
- jestOptions.push("--collectCoverageFrom", collectCoverageFrom);
76
- }
77
- if (colors) {
78
- jestOptions.push("--colors");
79
- }
80
- if (debug) {
81
- jestOptions.push("--debug");
82
- }
83
- if (detectOpenHandles) {
84
- jestOptions.push("--detectOpenHandles");
85
- }
86
- if (env) {
87
- jestOptions.push("--env");
88
- }
89
- if (errorOnDeprecated) {
90
- jestOptions.push("--errorOnDeprecated");
91
- }
92
- if (expand) {
93
- jestOptions.push("--expand");
94
- }
95
- if (forceExit) {
96
- jestOptions.push("--forceExit");
97
- }
98
- if (json) {
99
- jestOptions.push("--json");
100
- }
101
- if (lastCommit) {
102
- jestOptions.push("--lastCommit");
103
- }
104
- if (listTests) {
105
- jestOptions.push("--listTests");
106
- }
107
- if (logHeapUsage) {
108
- jestOptions.push("--logHeapUsage");
109
- }
110
- if (maxWorkers) {
111
- jestOptions.push("--maxWorkers", maxWorkers);
112
- }
113
- if (noStackTrace) {
114
- jestOptions.push("--noStackTrace");
115
- }
116
- if (notify) {
117
- jestOptions.push("--notify");
118
- }
119
- if (onlyChanged) {
120
- jestOptions.push("--onlyChanged");
121
- }
122
- if (outputFile) {
123
- jestOptions.push("--outputFile", outputFile);
124
- }
125
- if (passWithNoTests) {
126
- jestOptions.push("--passWithNoTests");
127
- }
128
- if (runInBand) {
129
- jestOptions.push("--runInBand");
130
- }
131
- if (showConfig) {
132
- jestOptions.push("--showConfig");
133
- }
134
- if (silent) {
135
- jestOptions.push("--silent");
136
- }
137
- if (testLocationInResults) {
138
- jestOptions.push("--testLocationInResults");
139
- }
140
- if (testNamePattern) {
141
- jestOptions.push("--testNamePattern", testNamePattern);
142
- }
143
- if (testPathPattern) {
144
- jestOptions.push("--testPathPattern", testPathPattern);
145
- }
146
- if (useStderr) {
147
- jestOptions.push("--useStderr");
148
- }
149
- if (verbose) {
150
- jestOptions.push("--verbose");
151
- }
152
- if (watchAll) {
153
- jestOptions.push("--watchAll");
154
- }
155
- if (removeCache) {
156
- jestOptions.push("--no-cache");
157
- }
158
- if (jestSetupFile !== "") {
159
- const cwd = process.cwd();
160
- jestOptions.push(`--setupFilesAfterEnv=${pathResolve(cwd, jestSetupFile)}`);
161
- }
162
- if (update) {
163
- jestOptions.push("--updateSnapshot");
164
- }
165
- if (watch) {
166
- jestOptions.push("--watch", watch);
167
- }
168
- if (args) {
169
- jestOptions.push(...args);
170
- }
171
- try {
172
- await execa(jestPath, jestOptions, {
173
- encoding: "utf8",
174
- stdio: "inherit"
175
- });
176
- spinner.succeed("Testing completed!");
177
- callback(0);
178
- return 0;
179
- } catch (error) {
180
- log(`
181
- ${cliName} Error: Check for unit test errors and/or coverage.`, "error", quiet);
182
- spinner.fail("Testing failed!");
183
- callback(1);
184
- return 1;
185
- }
186
- };
187
- export {
188
- test
189
- };
190
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/test.ts"],
  "sourcesContent": ["import {execa} from 'execa';\n\nimport {resolve as pathResolve} from 'path';\n\nimport {URL} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner} from '../utils/app.js';\nimport {relativeNodePath} from '../utils/file.js';\nimport {log} from '../utils/log.js';\n\nexport const test = async (options: any, args: string[], callback: any = process.exit): Promise<number> => {\n  const {\n    bail,\n    changedFilesWithAncestor,\n    changedSince,\n    ci,\n    cliName = 'Lex',\n    collectCoverageFrom,\n    colors,\n    config,\n    debug,\n    detectOpenHandles,\n    env,\n    errorOnDeprecated,\n    expand,\n    forceExit,\n    json,\n    lastCommit,\n    listTests,\n    logHeapUsage,\n    maxWorkers,\n    noStackTrace,\n    notify,\n    onlyChanged,\n    outputFile,\n    passWithNoTests,\n    quiet,\n    removeCache,\n    runInBand,\n    setup,\n    showConfig,\n    silent,\n    testLocationInResults,\n    testNamePattern,\n    testPathPattern,\n    update,\n    useStderr,\n    verbose,\n    watch,\n    watchAll\n  } = options;\n\n  log(`${cliName} testing...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(options);\n\n  const {jest, useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    // Make sure tsconfig.json exists\n    LexConfig.checkTypescriptConfig();\n  }\n\n  // Configure jest\n  const dirName = new URL('.', import.meta.url).pathname;\n  const dirPath: string = pathResolve(dirName, '../..');\n  const jestPath: string = relativeNodePath('jest-cli/bin/jest.js', dirPath);\n  const jestConfigFile: string = config || pathResolve(dirName, '../../jest.config.lex.js');\n  const jestSetupFile: string = setup || '';\n  const jestOptions: string[] = ['--config', jestConfigFile, '--no-cache'];\n\n  if(bail) {\n    jestOptions.push('--bail');\n  }\n\n  if(changedFilesWithAncestor) {\n    jestOptions.push('--changedFilesWithAncestor');\n  }\n\n  if(changedSince) {\n    jestOptions.push('--changedSince');\n  }\n\n  if(ci) {\n    jestOptions.push('--ci');\n  }\n\n  if(collectCoverageFrom) {\n    jestOptions.push('--collectCoverageFrom', collectCoverageFrom);\n  }\n\n  if(colors) {\n    jestOptions.push('--colors');\n  }\n\n  if(debug) {\n    jestOptions.push('--debug');\n  }\n\n  // Detect open handles\n  if(detectOpenHandles) {\n    jestOptions.push('--detectOpenHandles');\n  }\n\n  if(env) {\n    jestOptions.push('--env');\n  }\n\n  if(errorOnDeprecated) {\n    jestOptions.push('--errorOnDeprecated');\n  }\n\n  if(expand) {\n    jestOptions.push('--expand');\n  }\n\n  if(forceExit) {\n    jestOptions.push('--forceExit');\n  }\n\n  if(json) {\n    jestOptions.push('--json');\n  }\n\n  if(lastCommit) {\n    jestOptions.push('--lastCommit');\n  }\n\n  if(listTests) {\n    jestOptions.push('--listTests');\n  }\n\n  if(logHeapUsage) {\n    jestOptions.push('--logHeapUsage');\n  }\n\n  if(maxWorkers) {\n    jestOptions.push('--maxWorkers', maxWorkers);\n  }\n\n  if(noStackTrace) {\n    jestOptions.push('--noStackTrace');\n  }\n\n  if(notify) {\n    jestOptions.push('--notify');\n  }\n\n  if(onlyChanged) {\n    jestOptions.push('--onlyChanged');\n  }\n\n  if(outputFile) {\n    jestOptions.push('--outputFile', outputFile);\n  }\n\n  if(passWithNoTests) {\n    jestOptions.push('--passWithNoTests');\n  }\n\n  if(runInBand) {\n    jestOptions.push('--runInBand');\n  }\n\n  if(showConfig) {\n    jestOptions.push('--showConfig');\n  }\n\n  if(silent) {\n    jestOptions.push('--silent');\n  }\n\n  if(testLocationInResults) {\n    jestOptions.push('--testLocationInResults');\n  }\n\n  if(testNamePattern) {\n    jestOptions.push('--testNamePattern', testNamePattern);\n  }\n\n  if(testPathPattern) {\n    jestOptions.push('--testPathPattern', testPathPattern);\n  }\n\n  if(useStderr) {\n    jestOptions.push('--useStderr');\n  }\n\n  if(verbose) {\n    jestOptions.push('--verbose');\n  }\n\n  if(watchAll) {\n    jestOptions.push('--watchAll');\n  }\n\n  // Clear cache\n  if(removeCache) {\n    jestOptions.push('--no-cache');\n  }\n\n  if(jestSetupFile !== '') {\n    const cwd: string = process.cwd();\n    jestOptions.push(`--setupFilesAfterEnv=${pathResolve(cwd, jestSetupFile)}`);\n  }\n\n  // Update snapshots\n  if(update) {\n    jestOptions.push('--updateSnapshot');\n  }\n\n  if(watch) {\n    jestOptions.push('--watch', watch);\n  }\n\n  if(args) {\n    jestOptions.push(...args);\n  }\n\n  try {\n    await execa(jestPath, jestOptions, {\n      encoding: 'utf8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Testing completed!');\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Testing failed!');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -1,64 +0,0 @@
1
- import { execa } from "execa";
2
- import { resolve as pathResolve } from "path";
3
- import { LexConfig } from "../LexConfig.js";
4
- import { createSpinner } from "../utils/app.js";
5
- import { relativeNodePath } from "../utils/file.js";
6
- import { log } from "../utils/log.js";
7
- const update = async (cmd, callback = process.exit) => {
8
- const { cliName = "Lex", packageManager: cmdPackageManager, quiet, registry } = cmd;
9
- log(`${cliName} updating packages...`, "info", quiet);
10
- const spinner = createSpinner(quiet);
11
- await LexConfig.parseConfig(cmd);
12
- const { packageManager: configPackageManager } = LexConfig.config;
13
- const packageManager = cmdPackageManager || configPackageManager || "npm";
14
- const isNpm = packageManager === "npm";
15
- const updateApp = isNpm ? "npx" : "yarn";
16
- const dirName = new URL(".", import.meta.url).pathname;
17
- const dirPath = pathResolve(dirName, "../..");
18
- const npmCheckUpdatesPath = relativeNodePath("npm-check-updates", dirPath);
19
- const updateOptions = isNpm ? [
20
- npmCheckUpdatesPath,
21
- "--concurrency",
22
- "10",
23
- "--packageManager",
24
- packageManager,
25
- "--pre",
26
- "0",
27
- "--target",
28
- "latest",
29
- cmd.interactive ? "--interactive" : "",
30
- "--upgrade"
31
- ] : [cmd.interactive ? "upgrade-interactive" : "upgrade", "--latest"];
32
- if (registry) {
33
- updateOptions.push("--registry", registry);
34
- }
35
- try {
36
- await execa(updateApp, updateOptions, {
37
- encoding: "utf8",
38
- stdio: "inherit"
39
- });
40
- if (isNpm) {
41
- await execa("npm", ["i", "--force"], {
42
- encoding: "utf8",
43
- stdio: "inherit"
44
- });
45
- await execa("npm", ["audit", "fix"], {
46
- encoding: "utf8",
47
- stdio: "inherit"
48
- });
49
- }
50
- spinner.succeed("Successfully updated packages!");
51
- callback(0);
52
- return 0;
53
- } catch (error) {
54
- log(`
55
- ${cliName} Error: ${error.message}`, "error", quiet);
56
- spinner.fail("Failed to updated packages.");
57
- callback(1);
58
- return 1;
59
- }
60
- };
61
- export {
62
- update
63
- };
64
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL3VwZGF0ZS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcblxuaW1wb3J0IHtyZXNvbHZlIGFzIHBhdGhSZXNvbHZlfSBmcm9tICdwYXRoJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXJ9IGZyb20gJy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge3JlbGF0aXZlTm9kZVBhdGh9IGZyb20gJy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCB1cGRhdGUgPSBhc3luYyAoY21kOiBhbnksIGNhbGxiYWNrOiBhbnkgPSBwcm9jZXNzLmV4aXQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBwYWNrYWdlTWFuYWdlcjogY21kUGFja2FnZU1hbmFnZXIsIHF1aWV0LCByZWdpc3RyeX0gPSBjbWQ7XG5cbiAgLy8gRGlzcGxheSBzdGF0dXNcbiAgbG9nKGAke2NsaU5hbWV9IHVwZGF0aW5nIHBhY2thZ2VzLi4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gU3Bpbm5lclxuICBjb25zdCBzcGlubmVyID0gY3JlYXRlU3Bpbm5lcihxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIGF3YWl0IExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIGNvbnN0IHtwYWNrYWdlTWFuYWdlcjogY29uZmlnUGFja2FnZU1hbmFnZXJ9ID0gTGV4Q29uZmlnLmNvbmZpZztcbiAgY29uc3QgcGFja2FnZU1hbmFnZXI6IHN0cmluZyA9IGNtZFBhY2thZ2VNYW5hZ2VyIHx8IGNvbmZpZ1BhY2thZ2VNYW5hZ2VyIHx8ICducG0nO1xuICBjb25zdCBpc05wbTogYm9vbGVhbiA9IHBhY2thZ2VNYW5hZ2VyID09PSAnbnBtJztcbiAgY29uc3QgdXBkYXRlQXBwOiBzdHJpbmcgPSBpc05wbSA/ICducHgnIDogJ3lhcm4nO1xuICBjb25zdCBkaXJOYW1lID0gbmV3IFVSTCgnLicsIGltcG9ydC5tZXRhLnVybCkucGF0aG5hbWU7XG4gIGNvbnN0IGRpclBhdGg6IHN0cmluZyA9IHBhdGhSZXNvbHZlKGRpck5hbWUsICcuLi8uLicpO1xuICBjb25zdCBucG1DaGVja1VwZGF0ZXNQYXRoOiBzdHJpbmcgPSByZWxhdGl2ZU5vZGVQYXRoKCducG0tY2hlY2stdXBkYXRlcycsIGRpclBhdGgpO1xuICBjb25zdCB1cGRhdGVPcHRpb25zOiBzdHJpbmdbXSA9IGlzTnBtXG4gICAgPyBbbnBtQ2hlY2tVcGRhdGVzUGF0aCxcbiAgICAgICctLWNvbmN1cnJlbmN5JywgJzEwJyxcbiAgICAgICctLXBhY2thZ2VNYW5hZ2VyJywgcGFja2FnZU1hbmFnZXIsXG4gICAgICAnLS1wcmUnLCAnMCcsXG4gICAgICAnLS10YXJnZXQnLCAnbGF0ZXN0JyxcbiAgICAgIGNtZC5pbnRlcmFjdGl2ZSA/ICctLWludGVyYWN0aXZlJyA6ICcnLFxuICAgICAgJy0tdXBncmFkZSdcbiAgICBdXG4gICAgOiBbY21kLmludGVyYWN0aXZlID8gJ3VwZ3JhZGUtaW50ZXJhY3RpdmUnIDogJ3VwZ3JhZGUnLCAnLS1sYXRlc3QnXTtcblxuICBpZihyZWdpc3RyeSkge1xuICAgIHVwZGF0ZU9wdGlvbnMucHVzaCgnLS1yZWdpc3RyeScsIHJlZ2lzdHJ5KTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EodXBkYXRlQXBwLCB1cGRhdGVPcHRpb25zLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgIH0pO1xuXG4gICAgaWYoaXNOcG0pIHtcbiAgICAgIGF3YWl0IGV4ZWNhKCducG0nLCBbJ2knLCAnLS1mb3JjZSddLCB7XG4gICAgICAgIGVuY29kaW5nOiAndXRmOCcsXG4gICAgICAgIHN0ZGlvOiAnaW5oZXJpdCdcbiAgICAgIH0pO1xuXG4gICAgICBhd2FpdCBleGVjYSgnbnBtJywgWydhdWRpdCcsICdmaXgnXSwge1xuICAgICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgICBzdGRpbzogJ2luaGVyaXQnXG4gICAgICB9KTtcbiAgICB9XG5cbiAgICAvLyBTdG9wIGxvYWRlclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnU3VjY2Vzc2Z1bGx5IHVwZGF0ZWQgcGFja2FnZXMhJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIHVwZGF0ZWQgcGFja2FnZXMuJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gMTtcbiAgfVxufTtcbiJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsYUFBWTtBQUVwQixTQUFRLFdBQVcsbUJBQWtCO0FBRXJDLFNBQVEsaUJBQWdCO0FBQ3hCLFNBQVEscUJBQW9CO0FBQzVCLFNBQVEsd0JBQXVCO0FBQy9CLFNBQVEsV0FBVTtBQUVYLE1BQU0sU0FBUyxPQUFPLEtBQVUsV0FBZ0IsUUFBUSxTQUEwQjtBQUN2RixRQUFNLEVBQUMsVUFBVSxPQUFPLGdCQUFnQixtQkFBbUIsT0FBTyxTQUFRLElBQUk7QUFHOUUsTUFBSSxHQUFHLE9BQU8seUJBQXlCLFFBQVEsS0FBSztBQUdwRCxRQUFNLFVBQVUsY0FBYyxLQUFLO0FBR25DLFFBQU0sVUFBVSxZQUFZLEdBQUc7QUFFL0IsUUFBTSxFQUFDLGdCQUFnQixxQkFBb0IsSUFBSSxVQUFVO0FBQ3pELFFBQU0saUJBQXlCLHFCQUFxQix3QkFBd0I7QUFDNUUsUUFBTSxRQUFpQixtQkFBbUI7QUFDMUMsUUFBTSxZQUFvQixRQUFRLFFBQVE7QUFDMUMsUUFBTSxVQUFVLElBQUksSUFBSSxLQUFLLFlBQVksR0FBRyxFQUFFO0FBQzlDLFFBQU0sVUFBa0IsWUFBWSxTQUFTLE9BQU87QUFDcEQsUUFBTSxzQkFBOEIsaUJBQWlCLHFCQUFxQixPQUFPO0FBQ2pGLFFBQU0sZ0JBQTBCLFFBQzVCO0FBQUEsSUFBQztBQUFBLElBQ0Q7QUFBQSxJQUFpQjtBQUFBLElBQ2pCO0FBQUEsSUFBb0I7QUFBQSxJQUNwQjtBQUFBLElBQVM7QUFBQSxJQUNUO0FBQUEsSUFBWTtBQUFBLElBQ1osSUFBSSxjQUFjLGtCQUFrQjtBQUFBLElBQ3BDO0FBQUEsRUFDRixJQUNFLENBQUMsSUFBSSxjQUFjLHdCQUF3QixXQUFXLFVBQVU7QUFFcEUsTUFBRyxVQUFVO0FBQ1gsa0JBQWMsS0FBSyxjQUFjLFFBQVE7QUFBQSxFQUMzQztBQUVBLE1BQUk7QUFDRixVQUFNLE1BQU0sV0FBVyxlQUFlO0FBQUEsTUFDcEMsVUFBVTtBQUFBLE1BQ1YsT0FBTztBQUFBLElBQ1QsQ0FBQztBQUVELFFBQUcsT0FBTztBQUNSLFlBQU0sTUFBTSxPQUFPLENBQUMsS0FBSyxTQUFTLEdBQUc7QUFBQSxRQUNuQyxVQUFVO0FBQUEsUUFDVixPQUFPO0FBQUEsTUFDVCxDQUFDO0FBRUQsWUFBTSxNQUFNLE9BQU8sQ0FBQyxTQUFTLEtBQUssR0FBRztBQUFBLFFBQ25DLFVBQVU7QUFBQSxRQUNWLE9BQU87QUFBQSxNQUNULENBQUM7QUFBQSxJQUNIO0FBR0EsWUFBUSxRQUFRLGdDQUFnQztBQUdoRCxhQUFTLENBQUM7QUFDVixXQUFPO0FBQUEsRUFDVCxTQUFRLE9BQU87QUFFYixRQUFJO0FBQUEsRUFBSyxPQUFPLFdBQVcsTUFBTSxPQUFPLElBQUksU0FBUyxLQUFLO0FBRzFELFlBQVEsS0FBSyw2QkFBNkI7QUFHMUMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1Q7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
@@ -1,47 +0,0 @@
1
- import { compareVersions } from "compare-versions";
2
- import { execa } from "execa";
3
- import { readFileSync } from "fs";
4
- import latestVersion from "latest-version";
5
- import { fileURLToPath } from "url";
6
- import { LexConfig } from "../LexConfig.js";
7
- import { createSpinner } from "../utils/app.js";
8
- import { log } from "../utils/log.js";
9
- import { parseVersion } from "./versions.js";
10
- const packagePath = fileURLToPath(new URL("../../package.json", import.meta.url));
11
- const packageJson = JSON.parse(readFileSync(packagePath, "utf8"));
12
- const upgrade = async (cmd, callback = process.exit) => {
13
- const { cliName = "Lex", cliPackage = "@nlabs/lex", quiet } = cmd;
14
- log(`Upgrading ${cliName}...`, "info", quiet);
15
- const spinner = createSpinner(quiet);
16
- await LexConfig.parseConfig(cmd);
17
- return latestVersion("@nlabs/lex").then(async (latest) => {
18
- const current = parseVersion(packageJson.version);
19
- const versionDiff = compareVersions(latest, current);
20
- if (versionDiff === 0) {
21
- log(`
22
- Currently up-to-date. Version ${latest} is the latest.`, "note", quiet);
23
- callback(0);
24
- return 0;
25
- }
26
- log(`
27
- Currently out of date. Upgrading from version ${current} to ${latest}...`, "note", quiet);
28
- const upgradeOptions = ["install", "-g", `${cliPackage}@latest`];
29
- await execa("npm", upgradeOptions, {
30
- encoding: "utf8",
31
- stdio: "inherit"
32
- });
33
- spinner.succeed(`Successfully updated ${cliName}!`);
34
- callback(0);
35
- return 0;
36
- }).catch((error) => {
37
- log(`
38
- ${cliName} Error: ${error.message}`, "error", quiet);
39
- spinner.fail("Failed to updated packages.");
40
- callback(1);
41
- return 1;
42
- });
43
- };
44
- export {
45
- upgrade
46
- };
47
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL3VwZ3JhZGUudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2NvbXBhcmVWZXJzaW9uc30gZnJvbSAnY29tcGFyZS12ZXJzaW9ucyc7XG5pbXBvcnQge2V4ZWNhfSBmcm9tICdleGVjYSc7XG5pbXBvcnQge3JlYWRGaWxlU3luY30gZnJvbSAnZnMnO1xuaW1wb3J0IGxhdGVzdFZlcnNpb24gZnJvbSAnbGF0ZXN0LXZlcnNpb24nO1xuaW1wb3J0IHtmaWxlVVJMVG9QYXRofSBmcm9tICd1cmwnO1xuXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y3JlYXRlU3Bpbm5lcn0gZnJvbSAnLi4vdXRpbHMvYXBwLmpzJztcbmltcG9ydCB7bG9nfSBmcm9tICcuLi91dGlscy9sb2cuanMnO1xuaW1wb3J0IHtwYXJzZVZlcnNpb259IGZyb20gJy4vdmVyc2lvbnMuanMnO1xuXG5jb25zdCBwYWNrYWdlUGF0aCA9IGZpbGVVUkxUb1BhdGgobmV3IFVSTCgnLi4vLi4vcGFja2FnZS5qc29uJywgaW1wb3J0Lm1ldGEudXJsKSk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGNvbnN0IHVwZ3JhZGUgPSBhc3luYyAoY21kOiBhbnksIGNhbGxiYWNrOiBhbnkgPSBwcm9jZXNzLmV4aXQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBjbGlQYWNrYWdlID0gJ0BubGFicy9sZXgnLCBxdWlldH0gPSBjbWQ7XG5cbiAgLy8gRGlzcGxheSBzdGF0dXNcbiAgbG9nKGBVcGdyYWRpbmcgJHtjbGlOYW1lfS4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIC8vIFNwaW5uZXJcbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gIC8vIEdldCBjdXN0b20gY29uZmlndXJhdGlvblxuICBhd2FpdCBMZXhDb25maWcucGFyc2VDb25maWcoY21kKTtcblxuICByZXR1cm4gbGF0ZXN0VmVyc2lvbignQG5sYWJzL2xleCcpXG4gICAgLnRoZW4oYXN5bmMgKGxhdGVzdDogc3RyaW5nKSA9PiB7XG4gICAgICBjb25zdCBjdXJyZW50OiBzdHJpbmcgPSBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24udmVyc2lvbik7XG4gICAgICBjb25zdCB2ZXJzaW9uRGlmZjogbnVtYmVyID0gY29tcGFyZVZlcnNpb25zKGxhdGVzdCwgY3VycmVudCk7XG5cbiAgICAgIGlmKHZlcnNpb25EaWZmID09PSAwKSB7XG4gICAgICAgIGxvZyhgXFxuQ3VycmVudGx5IHVwLXRvLWRhdGUuIFZlcnNpb24gJHtsYXRlc3R9IGlzIHRoZSBsYXRlc3QuYCwgJ25vdGUnLCBxdWlldCk7XG4gICAgICAgIGNhbGxiYWNrKDApO1xuICAgICAgICByZXR1cm4gMDtcbiAgICAgIH1cblxuICAgICAgbG9nKGBcXG5DdXJyZW50bHkgb3V0IG9mIGRhdGUuIFVwZ3JhZGluZyBmcm9tIHZlcnNpb24gJHtjdXJyZW50fSB0byAke2xhdGVzdH0uLi5gLCAnbm90ZScsIHF1aWV0KTtcblxuICAgICAgY29uc3QgdXBncmFkZU9wdGlvbnM6IHN0cmluZ1tdID0gWydpbnN0YWxsJywgJy1nJywgYCR7Y2xpUGFja2FnZX1AbGF0ZXN0YF07XG5cbiAgICAgIGF3YWl0IGV4ZWNhKCducG0nLCB1cGdyYWRlT3B0aW9ucywge1xuICAgICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgICBzdGRpbzogJ2luaGVyaXQnXG4gICAgICB9KTtcblxuICAgICAgLy8gU3RvcCBsb2FkZXJcbiAgICAgIHNwaW5uZXIuc3VjY2VlZChgU3VjY2Vzc2Z1bGx5IHVwZGF0ZWQgJHtjbGlOYW1lfSFgKTtcblxuICAgICAgLy8gU3RvcCBwcm9jZXNzXG4gICAgICBjYWxsYmFjaygwKTtcbiAgICAgIHJldHVybiAwO1xuICAgIH0pXG4gICAgLmNhdGNoKChlcnJvcikgPT4ge1xuICAgICAgLy8gRGlzcGxheSBlcnJvciBtZXNzYWdlXG4gICAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6ICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG5cbiAgICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgICAgc3Bpbm5lci5mYWlsKCdGYWlsZWQgdG8gdXBkYXRlZCBwYWNrYWdlcy4nKTtcblxuICAgICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgICBjYWxsYmFjaygxKTtcbiAgICAgIHJldHVybiAxO1xuICAgIH0pO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsdUJBQXNCO0FBQzlCLFNBQVEsYUFBWTtBQUNwQixTQUFRLG9CQUFtQjtBQUMzQixPQUFPLG1CQUFtQjtBQUMxQixTQUFRLHFCQUFvQjtBQUU1QixTQUFRLGlCQUFnQjtBQUN4QixTQUFRLHFCQUFvQjtBQUM1QixTQUFRLFdBQVU7QUFDbEIsU0FBUSxvQkFBbUI7QUFFM0IsTUFBTSxjQUFjLGNBQWMsSUFBSSxJQUFJLHNCQUFzQixZQUFZLEdBQUcsQ0FBQztBQUNoRixNQUFNLGNBQWMsS0FBSyxNQUFNLGFBQWEsYUFBYSxNQUFNLENBQUM7QUFFekQsTUFBTSxVQUFVLE9BQU8sS0FBVSxXQUFnQixRQUFRLFNBQTBCO0FBQ3hGLFFBQU0sRUFBQyxVQUFVLE9BQU8sYUFBYSxjQUFjLE1BQUssSUFBSTtBQUc1RCxNQUFJLGFBQWEsT0FBTyxPQUFPLFFBQVEsS0FBSztBQUc1QyxRQUFNLFVBQVUsY0FBYyxLQUFLO0FBR25DLFFBQU0sVUFBVSxZQUFZLEdBQUc7QUFFL0IsU0FBTyxjQUFjLFlBQVksRUFDOUIsS0FBSyxPQUFPLFdBQW1CO0FBQzlCLFVBQU0sVUFBa0IsYUFBYSxZQUFZLE9BQU87QUFDeEQsVUFBTSxjQUFzQixnQkFBZ0IsUUFBUSxPQUFPO0FBRTNELFFBQUcsZ0JBQWdCLEdBQUc7QUFDcEIsVUFBSTtBQUFBLGdDQUFtQyxNQUFNLG1CQUFtQixRQUFRLEtBQUs7QUFDN0UsZUFBUyxDQUFDO0FBQ1YsYUFBTztBQUFBLElBQ1Q7QUFFQSxRQUFJO0FBQUEsZ0RBQW1ELE9BQU8sT0FBTyxNQUFNLE9BQU8sUUFBUSxLQUFLO0FBRS9GLFVBQU0saUJBQTJCLENBQUMsV0FBVyxNQUFNLEdBQUcsVUFBVSxTQUFTO0FBRXpFLFVBQU0sTUFBTSxPQUFPLGdCQUFnQjtBQUFBLE1BQ2pDLFVBQVU7QUFBQSxNQUNWLE9BQU87QUFBQSxJQUNULENBQUM7QUFHRCxZQUFRLFFBQVEsd0JBQXdCLE9BQU8sR0FBRztBQUdsRCxhQUFTLENBQUM7QUFDVixXQUFPO0FBQUEsRUFDVCxDQUFDLEVBQ0EsTUFBTSxDQUFDLFVBQVU7QUFFaEIsUUFBSTtBQUFBLEVBQUssT0FBTyxXQUFXLE1BQU0sT0FBTyxJQUFJLFNBQVMsS0FBSztBQUcxRCxZQUFRLEtBQUssNkJBQTZCO0FBRzFDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNULENBQUM7QUFDTDsiLAogICJuYW1lcyI6IFtdCn0K
@@ -1,41 +0,0 @@
1
- import { readFileSync } from "fs";
2
- import { fileURLToPath } from "url";
3
- import { log } from "../utils/log.js";
4
- const packagePath = fileURLToPath(new URL("../../package.json", import.meta.url));
5
- const packageJson = JSON.parse(readFileSync(packagePath, "utf8"));
6
- const parseVersion = (packageVersion) => packageVersion?.replace(/\^/g, "");
7
- const packages = {
8
- esbuild: parseVersion(packageJson.dependencies.esbuild),
9
- jest: parseVersion(packageJson.dependencies.jest),
10
- lex: packageJson.version,
11
- typescript: parseVersion(packageJson.dependencies.typescript),
12
- webpack: parseVersion(packageJson.dependencies.webpack)
13
- };
14
- const jsonVersions = (lexPackages) => Object.keys(lexPackages).reduce((list, key) => {
15
- list[key] = packages[key];
16
- return list;
17
- }, {});
18
- const versions = (cmd, callback) => {
19
- if (cmd.json) {
20
- console.log(JSON.stringify(jsonVersions(packages)));
21
- } else {
22
- log("Versions:", "info", false);
23
- log(` Lex: ${packages.lex}`, "info", false);
24
- log(" ----------", "note", false);
25
- log(` ESBuild: ${packages.esbuild}`, "info", false);
26
- log(` Jest: ${packages.jest}`, "info", false);
27
- log(` Typescript: ${packages.typescript}`, "info", false);
28
- log(` Webpack: ${packages.webpack}`, "info", false);
29
- }
30
- if (callback) {
31
- callback(0);
32
- }
33
- return Promise.resolve(0);
34
- };
35
- export {
36
- jsonVersions,
37
- packages,
38
- parseVersion,
39
- versions
40
- };
41
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL3ZlcnNpb25zLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcbmltcG9ydCB7ZmlsZVVSTFRvUGF0aH0gZnJvbSAndXJsJztcblxuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZmlsZVVSTFRvUGF0aChuZXcgVVJMKCcuLi8uLi9wYWNrYWdlLmpzb24nLCBpbXBvcnQubWV0YS51cmwpKTtcbmNvbnN0IHBhY2thZ2VKc29uID0gSlNPTi5wYXJzZShyZWFkRmlsZVN5bmMocGFja2FnZVBhdGgsICd1dGY4JykpO1xuXG5leHBvcnQgY29uc3QgcGFyc2VWZXJzaW9uID0gKHBhY2thZ2VWZXJzaW9uOiBzdHJpbmcpOiBzdHJpbmcgPT4gcGFja2FnZVZlcnNpb24/LnJlcGxhY2UoL1xcXi9nLCAnJyk7XG5cbmV4cG9ydCBjb25zdCBwYWNrYWdlcyA9IHtcbiAgZXNidWlsZDogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uLmRlcGVuZGVuY2llcy5lc2J1aWxkKSxcbiAgamVzdDogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uLmRlcGVuZGVuY2llcy5qZXN0KSxcbiAgbGV4OiBwYWNrYWdlSnNvbi52ZXJzaW9uLFxuICB0eXBlc2NyaXB0OiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24uZGVwZW5kZW5jaWVzLnR5cGVzY3JpcHQpLFxuICB3ZWJwYWNrOiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24uZGVwZW5kZW5jaWVzLndlYnBhY2spXG59O1xuXG5leHBvcnQgY29uc3QganNvblZlcnNpb25zID0gKGxleFBhY2thZ2VzKSA9PiBPYmplY3Qua2V5cyhsZXhQYWNrYWdlcykucmVkdWNlKChsaXN0LCBrZXkpID0+IHtcbiAgbGlzdFtrZXldID0gcGFja2FnZXNba2V5XTtcbiAgcmV0dXJuIGxpc3Q7XG59LCB7fSk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmVyc2lvbnNDbWQge1xuICByZWFkb25seSBqc29uPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNvbnN0IHZlcnNpb25zID0gKGNtZDogVmVyc2lvbnNDbWQsIGNhbGxiYWNrOiAoc3RhdHVzOiBudW1iZXIpID0+IHZvaWQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBpZihjbWQuanNvbikge1xuICAgIGNvbnNvbGUubG9nKEpTT04uc3RyaW5naWZ5KGpzb25WZXJzaW9ucyhwYWNrYWdlcykpKTtcbiAgfSBlbHNlIHtcbiAgICBsb2coJ1ZlcnNpb25zOicsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBMZXg6ICR7cGFja2FnZXMubGV4fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZygnICAtLS0tLS0tLS0tJywgJ25vdGUnLCBmYWxzZSk7XG4gICAgbG9nKGAgIEVTQnVpbGQ6ICR7cGFja2FnZXMuZXNidWlsZH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgSmVzdDogJHtwYWNrYWdlcy5qZXN0fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBUeXBlc2NyaXB0OiAke3BhY2thZ2VzLnR5cGVzY3JpcHR9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFdlYnBhY2s6ICR7cGFja2FnZXMud2VicGFja31gLCAnaW5mbycsIGZhbHNlKTtcbiAgfVxuXG4gIGlmKGNhbGxiYWNrKSB7XG4gICAgY2FsbGJhY2soMCk7XG4gIH1cblxuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDApO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsb0JBQW1CO0FBQzNCLFNBQVEscUJBQW9CO0FBRTVCLFNBQVEsV0FBVTtBQUVsQixNQUFNLGNBQWMsY0FBYyxJQUFJLElBQUksc0JBQXNCLFlBQVksR0FBRyxDQUFDO0FBQ2hGLE1BQU0sY0FBYyxLQUFLLE1BQU0sYUFBYSxhQUFhLE1BQU0sQ0FBQztBQUV6RCxNQUFNLGVBQWUsQ0FBQyxtQkFBbUMsZ0JBQWdCLFFBQVEsT0FBTyxFQUFFO0FBRTFGLE1BQU0sV0FBVztBQUFBLEVBQ3RCLFNBQVMsYUFBYSxZQUFZLGFBQWEsT0FBTztBQUFBLEVBQ3RELE1BQU0sYUFBYSxZQUFZLGFBQWEsSUFBSTtBQUFBLEVBQ2hELEtBQUssWUFBWTtBQUFBLEVBQ2pCLFlBQVksYUFBYSxZQUFZLGFBQWEsVUFBVTtBQUFBLEVBQzVELFNBQVMsYUFBYSxZQUFZLGFBQWEsT0FBTztBQUN4RDtBQUVPLE1BQU0sZUFBZSxDQUFDLGdCQUFnQixPQUFPLEtBQUssV0FBVyxFQUFFLE9BQU8sQ0FBQyxNQUFNLFFBQVE7QUFDMUYsT0FBSyxHQUFHLElBQUksU0FBUyxHQUFHO0FBQ3hCLFNBQU87QUFDVCxHQUFHLENBQUMsQ0FBQztBQU1FLE1BQU0sV0FBVyxDQUFDLEtBQWtCLGFBQXdEO0FBQ2pHLE1BQUcsSUFBSSxNQUFNO0FBQ1gsWUFBUSxJQUFJLEtBQUssVUFBVSxhQUFhLFFBQVEsQ0FBQyxDQUFDO0FBQUEsRUFDcEQsT0FBTztBQUNMLFFBQUksYUFBYSxRQUFRLEtBQUs7QUFDOUIsUUFBSSxVQUFVLFNBQVMsR0FBRyxJQUFJLFFBQVEsS0FBSztBQUMzQyxRQUFJLGdCQUFnQixRQUFRLEtBQUs7QUFDakMsUUFBSSxjQUFjLFNBQVMsT0FBTyxJQUFJLFFBQVEsS0FBSztBQUNuRCxRQUFJLFdBQVcsU0FBUyxJQUFJLElBQUksUUFBUSxLQUFLO0FBQzdDLFFBQUksaUJBQWlCLFNBQVMsVUFBVSxJQUFJLFFBQVEsS0FBSztBQUN6RCxRQUFJLGNBQWMsU0FBUyxPQUFPLElBQUksUUFBUSxLQUFLO0FBQUEsRUFDckQ7QUFFQSxNQUFHLFVBQVU7QUFDWCxhQUFTLENBQUM7QUFBQSxFQUNaO0FBRUEsU0FBTyxRQUFRLFFBQVEsQ0FBQztBQUMxQjsiLAogICJuYW1lcyI6IFtdCn0K
@@ -1,49 +0,0 @@
1
- import { jsonVersions, packages, parseVersion, versions } from "./versions.js";
2
- import { log } from "../utils/log.js";
3
- jest.mock("../utils/log", () => ({
4
- log: jest.fn()
5
- }));
6
- describe("versions", () => {
7
- let oldConsole;
8
- beforeAll(() => {
9
- oldConsole = { ...console };
10
- console = {
11
- ...oldConsole,
12
- debug: jest.fn(),
13
- error: jest.fn(),
14
- log: jest.fn(),
15
- warn: jest.fn()
16
- };
17
- });
18
- afterAll(() => {
19
- console = { ...oldConsole };
20
- jest.resetAllMocks();
21
- });
22
- it("should log correct versions", async () => {
23
- const callback = jest.fn();
24
- const status = await versions({ json: false }, callback);
25
- expect(status).toBe(0);
26
- expect(callback).toHaveBeenCalledWith(0);
27
- expect(log).toHaveBeenCalledWith("Versions:", "info", false);
28
- });
29
- it("should display correct versions in json format", async () => {
30
- const callback = jest.fn();
31
- const status = await versions({ json: true }, callback);
32
- expect(status).toBe(0);
33
- expect(callback).toHaveBeenCalledWith(0);
34
- expect(log).toHaveBeenCalledWith("Versions:", "info", false);
35
- });
36
- describe("jsonVersions", () => {
37
- it("should get package versions", async () => {
38
- const packageVersions = jsonVersions(packages);
39
- expect(packageVersions).toEqual(packages);
40
- });
41
- });
42
- describe("parseVersion", () => {
43
- it("should parse version", async () => {
44
- const version = parseVersion("^1.5.0");
45
- expect(version).toEqual("1.5.0");
46
- });
47
- });
48
- });
49
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL3ZlcnNpb25zLnRlc3QudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7anNvblZlcnNpb25zLCBwYWNrYWdlcywgcGFyc2VWZXJzaW9uLCB2ZXJzaW9uc30gZnJvbSAnLi92ZXJzaW9ucy5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nLmpzJztcblxuamVzdC5tb2NrKCcuLi91dGlscy9sb2cnLCAoKSA9PiAoe1xuICBsb2c6IGplc3QuZm4oKVxufSkpO1xuXG5kZXNjcmliZSgndmVyc2lvbnMnLCAoKSA9PiB7XG4gIGxldCBvbGRDb25zb2xlO1xuXG4gIGJlZm9yZUFsbCgoKSA9PiB7XG4gICAgb2xkQ29uc29sZSA9IHsuLi5jb25zb2xlfTtcbiAgICBjb25zb2xlID0ge1xuICAgICAgLi4ub2xkQ29uc29sZSxcbiAgICAgIGRlYnVnOiBqZXN0LmZuKCksXG4gICAgICBlcnJvcjogamVzdC5mbigpLFxuICAgICAgbG9nOiBqZXN0LmZuKCksXG4gICAgICB3YXJuOiBqZXN0LmZuKClcbiAgICB9O1xuICB9KTtcblxuICBhZnRlckFsbCgoKSA9PiB7XG4gICAgY29uc29sZSA9IHsuLi5vbGRDb25zb2xlfTtcbiAgICBqZXN0LnJlc2V0QWxsTW9ja3MoKTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBsb2cgY29ycmVjdCB2ZXJzaW9ucycsIGFzeW5jICgpID0+IHtcbiAgICBjb25zdCBjYWxsYmFjayA9IGplc3QuZm4oKTtcbiAgICBjb25zdCBzdGF0dXM6IG51bWJlciA9IGF3YWl0IHZlcnNpb25zKHtqc29uOiBmYWxzZX0sIGNhbGxiYWNrKTtcbiAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDApO1xuICAgIGV4cGVjdChjYWxsYmFjaykudG9IYXZlQmVlbkNhbGxlZFdpdGgoMCk7XG4gICAgZXhwZWN0KGxvZykudG9IYXZlQmVlbkNhbGxlZFdpdGgoJ1ZlcnNpb25zOicsICdpbmZvJywgZmFsc2UpO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIGRpc3BsYXkgY29ycmVjdCB2ZXJzaW9ucyBpbiBqc29uIGZvcm1hdCcsIGFzeW5jICgpID0+IHtcbiAgICBjb25zdCBjYWxsYmFjayA9IGplc3QuZm4oKTtcbiAgICBjb25zdCBzdGF0dXM6IG51bWJlciA9IGF3YWl0IHZlcnNpb25zKHtqc29uOiB0cnVlfSwgY2FsbGJhY2spO1xuICAgIGV4cGVjdChzdGF0dXMpLnRvQmUoMCk7XG4gICAgZXhwZWN0KGNhbGxiYWNrKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgwKTtcbiAgICBleHBlY3QobG9nKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgnVmVyc2lvbnM6JywgJ2luZm8nLCBmYWxzZSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdqc29uVmVyc2lvbnMnLCAoKSA9PiB7XG4gICAgaXQoJ3Nob3VsZCBnZXQgcGFja2FnZSB2ZXJzaW9ucycsIGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHBhY2thZ2VWZXJzaW9ucyA9IGpzb25WZXJzaW9ucyhwYWNrYWdlcyk7XG4gICAgICBleHBlY3QocGFja2FnZVZlcnNpb25zKS50b0VxdWFsKHBhY2thZ2VzKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3BhcnNlVmVyc2lvbicsICgpID0+IHtcbiAgICBpdCgnc2hvdWxkIHBhcnNlIHZlcnNpb24nLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCB2ZXJzaW9uID0gcGFyc2VWZXJzaW9uKCdeMS41LjAnKTtcbiAgICAgIGV4cGVjdCh2ZXJzaW9uKS50b0VxdWFsKCcxLjUuMCcpO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBQUEsU0FBUSxjQUFjLFVBQVUsY0FBYyxnQkFBZTtBQUM3RCxTQUFRLFdBQVU7QUFFbEIsS0FBSyxLQUFLLGdCQUFnQixPQUFPO0FBQUEsRUFDL0IsS0FBSyxLQUFLLEdBQUc7QUFDZixFQUFFO0FBRUYsU0FBUyxZQUFZLE1BQU07QUFDekIsTUFBSTtBQUVKLFlBQVUsTUFBTTtBQUNkLGlCQUFhLEVBQUMsR0FBRyxRQUFPO0FBQ3hCLGNBQVU7QUFBQSxNQUNSLEdBQUc7QUFBQSxNQUNILE9BQU8sS0FBSyxHQUFHO0FBQUEsTUFDZixPQUFPLEtBQUssR0FBRztBQUFBLE1BQ2YsS0FBSyxLQUFLLEdBQUc7QUFBQSxNQUNiLE1BQU0sS0FBSyxHQUFHO0FBQUEsSUFDaEI7QUFBQSxFQUNGLENBQUM7QUFFRCxXQUFTLE1BQU07QUFDYixjQUFVLEVBQUMsR0FBRyxXQUFVO0FBQ3hCLFNBQUssY0FBYztBQUFBLEVBQ3JCLENBQUM7QUFFRCxLQUFHLCtCQUErQixZQUFZO0FBQzVDLFVBQU0sV0FBVyxLQUFLLEdBQUc7QUFDekIsVUFBTSxTQUFpQixNQUFNLFNBQVMsRUFBQyxNQUFNLE1BQUssR0FBRyxRQUFRO0FBQzdELFdBQU8sTUFBTSxFQUFFLEtBQUssQ0FBQztBQUNyQixXQUFPLFFBQVEsRUFBRSxxQkFBcUIsQ0FBQztBQUN2QyxXQUFPLEdBQUcsRUFBRSxxQkFBcUIsYUFBYSxRQUFRLEtBQUs7QUFBQSxFQUM3RCxDQUFDO0FBRUQsS0FBRyxrREFBa0QsWUFBWTtBQUMvRCxVQUFNLFdBQVcsS0FBSyxHQUFHO0FBQ3pCLFVBQU0sU0FBaUIsTUFBTSxTQUFTLEVBQUMsTUFBTSxLQUFJLEdBQUcsUUFBUTtBQUM1RCxXQUFPLE1BQU0sRUFBRSxLQUFLLENBQUM7QUFDckIsV0FBTyxRQUFRLEVBQUUscUJBQXFCLENBQUM7QUFDdkMsV0FBTyxHQUFHLEVBQUUscUJBQXFCLGFBQWEsUUFBUSxLQUFLO0FBQUEsRUFDN0QsQ0FBQztBQUVELFdBQVMsZ0JBQWdCLE1BQU07QUFDN0IsT0FBRywrQkFBK0IsWUFBWTtBQUM1QyxZQUFNLGtCQUFrQixhQUFhLFFBQVE7QUFDN0MsYUFBTyxlQUFlLEVBQUUsUUFBUSxRQUFRO0FBQUEsSUFDMUMsQ0FBQztBQUFBLEVBQ0gsQ0FBQztBQUVELFdBQVMsZ0JBQWdCLE1BQU07QUFDN0IsT0FBRyx3QkFBd0IsWUFBWTtBQUNyQyxZQUFNLFVBQVUsYUFBYSxRQUFRO0FBQ3JDLGFBQU8sT0FBTyxFQUFFLFFBQVEsT0FBTztBQUFBLElBQ2pDLENBQUM7QUFBQSxFQUNILENBQUM7QUFDSCxDQUFDOyIsCiAgIm5hbWVzIjogW10KfQo=
package/dist/lint.js DELETED
@@ -1,11 +0,0 @@
1
- #!/usr/bin/env node
2
- import { program } from "commander";
3
- import { readFileSync } from "fs";
4
- import { fileURLToPath } from "url";
5
- import { lint } from "./commands/lint.js";
6
- const packagePath = fileURLToPath(new URL("../../package.json", import.meta.url));
7
- const packageJson = JSON.parse(readFileSync(packagePath, "utf8"));
8
- program.option("--cache", "Only check changed files. Default: false.", false).option("--cache-location <path>", "Path to the cache file or directory.").option("--color", "Force enabling of color.", false).option("--config <path>", "Use this configuration, overriding .eslintrc.* config options if present.").option("--debug", "Output debugging information.", false).option("--env-info", "Output execution environment information. Default: false.", false).option("--env <name>", "Specify environments.").option("--ext <type>", "Specify JavaScript file extensions. Default: .js.").option("--fix", "Automatically fix problems.", false).option("--fix-dry-run", "Automatically fix problems without saving the changes to the file system.", false).option("--fix-type <type>", "Specify the types of fixes to apply (problem, suggestion, layout).").option("--format <name>", "Use a specific output format. Default: stylish.").option("--global <variables>", "Define global variables.").option("--ignore-path <path>", "Specify path of ignore file.").option("--ignore-pattern <pattern>", "Pattern of files to ignore (in addition to those in .eslintignore).").option("--init", "Run config initialization wizard. Default: false.", false).option("--max-warnings <num>", "Number of warnings to trigger nonzero exit code. Default: -1.").option("--no-color", "Force disabling of color.", false).option("--no-eslintrc", "Disable use of configuration from .eslintrc.*.", false).option("--no-ignore", "Disable use of ignore files and patterns.", false).option("--no-inline-config", "Prevent comments from changing config or rules.", false).option("--output-file <path>", "Specify file to write report to.").option("--parser <name>", "Specify the parser to be used.").option("--parser-options <options>", "Specify parser options.").option("--plugin <plugins>", "Specify plugins.").option("--print-config <path>", "Print the configuration for the given file.").option("--quiet", "No Lex notifications printed in the console.", false).option("--report-unused-disable-directives", "Adds reported errors for unused eslint-disable directives.", false).option("--resolve-plugins-relative-to <path>", "A folder where plugins should be resolved from.").option("--rule <path>", "Specify rules.").option("--rulesdir <path>", "Use additional rules from this directory.").option("--stdin", "Lint code provided on <STDIN> - Default: false.", false).option("--stdin-filename <name>", "Specify filename to process STDIN as.").action((cmd) => lint(cmd, process.exit).then(() => {
9
- }));
10
- program.version(packageJson.version).parse(process.argv);
11
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2xpbnQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIiMhL3Vzci9iaW4vZW52IG5vZGVcbi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIzLVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge3Byb2dyYW19IGZyb20gJ2NvbW1hbmRlcic7XG5pbXBvcnQge3JlYWRGaWxlU3luY30gZnJvbSAnZnMnO1xuaW1wb3J0IHtmaWxlVVJMVG9QYXRofSBmcm9tICd1cmwnO1xuXG5pbXBvcnQge2xpbnR9IGZyb20gJy4vY29tbWFuZHMvbGludC5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZmlsZVVSTFRvUGF0aChuZXcgVVJMKCcuLi8uLi9wYWNrYWdlLmpzb24nLCBpbXBvcnQubWV0YS51cmwpKTtcbmNvbnN0IHBhY2thZ2VKc29uID0gSlNPTi5wYXJzZShyZWFkRmlsZVN5bmMocGFja2FnZVBhdGgsICd1dGY4JykpO1xuXG5wcm9ncmFtXG4gIC5vcHRpb24oJy0tY2FjaGUnLCAnT25seSBjaGVjayBjaGFuZ2VkIGZpbGVzLiBEZWZhdWx0OiBmYWxzZS4nLCBmYWxzZSlcbiAgLm9wdGlvbignLS1jYWNoZS1sb2NhdGlvbiA8cGF0aD4nLCAnUGF0aCB0byB0aGUgY2FjaGUgZmlsZSBvciBkaXJlY3RvcnkuJylcbiAgLm9wdGlvbignLS1jb2xvcicsICdGb3JjZSBlbmFibGluZyBvZiBjb2xvci4nLCBmYWxzZSlcbiAgLm9wdGlvbignLS1jb25maWcgPHBhdGg+JywgJ1VzZSB0aGlzIGNvbmZpZ3VyYXRpb24sIG92ZXJyaWRpbmcgLmVzbGludHJjLiogY29uZmlnIG9wdGlvbnMgaWYgcHJlc2VudC4nKVxuICAub3B0aW9uKCctLWRlYnVnJywgJ091dHB1dCBkZWJ1Z2dpbmcgaW5mb3JtYXRpb24uJywgZmFsc2UpXG4gIC5vcHRpb24oJy0tZW52LWluZm8nLCAnT3V0cHV0IGV4ZWN1dGlvbiBlbnZpcm9ubWVudCBpbmZvcm1hdGlvbi4gRGVmYXVsdDogZmFsc2UuJywgZmFsc2UpXG4gIC5vcHRpb24oJy0tZW52IDxuYW1lPicsICdTcGVjaWZ5IGVudmlyb25tZW50cy4nKVxuICAub3B0aW9uKCctLWV4dCA8dHlwZT4nLCAnU3BlY2lmeSBKYXZhU2NyaXB0IGZpbGUgZXh0ZW5zaW9ucy4gRGVmYXVsdDogLmpzLicpXG4gIC5vcHRpb24oJy0tZml4JywgJ0F1dG9tYXRpY2FsbHkgZml4IHByb2JsZW1zLicsIGZhbHNlKVxuICAub3B0aW9uKCctLWZpeC1kcnktcnVuJywgJ0F1dG9tYXRpY2FsbHkgZml4IHByb2JsZW1zIHdpdGhvdXQgc2F2aW5nIHRoZSBjaGFuZ2VzIHRvIHRoZSBmaWxlIHN5c3RlbS4nLCBmYWxzZSlcbiAgLm9wdGlvbignLS1maXgtdHlwZSA8dHlwZT4nLCAnU3BlY2lmeSB0aGUgdHlwZXMgb2YgZml4ZXMgdG8gYXBwbHkgKHByb2JsZW0sIHN1Z2dlc3Rpb24sIGxheW91dCkuJylcbiAgLm9wdGlvbignLS1mb3JtYXQgPG5hbWU+JywgJ1VzZSBhIHNwZWNpZmljIG91dHB1dCBmb3JtYXQuIERlZmF1bHQ6IHN0eWxpc2guJylcbiAgLm9wdGlvbignLS1nbG9iYWwgPHZhcmlhYmxlcz4nLCAnRGVmaW5lIGdsb2JhbCB2YXJpYWJsZXMuJylcbiAgLm9wdGlvbignLS1pZ25vcmUtcGF0aCA8cGF0aD4nLCAnU3BlY2lmeSBwYXRoIG9mIGlnbm9yZSBmaWxlLicpXG4gIC5vcHRpb24oJy0taWdub3JlLXBhdHRlcm4gPHBhdHRlcm4+JywgJ1BhdHRlcm4gb2YgZmlsZXMgdG8gaWdub3JlIChpbiBhZGRpdGlvbiB0byB0aG9zZSBpbiAuZXNsaW50aWdub3JlKS4nKVxuICAub3B0aW9uKCctLWluaXQnLCAnUnVuIGNvbmZpZyBpbml0aWFsaXphdGlvbiB3aXphcmQuIERlZmF1bHQ6IGZhbHNlLicsIGZhbHNlKVxuICAub3B0aW9uKCctLW1heC13YXJuaW5ncyA8bnVtPicsICdOdW1iZXIgb2Ygd2FybmluZ3MgdG8gdHJpZ2dlciBub256ZXJvIGV4aXQgY29kZS4gRGVmYXVsdDogLTEuJylcbiAgLm9wdGlvbignLS1uby1jb2xvcicsICdGb3JjZSBkaXNhYmxpbmcgb2YgY29sb3IuJywgZmFsc2UpXG4gIC5vcHRpb24oJy0tbm8tZXNsaW50cmMnLCAnRGlzYWJsZSB1c2Ugb2YgY29uZmlndXJhdGlvbiBmcm9tIC5lc2xpbnRyYy4qLicsIGZhbHNlKVxuICAub3B0aW9uKCctLW5vLWlnbm9yZScsICdEaXNhYmxlIHVzZSBvZiBpZ25vcmUgZmlsZXMgYW5kIHBhdHRlcm5zLicsIGZhbHNlKVxuICAub3B0aW9uKCctLW5vLWlubGluZS1jb25maWcnLCAnUHJldmVudCBjb21tZW50cyBmcm9tIGNoYW5naW5nIGNvbmZpZyBvciBydWxlcy4nLCBmYWxzZSlcbiAgLm9wdGlvbignLS1vdXRwdXQtZmlsZSA8cGF0aD4nLCAnU3BlY2lmeSBmaWxlIHRvIHdyaXRlIHJlcG9ydCB0by4nKVxuICAub3B0aW9uKCctLXBhcnNlciA8bmFtZT4nLCAnU3BlY2lmeSB0aGUgcGFyc2VyIHRvIGJlIHVzZWQuJylcbiAgLm9wdGlvbignLS1wYXJzZXItb3B0aW9ucyA8b3B0aW9ucz4nLCAnU3BlY2lmeSBwYXJzZXIgb3B0aW9ucy4nKVxuICAub3B0aW9uKCctLXBsdWdpbiA8cGx1Z2lucz4nLCAnU3BlY2lmeSBwbHVnaW5zLicpXG4gIC5vcHRpb24oJy0tcHJpbnQtY29uZmlnIDxwYXRoPicsICdQcmludCB0aGUgY29uZmlndXJhdGlvbiBmb3IgdGhlIGdpdmVuIGZpbGUuJylcbiAgLm9wdGlvbignLS1xdWlldCcsICdObyBMZXggbm90aWZpY2F0aW9ucyBwcmludGVkIGluIHRoZSBjb25zb2xlLicsIGZhbHNlKVxuICAub3B0aW9uKCctLXJlcG9ydC11bnVzZWQtZGlzYWJsZS1kaXJlY3RpdmVzJywgJ0FkZHMgcmVwb3J0ZWQgZXJyb3JzIGZvciB1bnVzZWQgZXNsaW50LWRpc2FibGUgZGlyZWN0aXZlcy4nLCBmYWxzZSlcbiAgLm9wdGlvbignLS1yZXNvbHZlLXBsdWdpbnMtcmVsYXRpdmUtdG8gPHBhdGg+JywgJ0EgZm9sZGVyIHdoZXJlIHBsdWdpbnMgc2hvdWxkIGJlIHJlc29sdmVkIGZyb20uJylcbiAgLm9wdGlvbignLS1ydWxlIDxwYXRoPicsICdTcGVjaWZ5IHJ1bGVzLicpXG4gIC5vcHRpb24oJy0tcnVsZXNkaXIgPHBhdGg+JywgJ1VzZSBhZGRpdGlvbmFsIHJ1bGVzIGZyb20gdGhpcyBkaXJlY3RvcnkuJylcbiAgLm9wdGlvbignLS1zdGRpbicsICdMaW50IGNvZGUgcHJvdmlkZWQgb24gPFNURElOPiAtIERlZmF1bHQ6IGZhbHNlLicsIGZhbHNlKVxuICAub3B0aW9uKCctLXN0ZGluLWZpbGVuYW1lIDxuYW1lPicsICdTcGVjaWZ5IGZpbGVuYW1lIHRvIHByb2Nlc3MgU1RESU4gYXMuJylcbiAgLmFjdGlvbigoY21kKSA9PiBsaW50KGNtZCwgcHJvY2Vzcy5leGl0KS50aGVuKCgpID0+IHt9KSk7XG5cbnByb2dyYW1cbiAgLnZlcnNpb24ocGFja2FnZUpzb24udmVyc2lvbilcbiAgLnBhcnNlKHByb2Nlc3MuYXJndik7XG4iXSwKICAibWFwcGluZ3MiOiAiO0FBS0EsU0FBUSxlQUFjO0FBQ3RCLFNBQVEsb0JBQW1CO0FBQzNCLFNBQVEscUJBQW9CO0FBRTVCLFNBQVEsWUFBVztBQUVuQixNQUFNLGNBQWMsY0FBYyxJQUFJLElBQUksc0JBQXNCLFlBQVksR0FBRyxDQUFDO0FBQ2hGLE1BQU0sY0FBYyxLQUFLLE1BQU0sYUFBYSxhQUFhLE1BQU0sQ0FBQztBQUVoRSxRQUNHLE9BQU8sV0FBVyw2Q0FBNkMsS0FBSyxFQUNwRSxPQUFPLDJCQUEyQixzQ0FBc0MsRUFDeEUsT0FBTyxXQUFXLDRCQUE0QixLQUFLLEVBQ25ELE9BQU8sbUJBQW1CLDJFQUEyRSxFQUNyRyxPQUFPLFdBQVcsaUNBQWlDLEtBQUssRUFDeEQsT0FBTyxjQUFjLDZEQUE2RCxLQUFLLEVBQ3ZGLE9BQU8sZ0JBQWdCLHVCQUF1QixFQUM5QyxPQUFPLGdCQUFnQixtREFBbUQsRUFDMUUsT0FBTyxTQUFTLCtCQUErQixLQUFLLEVBQ3BELE9BQU8saUJBQWlCLDZFQUE2RSxLQUFLLEVBQzFHLE9BQU8scUJBQXFCLG9FQUFvRSxFQUNoRyxPQUFPLG1CQUFtQixpREFBaUQsRUFDM0UsT0FBTyx3QkFBd0IsMEJBQTBCLEVBQ3pELE9BQU8sd0JBQXdCLDhCQUE4QixFQUM3RCxPQUFPLDhCQUE4QixxRUFBcUUsRUFDMUcsT0FBTyxVQUFVLHFEQUFxRCxLQUFLLEVBQzNFLE9BQU8sd0JBQXdCLCtEQUErRCxFQUM5RixPQUFPLGNBQWMsNkJBQTZCLEtBQUssRUFDdkQsT0FBTyxpQkFBaUIsa0RBQWtELEtBQUssRUFDL0UsT0FBTyxlQUFlLDZDQUE2QyxLQUFLLEVBQ3hFLE9BQU8sc0JBQXNCLG1EQUFtRCxLQUFLLEVBQ3JGLE9BQU8sd0JBQXdCLGtDQUFrQyxFQUNqRSxPQUFPLG1CQUFtQixnQ0FBZ0MsRUFDMUQsT0FBTyw4QkFBOEIseUJBQXlCLEVBQzlELE9BQU8sc0JBQXNCLGtCQUFrQixFQUMvQyxPQUFPLHlCQUF5Qiw2Q0FBNkMsRUFDN0UsT0FBTyxXQUFXLGdEQUFnRCxLQUFLLEVBQ3ZFLE9BQU8sc0NBQXNDLDhEQUE4RCxLQUFLLEVBQ2hILE9BQU8sd0NBQXdDLGlEQUFpRCxFQUNoRyxPQUFPLGlCQUFpQixnQkFBZ0IsRUFDeEMsT0FBTyxxQkFBcUIsMkNBQTJDLEVBQ3ZFLE9BQU8sV0FBVyxtREFBbUQsS0FBSyxFQUMxRSxPQUFPLDJCQUEyQix1Q0FBdUMsRUFDekUsT0FBTyxDQUFDLFFBQVEsS0FBSyxLQUFLLFFBQVEsSUFBSSxFQUFFLEtBQUssTUFBTTtBQUFDLENBQUMsQ0FBQztBQUV6RCxRQUNHLFFBQVEsWUFBWSxPQUFPLEVBQzNCLE1BQU0sUUFBUSxJQUFJOyIsCiAgIm5hbWVzIjogW10KfQo=
package/jest.setup.ts DELETED
@@ -1,3 +0,0 @@
1
- // const execaMock = require('@nlabs/execa-mock');
2
-
3
- // jest.mock('execa', execaMock);