@nlabs/lex 1.39.0 → 1.41.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/.eslintrc +1 -0
- package/.vscode/settings.json +1 -1
- package/babel.config.json +13 -0
- package/dist/LexConfig.js +40 -36
- package/dist/commands/build.js +98 -52
- package/dist/commands/bulid.test.js +314 -5
- package/dist/commands/clean.js +4 -4
- package/dist/commands/clean.test.js +63 -0
- package/dist/commands/compile.js +32 -35
- package/dist/commands/compile.test.js +93 -0
- package/dist/commands/config.js +4 -4
- package/dist/commands/copy.js +1 -1
- package/dist/commands/create.js +10 -10
- package/dist/commands/dev.js +12 -12
- package/dist/commands/init.js +17 -17
- package/dist/commands/link.js +3 -3
- package/dist/commands/lint.js +53 -39
- package/dist/commands/migrate.js +4 -4
- package/dist/commands/publish.js +7 -7
- package/dist/commands/test.js +14 -14
- package/dist/commands/update.js +10 -10
- package/dist/commands/upgrade.js +7 -7
- package/dist/commands/versions.js +8 -9
- package/dist/commands/versions.test.js +49 -0
- package/dist/create/changelog.js +3 -3
- package/dist/lex.js +16 -16
- package/dist/lint.js +8 -0
- package/dist/utils/app.js +1 -1
- package/dist/utils/file.js +20 -10
- package/jest.config.cjs +55 -0
- package/jest.config.lex.js +27 -28
- package/jest.setup.ts +3 -0
- package/package.json +76 -71
- package/resolver.cjs +86 -0
- package/test/javascript.js +6 -0
- package/test/typescript.ts +6 -0
- package/tsconfig.build.json +1 -1
- package/tsconfig.json +1 -1
- package/tsconfig.template.json +5 -5
- package/webpack.config.js +78 -65
- package/dist/resolver.js +0 -70
- package/jest.config.js +0 -14
- package/jest.setup.js +0 -3
package/dist/commands/test.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { execa } from "execa";
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
2
|
+
import { resolve as pathResolve } from "path";
|
|
3
|
+
import { URL } from "url";
|
|
4
4
|
import { LexConfig } from "../LexConfig.js";
|
|
5
5
|
import { createSpinner } from "../utils/app.js";
|
|
6
|
-
import {
|
|
6
|
+
import { relativeNodePath } from "../utils/file.js";
|
|
7
7
|
import { log } from "../utils/log.js";
|
|
8
8
|
const test = async (cmd, callback = process.exit) => {
|
|
9
9
|
const {
|
|
@@ -48,17 +48,17 @@ const test = async (cmd, callback = process.exit) => {
|
|
|
48
48
|
} = cmd;
|
|
49
49
|
log(`${cliName} testing...`, "info", quiet);
|
|
50
50
|
const spinner = createSpinner(quiet);
|
|
51
|
-
LexConfig.parseConfig(cmd);
|
|
51
|
+
await LexConfig.parseConfig(cmd);
|
|
52
52
|
const { useTypescript } = LexConfig.config;
|
|
53
53
|
if (useTypescript) {
|
|
54
54
|
LexConfig.checkTypescriptConfig();
|
|
55
55
|
}
|
|
56
|
-
const dirName =
|
|
57
|
-
const
|
|
58
|
-
const jestPath =
|
|
59
|
-
const jestConfigFile = config ||
|
|
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
60
|
const jestSetupFile = setup || "";
|
|
61
|
-
const jestOptions = ["--config", jestConfigFile];
|
|
61
|
+
const jestOptions = ["--config", jestConfigFile, "--no-cache"];
|
|
62
62
|
if (bail) {
|
|
63
63
|
jestOptions.push("--bail");
|
|
64
64
|
}
|
|
@@ -157,7 +157,7 @@ const test = async (cmd, callback = process.exit) => {
|
|
|
157
157
|
}
|
|
158
158
|
if (jestSetupFile !== "") {
|
|
159
159
|
const cwd = process.cwd();
|
|
160
|
-
jestOptions.push(`--
|
|
160
|
+
jestOptions.push(`--setupFilesAfterEnv=${pathResolve(cwd, jestSetupFile)}`);
|
|
161
161
|
}
|
|
162
162
|
if (update) {
|
|
163
163
|
jestOptions.push("--updateSnapshot");
|
|
@@ -167,7 +167,7 @@ const test = async (cmd, callback = process.exit) => {
|
|
|
167
167
|
}
|
|
168
168
|
try {
|
|
169
169
|
await execa(jestPath, jestOptions, {
|
|
170
|
-
encoding: "
|
|
170
|
+
encoding: "utf8",
|
|
171
171
|
stdio: "inherit"
|
|
172
172
|
});
|
|
173
173
|
spinner.succeed("Testing completed!");
|
|
@@ -177,11 +177,11 @@ const test = async (cmd, callback = process.exit) => {
|
|
|
177
177
|
log(`
|
|
178
178
|
${cliName} Error: Check for unit test errors and/or coverage.`, "error", quiet);
|
|
179
179
|
spinner.fail("Testing failed!");
|
|
180
|
-
callback(
|
|
181
|
-
return
|
|
180
|
+
callback(1);
|
|
181
|
+
return 1;
|
|
182
182
|
}
|
|
183
183
|
};
|
|
184
184
|
export {
|
|
185
185
|
test
|
|
186
186
|
};
|
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/test.ts"],
  "sourcesContent": ["import {execa} from 'execa';\nimport * as path from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner} from '../utils/app.js';\nimport {relativeFilePath} from '../utils/file.js';\nimport {log} from '../utils/log.js';\n\nexport const test = async (cmd: any, 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  } = cmd;\n\n  log(`${cliName} testing...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  LexConfig.parseConfig(cmd);\n\n  const {useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    // Make sure tsconfig.json exists\n    LexConfig.checkTypescriptConfig();\n  }\n\n  // Configure jest\n  const dirName = fileURLToPath(new URL('.', import.meta.url));\n  const nodePath: string = path.resolve(dirName, '../../node_modules');\n  const jestPath: string = relativeFilePath('jest-cli/bin/jest.js', nodePath);\n  const jestConfigFile: string = config || path.resolve(dirName, '../../jest.config.lex.js');\n  const jestSetupFile: string = setup || '';\n  const jestOptions: string[] = ['--config', jestConfigFile];\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(`--setupTestFrameworkScriptFile=${path.resolve(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  // Test app using jest\n  try {\n    await execa(jestPath, jestOptions, {\n      encoding: 'utf-8',\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(error.status);\n    return error.status;\n  }\n};\n"],
  "mappings": "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",
  "names": []
}

|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/test.ts"],
  "sourcesContent": ["import {execa} from 'execa';\nimport {resolve as pathResolve} from 'path';\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 (cmd: any, 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  } = cmd;\n\n  log(`${cliName} testing...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n\n  const {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  // Test app using jest\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": []
}

|
package/dist/commands/update.js
CHANGED
|
@@ -6,7 +6,7 @@ const update = async (cmd, callback = process.exit) => {
|
|
|
6
6
|
const { cliName = "Lex", packageManager: cmdPackageManager, quiet, registry } = cmd;
|
|
7
7
|
log(`${cliName} updating packages...`, "info", quiet);
|
|
8
8
|
const spinner = createSpinner(quiet);
|
|
9
|
-
LexConfig.parseConfig(cmd);
|
|
9
|
+
await LexConfig.parseConfig(cmd);
|
|
10
10
|
const { packageManager: configPackageManager } = LexConfig.config;
|
|
11
11
|
const packageManager = cmdPackageManager || configPackageManager || "npm";
|
|
12
12
|
const updateApp = packageManager === "npm" ? "npx" : "yarn";
|
|
@@ -20,24 +20,24 @@ const update = async (cmd, callback = process.exit) => {
|
|
|
20
20
|
"0",
|
|
21
21
|
"--target",
|
|
22
22
|
"latest",
|
|
23
|
-
cmd.interactive ? "
|
|
24
|
-
"
|
|
23
|
+
cmd.interactive ? "--interactive" : "",
|
|
24
|
+
"--upgrade"
|
|
25
25
|
] : [cmd.interactive ? "upgrade-interactive" : "upgrade", "--latest"];
|
|
26
26
|
if (registry) {
|
|
27
27
|
updateOptions.push("--registry", registry);
|
|
28
28
|
}
|
|
29
29
|
try {
|
|
30
30
|
await execa(updateApp, updateOptions, {
|
|
31
|
-
encoding: "
|
|
31
|
+
encoding: "utf8",
|
|
32
32
|
stdio: "inherit"
|
|
33
33
|
});
|
|
34
34
|
if (packageManager === "npm") {
|
|
35
|
-
await execa("npm", ["i"], {
|
|
36
|
-
encoding: "
|
|
35
|
+
await execa("npm", ["i", "--force"], {
|
|
36
|
+
encoding: "utf8",
|
|
37
37
|
stdio: "inherit"
|
|
38
38
|
});
|
|
39
39
|
await execa("npm", ["audit", "fix"], {
|
|
40
|
-
encoding: "
|
|
40
|
+
encoding: "utf8",
|
|
41
41
|
stdio: "inherit"
|
|
42
42
|
});
|
|
43
43
|
}
|
|
@@ -48,11 +48,11 @@ const update = async (cmd, callback = process.exit) => {
|
|
|
48
48
|
log(`
|
|
49
49
|
${cliName} Error: ${error.message}`, "error", quiet);
|
|
50
50
|
spinner.fail("Failed to updated packages.");
|
|
51
|
-
callback(
|
|
52
|
-
return
|
|
51
|
+
callback(1);
|
|
52
|
+
return 1;
|
|
53
53
|
}
|
|
54
54
|
};
|
|
55
55
|
export {
|
|
56
56
|
update
|
|
57
57
|
};
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL3VwZGF0ZS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXJ9IGZyb20gJy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGNvbnN0IHVwZGF0ZSA9IGFzeW5jIChjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9IHByb2Nlc3MuZXhpdCk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtjbGlOYW1lID0gJ0xleCcsIHBhY2thZ2VNYW5hZ2VyOiBjbWRQYWNrYWdlTWFuYWdlciwgcXVpZXQsIHJlZ2lzdHJ5fSA9IGNtZDtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gdXBkYXRpbmcgcGFja2FnZXMuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgY29uc3Qge3BhY2thZ2VNYW5hZ2VyOiBjb25maWdQYWNrYWdlTWFuYWdlcn0gPSBMZXhDb25maWcuY29uZmlnO1xuICBjb25zdCBwYWNrYWdlTWFuYWdlcjogc3RyaW5nID0gY21kUGFja2FnZU1hbmFnZXIgfHwgY29uZmlnUGFja2FnZU1hbmFnZXIgfHwgJ25wbSc7XG4gIGNvbnN0IHVwZGF0ZUFwcDogc3RyaW5nID0gcGFja2FnZU1hbmFnZXIgPT09ICducG0nID8gJ25weCcgOiAneWFybic7XG4gIGNvbnN0IHVwZGF0ZU9wdGlvbnM6IHN0cmluZ1tdID0gcGFja2FnZU1hbmFnZXIgPT09ICducG0nXG4gICAgPyBbJ25wbS1jaGVjay11cGRhdGVzJyxcbiAgICAgICctLWNvbmN1cnJlbmN5JywgJzEwJyxcbiAgICAgICctLXBhY2thZ2VNYW5hZ2VyJywgcGFja2FnZU1hbmFnZXIsXG4gICAgICAnLS1wcmUnLCAnMCcsXG4gICAgICAnLS10YXJnZXQnLCAnbGF0ZXN0JyxcbiAgICAgIGNtZC5pbnRlcmFjdGl2ZSA/ICctLWludGVyYWN0aXZlJyA6ICcnLFxuICAgICAgJy0tdXBncmFkZSdcbiAgICBdXG4gICAgOiBbY21kLmludGVyYWN0aXZlID8gJ3VwZ3JhZGUtaW50ZXJhY3RpdmUnIDogJ3VwZ3JhZGUnLCAnLS1sYXRlc3QnXTtcblxuICBpZihyZWdpc3RyeSkge1xuICAgIHVwZGF0ZU9wdGlvbnMucHVzaCgnLS1yZWdpc3RyeScsIHJlZ2lzdHJ5KTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EodXBkYXRlQXBwLCB1cGRhdGVPcHRpb25zLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgIH0pO1xuXG4gICAgaWYocGFja2FnZU1hbmFnZXIgPT09ICducG0nKSB7XG4gICAgICBhd2FpdCBleGVjYSgnbnBtJywgWydpJywgJy0tZm9yY2UnXSwge1xuICAgICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgICBzdGRpbzogJ2luaGVyaXQnXG4gICAgICB9KTtcblxuICAgICAgYXdhaXQgZXhlY2EoJ25wbScsIFsnYXVkaXQnLCAnZml4J10sIHtcbiAgICAgICAgZW5jb2Rpbmc6ICd1dGY4JyxcbiAgICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgICAgfSk7XG4gICAgfVxuXG4gICAgLy8gU3RvcCBsb2FkZXJcbiAgICBzcGlubmVyLnN1Y2NlZWQoJ1N1Y2Nlc3NmdWxseSB1cGRhdGVkIHBhY2thZ2VzIScpO1xuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMCk7XG4gICAgcmV0dXJuIDA7XG4gIH0gY2F0Y2goZXJyb3IpIHtcbiAgICAvLyBEaXNwbGF5IGVycm9yIG1lc3NhZ2VcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6ICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG5cbiAgICAvLyBTdG9wIHNwaW5uZXJcbiAgICBzcGlubmVyLmZhaWwoJ0ZhaWxlZCB0byB1cGRhdGVkIHBhY2thZ2VzLicpO1xuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMSk7XG4gICAgcmV0dXJuIDE7XG4gIH1cbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGFBQVk7QUFFcEIsU0FBUSxpQkFBZ0I7QUFDeEIsU0FBUSxxQkFBb0I7QUFDNUIsU0FBUSxXQUFVO0FBRVgsTUFBTSxTQUFTLE9BQU8sS0FBVSxXQUFnQixRQUFRLFNBQTBCO0FBQ3ZGLFFBQU0sRUFBQyxVQUFVLE9BQU8sZ0JBQWdCLG1CQUFtQixPQUFPLFNBQVEsSUFBSTtBQUc5RSxNQUFJLEdBQUcsT0FBTyx5QkFBeUIsUUFBUSxLQUFLO0FBR3BELFFBQU0sVUFBVSxjQUFjLEtBQUs7QUFHbkMsUUFBTSxVQUFVLFlBQVksR0FBRztBQUUvQixRQUFNLEVBQUMsZ0JBQWdCLHFCQUFvQixJQUFJLFVBQVU7QUFDekQsUUFBTSxpQkFBeUIscUJBQXFCLHdCQUF3QjtBQUM1RSxRQUFNLFlBQW9CLG1CQUFtQixRQUFRLFFBQVE7QUFDN0QsUUFBTSxnQkFBMEIsbUJBQW1CLFFBQy9DO0FBQUEsSUFBQztBQUFBLElBQ0Q7QUFBQSxJQUFpQjtBQUFBLElBQ2pCO0FBQUEsSUFBb0I7QUFBQSxJQUNwQjtBQUFBLElBQVM7QUFBQSxJQUNUO0FBQUEsSUFBWTtBQUFBLElBQ1osSUFBSSxjQUFjLGtCQUFrQjtBQUFBLElBQ3BDO0FBQUEsRUFDRixJQUNFLENBQUMsSUFBSSxjQUFjLHdCQUF3QixXQUFXLFVBQVU7QUFFcEUsTUFBRyxVQUFVO0FBQ1gsa0JBQWMsS0FBSyxjQUFjLFFBQVE7QUFBQSxFQUMzQztBQUVBLE1BQUk7QUFDRixVQUFNLE1BQU0sV0FBVyxlQUFlO0FBQUEsTUFDcEMsVUFBVTtBQUFBLE1BQ1YsT0FBTztBQUFBLElBQ1QsQ0FBQztBQUVELFFBQUcsbUJBQW1CLE9BQU87QUFDM0IsWUFBTSxNQUFNLE9BQU8sQ0FBQyxLQUFLLFNBQVMsR0FBRztBQUFBLFFBQ25DLFVBQVU7QUFBQSxRQUNWLE9BQU87QUFBQSxNQUNULENBQUM7QUFFRCxZQUFNLE1BQU0sT0FBTyxDQUFDLFNBQVMsS0FBSyxHQUFHO0FBQUEsUUFDbkMsVUFBVTtBQUFBLFFBQ1YsT0FBTztBQUFBLE1BQ1QsQ0FBQztBQUFBLElBQ0g7QUFHQSxZQUFRLFFBQVEsZ0NBQWdDO0FBR2hELGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNULFNBQVEsT0FBTztBQUViLFFBQUk7QUFBQSxFQUFLLE9BQU8sV0FBVyxNQUFNLE9BQU8sSUFBSSxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLDZCQUE2QjtBQUcxQyxhQUFTLENBQUM7QUFDVixXQUFPO0FBQUEsRUFDVDtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
|
package/dist/commands/upgrade.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import compareVersions from "compare-versions";
|
|
1
|
+
import { compareVersions } from "compare-versions";
|
|
2
2
|
import { execa } from "execa";
|
|
3
3
|
import latestVersion from "latest-version";
|
|
4
4
|
import packageJson from "../../package.json" assert { type: "json" };
|
|
@@ -6,11 +6,11 @@ import { LexConfig } from "../LexConfig.js";
|
|
|
6
6
|
import { createSpinner } from "../utils/app.js";
|
|
7
7
|
import { log } from "../utils/log.js";
|
|
8
8
|
import { parseVersion } from "./versions.js";
|
|
9
|
-
const upgrade = (cmd, callback = process.exit) => {
|
|
9
|
+
const upgrade = async (cmd, callback = process.exit) => {
|
|
10
10
|
const { cliName = "Lex", cliPackage = "@nlabs/lex", quiet } = cmd;
|
|
11
11
|
log(`Upgrading ${cliName}...`, "info", quiet);
|
|
12
12
|
const spinner = createSpinner(quiet);
|
|
13
|
-
LexConfig.parseConfig(cmd);
|
|
13
|
+
await LexConfig.parseConfig(cmd);
|
|
14
14
|
return latestVersion("@nlabs/lex").then(async (latest) => {
|
|
15
15
|
const current = parseVersion(packageJson.version);
|
|
16
16
|
const versionDiff = compareVersions(latest, current);
|
|
@@ -24,7 +24,7 @@ Currently up-to-date. Version ${latest} is the latest.`, "note", quiet);
|
|
|
24
24
|
Currently out of date. Upgrading from version ${current} to ${latest}...`, "note", quiet);
|
|
25
25
|
const upgradeOptions = ["install", "-g", `${cliPackage}@latest`];
|
|
26
26
|
await execa("npm", upgradeOptions, {
|
|
27
|
-
encoding: "
|
|
27
|
+
encoding: "utf8",
|
|
28
28
|
stdio: "inherit"
|
|
29
29
|
});
|
|
30
30
|
spinner.succeed(`Successfully updated ${cliName}!`);
|
|
@@ -34,11 +34,11 @@ Currently out of date. Upgrading from version ${current} to ${latest}...`, "note
|
|
|
34
34
|
log(`
|
|
35
35
|
${cliName} Error: ${error.message}`, "error", quiet);
|
|
36
36
|
spinner.fail("Failed to updated packages.");
|
|
37
|
-
callback(
|
|
38
|
-
return
|
|
37
|
+
callback(1);
|
|
38
|
+
return 1;
|
|
39
39
|
});
|
|
40
40
|
};
|
|
41
41
|
export {
|
|
42
42
|
upgrade
|
|
43
43
|
};
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL3VwZ3JhZGUudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2NvbXBhcmVWZXJzaW9uc30gZnJvbSAnY29tcGFyZS12ZXJzaW9ucyc7XG5pbXBvcnQge2V4ZWNhfSBmcm9tICdleGVjYSc7XG5pbXBvcnQgbGF0ZXN0VmVyc2lvbiBmcm9tICdsYXRlc3QtdmVyc2lvbic7XG5cbmltcG9ydCBwYWNrYWdlSnNvbiBmcm9tICcuLi8uLi9wYWNrYWdlLmpzb24nIGFzc2VydCB7dHlwZTogJ2pzb24nfTtcbmltcG9ydCB7TGV4Q29uZmlnfSBmcm9tICcuLi9MZXhDb25maWcuanMnO1xuaW1wb3J0IHtjcmVhdGVTcGlubmVyfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5pbXBvcnQge3BhcnNlVmVyc2lvbn0gZnJvbSAnLi92ZXJzaW9ucy5qcyc7XG5cbmV4cG9ydCBjb25zdCB1cGdyYWRlID0gYXN5bmMgKGNtZDogYW55LCBjYWxsYmFjazogYW55ID0gcHJvY2Vzcy5leGl0KTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgY2xpUGFja2FnZSA9ICdAbmxhYnMvbGV4JywgcXVpZXR9ID0gY21kO1xuXG4gIC8vIERpc3BsYXkgc3RhdHVzXG4gIGxvZyhgVXBncmFkaW5nICR7Y2xpTmFtZX0uLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgcmV0dXJuIGxhdGVzdFZlcnNpb24oJ0BubGFicy9sZXgnKVxuICAgIC50aGVuKGFzeW5jIChsYXRlc3Q6IHN0cmluZykgPT4ge1xuICAgICAgY29uc3QgY3VycmVudDogc3RyaW5nID0gcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uLnZlcnNpb24pO1xuICAgICAgY29uc3QgdmVyc2lvbkRpZmY6IG51bWJlciA9IGNvbXBhcmVWZXJzaW9ucyhsYXRlc3QsIGN1cnJlbnQpO1xuXG4gICAgICBpZih2ZXJzaW9uRGlmZiA9PT0gMCkge1xuICAgICAgICBsb2coYFxcbkN1cnJlbnRseSB1cC10by1kYXRlLiBWZXJzaW9uICR7bGF0ZXN0fSBpcyB0aGUgbGF0ZXN0LmAsICdub3RlJywgcXVpZXQpO1xuICAgICAgICBjYWxsYmFjaygwKTtcbiAgICAgICAgcmV0dXJuIDA7XG4gICAgICB9XG5cbiAgICAgIGxvZyhgXFxuQ3VycmVudGx5IG91dCBvZiBkYXRlLiBVcGdyYWRpbmcgZnJvbSB2ZXJzaW9uICR7Y3VycmVudH0gdG8gJHtsYXRlc3R9Li4uYCwgJ25vdGUnLCBxdWlldCk7XG5cbiAgICAgIGNvbnN0IHVwZ3JhZGVPcHRpb25zOiBzdHJpbmdbXSA9IFsnaW5zdGFsbCcsICctZycsIGAke2NsaVBhY2thZ2V9QGxhdGVzdGBdO1xuXG4gICAgICBhd2FpdCBleGVjYSgnbnBtJywgdXBncmFkZU9wdGlvbnMsIHtcbiAgICAgICAgZW5jb2Rpbmc6ICd1dGY4JyxcbiAgICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgICAgfSk7XG5cbiAgICAgIC8vIFN0b3AgbG9hZGVyXG4gICAgICBzcGlubmVyLnN1Y2NlZWQoYFN1Y2Nlc3NmdWxseSB1cGRhdGVkICR7Y2xpTmFtZX0hYCk7XG5cbiAgICAgIC8vIFN0b3AgcHJvY2Vzc1xuICAgICAgY2FsbGJhY2soMCk7XG4gICAgICByZXR1cm4gMDtcbiAgICB9KVxuICAgIC5jYXRjaCgoZXJyb3IpID0+IHtcbiAgICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgICAvLyBTdG9wIHNwaW5uZXJcbiAgICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIHVwZGF0ZWQgcGFja2FnZXMuJyk7XG5cbiAgICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgICAgY2FsbGJhY2soMSk7XG4gICAgICByZXR1cm4gMTtcbiAgICB9KTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLHVCQUFzQjtBQUM5QixTQUFRLGFBQVk7QUFDcEIsT0FBTyxtQkFBbUI7QUFFMUIsT0FBTyxpQkFBaUIscUJBQXFCLE9BQU8sRUFBQyxNQUFNLE9BQU07QUFDakUsU0FBUSxpQkFBZ0I7QUFDeEIsU0FBUSxxQkFBb0I7QUFDNUIsU0FBUSxXQUFVO0FBQ2xCLFNBQVEsb0JBQW1CO0FBRXBCLE1BQU0sVUFBVSxPQUFPLEtBQVUsV0FBZ0IsUUFBUSxTQUEwQjtBQUN4RixRQUFNLEVBQUMsVUFBVSxPQUFPLGFBQWEsY0FBYyxNQUFLLElBQUk7QUFHNUQsTUFBSSxhQUFhLE9BQU8sT0FBTyxRQUFRLEtBQUs7QUFHNUMsUUFBTSxVQUFVLGNBQWMsS0FBSztBQUduQyxRQUFNLFVBQVUsWUFBWSxHQUFHO0FBRS9CLFNBQU8sY0FBYyxZQUFZLEVBQzlCLEtBQUssT0FBTyxXQUFtQjtBQUM5QixVQUFNLFVBQWtCLGFBQWEsWUFBWSxPQUFPO0FBQ3hELFVBQU0sY0FBc0IsZ0JBQWdCLFFBQVEsT0FBTztBQUUzRCxRQUFHLGdCQUFnQixHQUFHO0FBQ3BCLFVBQUk7QUFBQSxnQ0FBbUMsTUFBTSxtQkFBbUIsUUFBUSxLQUFLO0FBQzdFLGVBQVMsQ0FBQztBQUNWLGFBQU87QUFBQSxJQUNUO0FBRUEsUUFBSTtBQUFBLGdEQUFtRCxPQUFPLE9BQU8sTUFBTSxPQUFPLFFBQVEsS0FBSztBQUUvRixVQUFNLGlCQUEyQixDQUFDLFdBQVcsTUFBTSxHQUFHLFVBQVUsU0FBUztBQUV6RSxVQUFNLE1BQU0sT0FBTyxnQkFBZ0I7QUFBQSxNQUNqQyxVQUFVO0FBQUEsTUFDVixPQUFPO0FBQUEsSUFDVCxDQUFDO0FBR0QsWUFBUSxRQUFRLHdCQUF3QixPQUFPLEdBQUc7QUFHbEQsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsQ0FBQyxFQUNBLE1BQU0sQ0FBQyxVQUFVO0FBRWhCLFFBQUk7QUFBQSxFQUFLLE9BQU8sV0FBVyxNQUFNLE9BQU8sSUFBSSxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLDZCQUE2QjtBQUcxQyxhQUFTLENBQUM7QUFDVixXQUFPO0FBQUEsRUFDVCxDQUFDO0FBQ0w7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import packageJson from "../../package.json" assert { type: "json" };
|
|
2
2
|
import { log } from "../utils/log.js";
|
|
3
|
-
const parseVersion = (packageVersion
|
|
3
|
+
const parseVersion = (packageVersion) => packageVersion?.replace(/\^/g, "");
|
|
4
4
|
const packages = {
|
|
5
5
|
esbuild: parseVersion(packageJson.dependencies.esbuild),
|
|
6
6
|
jest: parseVersion(packageJson.dependencies.jest),
|
|
@@ -8,16 +8,13 @@ const packages = {
|
|
|
8
8
|
typescript: parseVersion(packageJson.dependencies.typescript),
|
|
9
9
|
webpack: parseVersion(packageJson.dependencies.webpack)
|
|
10
10
|
};
|
|
11
|
-
const jsonVersions = () => Object.keys(
|
|
11
|
+
const jsonVersions = (lexPackages) => Object.keys(lexPackages).reduce((list, key) => {
|
|
12
12
|
list[key] = packages[key];
|
|
13
13
|
return list;
|
|
14
14
|
}, {});
|
|
15
|
-
const versions = (cmd, callback
|
|
15
|
+
const versions = (cmd, callback) => {
|
|
16
16
|
if (cmd.json) {
|
|
17
|
-
console.log(JSON.stringify(
|
|
18
|
-
list[key] = packages[key];
|
|
19
|
-
return list;
|
|
20
|
-
}, {})));
|
|
17
|
+
console.log(JSON.stringify(jsonVersions(packages)));
|
|
21
18
|
} else {
|
|
22
19
|
log("Versions:", "info", false);
|
|
23
20
|
log(` Lex: ${packages.lex}`, "info", false);
|
|
@@ -27,7 +24,9 @@ const versions = (cmd, callback = () => 0) => {
|
|
|
27
24
|
log(` Typescript: ${packages.typescript}`, "info", false);
|
|
28
25
|
log(` Webpack: ${packages.webpack}`, "info", false);
|
|
29
26
|
}
|
|
30
|
-
callback
|
|
27
|
+
if (callback) {
|
|
28
|
+
callback(0);
|
|
29
|
+
}
|
|
31
30
|
return Promise.resolve(0);
|
|
32
31
|
};
|
|
33
32
|
export {
|
|
@@ -36,4 +35,4 @@ export {
|
|
|
36
35
|
parseVersion,
|
|
37
36
|
versions
|
|
38
37
|
};
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL3ZlcnNpb25zLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHBhY2thZ2VKc29uIGZyb20gJy4uLy4uL3BhY2thZ2UuanNvbicgYXNzZXJ0IHt0eXBlOidqc29uJ307XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGNvbnN0IHBhcnNlVmVyc2lvbiA9IChwYWNrYWdlVmVyc2lvbjogc3RyaW5nKTogc3RyaW5nID0+IHBhY2thZ2VWZXJzaW9uPy5yZXBsYWNlKC9cXF4vZywgJycpO1xuXG5leHBvcnQgY29uc3QgcGFja2FnZXMgPSB7XG4gIGVzYnVpbGQ6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbi5kZXBlbmRlbmNpZXMuZXNidWlsZCksXG4gIGplc3Q6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbi5kZXBlbmRlbmNpZXMuamVzdCksXG4gIGxleDogcGFja2FnZUpzb24udmVyc2lvbixcbiAgdHlwZXNjcmlwdDogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uLmRlcGVuZGVuY2llcy50eXBlc2NyaXB0KSxcbiAgd2VicGFjazogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uLmRlcGVuZGVuY2llcy53ZWJwYWNrKVxufTtcblxuZXhwb3J0IGNvbnN0IGpzb25WZXJzaW9ucyA9IChsZXhQYWNrYWdlcykgPT4gT2JqZWN0LmtleXMobGV4UGFja2FnZXMpLnJlZHVjZSgobGlzdCwga2V5KSA9PiB7XG4gIGxpc3Rba2V5XSA9IHBhY2thZ2VzW2tleV07XG4gIHJldHVybiBsaXN0O1xufSwge30pO1xuXG5leHBvcnQgaW50ZXJmYWNlIFZlcnNpb25zQ21kIHtcbiAgcmVhZG9ubHkganNvbj86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjb25zdCB2ZXJzaW9ucyA9IChjbWQ6IFZlcnNpb25zQ21kLCBjYWxsYmFjazogKHN0YXR1czogbnVtYmVyKSA9PiB2b2lkKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgaWYoY21kLmpzb24pIHtcbiAgICBjb25zb2xlLmxvZyhKU09OLnN0cmluZ2lmeShqc29uVmVyc2lvbnMocGFja2FnZXMpKSk7XG4gIH0gZWxzZSB7XG4gICAgbG9nKCdWZXJzaW9uczonLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgTGV4OiAke3BhY2thZ2VzLmxleH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coJyAgLS0tLS0tLS0tLScsICdub3RlJywgZmFsc2UpO1xuICAgIGxvZyhgICBFU0J1aWxkOiAke3BhY2thZ2VzLmVzYnVpbGR9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIEplc3Q6ICR7cGFja2FnZXMuamVzdH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgVHlwZXNjcmlwdDogJHtwYWNrYWdlcy50eXBlc2NyaXB0fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBXZWJwYWNrOiAke3BhY2thZ2VzLndlYnBhY2t9YCwgJ2luZm8nLCBmYWxzZSk7XG4gIH1cblxuICBpZihjYWxsYmFjaykge1xuICAgIGNhbGxiYWNrKDApO1xuICB9XG5cbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgwKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFLQSxPQUFPLGlCQUFpQixxQkFBcUIsT0FBTyxFQUFDLE1BQUssT0FBTTtBQUNoRSxTQUFRLFdBQVU7QUFFWCxNQUFNLGVBQWUsQ0FBQyxtQkFBbUMsZ0JBQWdCLFFBQVEsT0FBTyxFQUFFO0FBRTFGLE1BQU0sV0FBVztBQUFBLEVBQ3RCLFNBQVMsYUFBYSxZQUFZLGFBQWEsT0FBTztBQUFBLEVBQ3RELE1BQU0sYUFBYSxZQUFZLGFBQWEsSUFBSTtBQUFBLEVBQ2hELEtBQUssWUFBWTtBQUFBLEVBQ2pCLFlBQVksYUFBYSxZQUFZLGFBQWEsVUFBVTtBQUFBLEVBQzVELFNBQVMsYUFBYSxZQUFZLGFBQWEsT0FBTztBQUN4RDtBQUVPLE1BQU0sZUFBZSxDQUFDLGdCQUFnQixPQUFPLEtBQUssV0FBVyxFQUFFLE9BQU8sQ0FBQyxNQUFNLFFBQVE7QUFDMUYsT0FBSyxHQUFHLElBQUksU0FBUyxHQUFHO0FBQ3hCLFNBQU87QUFDVCxHQUFHLENBQUMsQ0FBQztBQU1FLE1BQU0sV0FBVyxDQUFDLEtBQWtCLGFBQXdEO0FBQ2pHLE1BQUcsSUFBSSxNQUFNO0FBQ1gsWUFBUSxJQUFJLEtBQUssVUFBVSxhQUFhLFFBQVEsQ0FBQyxDQUFDO0FBQUEsRUFDcEQsT0FBTztBQUNMLFFBQUksYUFBYSxRQUFRLEtBQUs7QUFDOUIsUUFBSSxVQUFVLFNBQVMsR0FBRyxJQUFJLFFBQVEsS0FBSztBQUMzQyxRQUFJLGdCQUFnQixRQUFRLEtBQUs7QUFDakMsUUFBSSxjQUFjLFNBQVMsT0FBTyxJQUFJLFFBQVEsS0FBSztBQUNuRCxRQUFJLFdBQVcsU0FBUyxJQUFJLElBQUksUUFBUSxLQUFLO0FBQzdDLFFBQUksaUJBQWlCLFNBQVMsVUFBVSxJQUFJLFFBQVEsS0FBSztBQUN6RCxRQUFJLGNBQWMsU0FBUyxPQUFPLElBQUksUUFBUSxLQUFLO0FBQUEsRUFDckQ7QUFFQSxNQUFHLFVBQVU7QUFDWCxhQUFTLENBQUM7QUFBQSxFQUNaO0FBRUEsU0FBTyxRQUFRLFFBQVEsQ0FBQztBQUMxQjsiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -0,0 +1,49 @@
|
|
|
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/create/changelog.js
CHANGED
|
@@ -4,7 +4,7 @@ import capitalize from "lodash/capitalize.js";
|
|
|
4
4
|
import isEmpty from "lodash/isEmpty.js";
|
|
5
5
|
import merge from "lodash/merge.js";
|
|
6
6
|
import { DateTime } from "luxon";
|
|
7
|
-
import
|
|
7
|
+
import { join as pathJoin } from "path";
|
|
8
8
|
import { createSpinner } from "../utils/app.js";
|
|
9
9
|
import { log } from "../utils/log.js";
|
|
10
10
|
const createChangelog = async ({ cliName, config, outputFile = "changelog.tmp.md", quiet }) => {
|
|
@@ -111,7 +111,7 @@ const createChangelog = async ({ cliName, config, outputFile = "changelog.tmp.md
|
|
|
111
111
|
});
|
|
112
112
|
return updatedContent;
|
|
113
113
|
}, "# Changes\n");
|
|
114
|
-
const logFile =
|
|
114
|
+
const logFile = pathJoin(process.cwd(), outputFile);
|
|
115
115
|
writeFileSync(logFile, formatLog);
|
|
116
116
|
spinner.succeed("Git change log complete!");
|
|
117
117
|
return 0;
|
|
@@ -125,4 +125,4 @@ ${cliName} Error: ${error.message}`, "error", quiet);
|
|
|
125
125
|
export {
|
|
126
126
|
createChangelog
|
|
127
127
|
};
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/create/changelog.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 {writeFileSync} from 'fs';\nimport capitalize from 'lodash/capitalize.js';\nimport isEmpty from 'lodash/isEmpty.js';\nimport merge from 'lodash/merge.js';\nimport {DateTime} from 'luxon';\nimport path from 'path';\n\nimport {createSpinner} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const createChangelog = async ({cliName, config, outputFile = 'changelog.tmp.md', quiet}): Promise<number> => {\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Configure git cli options\n  const gitOptions: string[] = [\n    'log',\n    '-3',\n    '--pretty=format:{\"authorName\": \"%an\", \"authorEmail\": \"%ae\", \"hashShort\": \"%h\", \"hashFull\": \"%H\", \"tag\": \"%D\", \"date\": %ct, \"subject\": \"%s\",\"comments\": \"%b\"}[lex_break]'\n  ];\n\n  // Run git\n  try {\n    const git = await execa('git', gitOptions, {encoding: 'utf-8'});\n\n    const {stdout} = git;\n    const entries: string[] = stdout.split('[lex_break]').filter((item) => !!item);\n    const gitJson = JSON.parse(\n      (`[${entries.join(',')}]`).replace(/\"[^\"]*(?:\"\"[^\"]*)*\"/g, (match) => match.replace(/\\n/g, '[lex_break]'))\n    );\n    const commitContent = {};\n    let version: string = 'Unreleased';\n\n    gitJson.forEach((item) => {\n      const {comments, authorEmail, authorName, date, hashFull, hashShort, tag} = item;\n      const formatDate: string = DateTime.fromMillis(date).toFormat('DDD');\n\n      if(!isEmpty(tag)) {\n        const refs = tag.split(', ');\n        const updatedVersion: string = refs.reduce((ref: string, tagItem: string) => {\n          let updatedRef: string = ref;\n\n          if(updatedRef === '' && tagItem.includes('tag: v')) {\n            updatedRef = tagItem.replace('tag: v', '').trim();\n          }\n\n          return updatedRef;\n        }, '');\n\n        if(!isEmpty(updatedVersion)) {\n          version = updatedVersion;\n          commitContent[version] = {date: formatDate, version: updatedVersion};\n        }\n      }\n\n      if(!commitContent[version]) {\n        commitContent[version] = {list: {}};\n      }\n\n      const subjectLines: string[] = comments.split('[lex_break]');\n      const topics = {};\n\n      // eslint-disable-next-line no-plusplus\n      for(let idx: number = 0, len: number = subjectLines.length; idx < len; idx++) {\n        const nextLine: string = subjectLines[idx];\n        const formatLine: string = nextLine.trim();\n        const headerPattern: RegExp = /^(\\w*)(?:\\(([\\w\\$\\.\\-\\* ]*)\\))?\\: (.*)$/;\n        const matches = formatLine.match(headerPattern);\n\n        if(matches) {\n          const itemType: string = capitalize(matches[1]);\n          const itemScope: string = matches[2];\n          const itemDetails: string = matches[3];\n          const details = {\n            authorEmail,\n            authorName,\n            details: itemDetails,\n            hashFull,\n            hashShort,\n            type: itemType\n          };\n\n          if(!topics[itemScope]) {\n            topics[itemScope] = {[itemType]: [details]};\n          } else {\n            topics[itemScope][itemType].push(details);\n          }\n        }\n      }\n\n      commitContent[version] = merge(commitContent[version], {list: topics});\n    });\n\n    const formatLog: string = Object.keys(commitContent).reduce((content: string, versionKey: string) => {\n      const {date, list = {}, version} = commitContent[versionKey];\n      const formatScopes: string[] = Object.keys(list);\n      let updatedContent: string = content;\n\n      const versionLabel: string = version ? version : 'Unreleased';\n      const headerLabels: string[] = [versionLabel];\n      if(date) {\n        headerLabels.push(`(${date})`);\n      }\n\n      updatedContent += `\\n## ${headerLabels.join(' ')}\\n`;\n\n      formatScopes.forEach((scopeName: string) => {\n        updatedContent += `\\n### ${scopeName}\\n\\n`;\n\n        // Get the topic name\n        const itemList = list[scopeName];\n        const itemNames: string[] = Object.keys(itemList);\n\n        itemNames.forEach((itemName: string) => {\n          updatedContent += `* ${itemName}\\n`;\n\n          itemList[itemName].forEach((changes) => {\n            const {authorEmail, authorName, details, hashFull, hashShort} = changes;\n            const {gitUrl} = config;\n            let hash: string = `#${hashShort}`;\n\n            if(!isEmpty(gitUrl)) {\n              let commitPath: string = 'commits';\n\n              if(gitUrl.includes('github.com')) {\n                commitPath = 'commit';\n              }\n\n              hash = `[#${hashShort}](${gitUrl}/${commitPath}/${hashFull})`;\n            }\n\n            updatedContent += `  * ${details} ([${authorName}](mailto:${authorEmail}) in ${hash})\\n`;\n          });\n        });\n      });\n\n      return updatedContent;\n    }, '# Changes\\n');\n\n    const logFile: string = path.join(process.cwd(), outputFile);\n    writeFileSync(logFile, formatLog);\n    spinner.succeed('Git change log complete!');\n\n    // Kill process\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('Failed generating change log!');\n\n    // Kill process\n    return error.status;\n  }\n};\n"],
  "mappings": "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",
  "names": ["version"]
}

|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/create/changelog.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 {writeFileSync} from 'fs';\nimport capitalize from 'lodash/capitalize.js';\nimport isEmpty from 'lodash/isEmpty.js';\nimport merge from 'lodash/merge.js';\nimport {DateTime} from 'luxon';\nimport {join as pathJoin} from 'path';\n\nimport {createSpinner} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const createChangelog = async ({cliName, config, outputFile = 'changelog.tmp.md', quiet}): Promise<number> => {\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Configure git cli options\n  const gitOptions: string[] = [\n    'log',\n    '-3',\n    '--pretty=format:{\"authorName\": \"%an\", \"authorEmail\": \"%ae\", \"hashShort\": \"%h\", \"hashFull\": \"%H\", \"tag\": \"%D\", \"date\": %ct, \"subject\": \"%s\",\"comments\": \"%b\"}[lex_break]'\n  ];\n\n  // Run git\n  try {\n    const git = await execa('git', gitOptions, {encoding: 'utf-8'});\n\n    const {stdout} = git;\n    const entries: string[] = stdout.split('[lex_break]').filter((item) => !!item);\n    const gitJson = JSON.parse(\n      (`[${entries.join(',')}]`).replace(/\"[^\"]*(?:\"\"[^\"]*)*\"/g, (match) => match.replace(/\\n/g, '[lex_break]'))\n    );\n    const commitContent = {};\n    let version: string = 'Unreleased';\n\n    gitJson.forEach((item) => {\n      const {comments, authorEmail, authorName, date, hashFull, hashShort, tag} = item;\n      const formatDate: string = DateTime.fromMillis(date).toFormat('DDD');\n\n      if(!isEmpty(tag)) {\n        const refs = tag.split(', ');\n        const updatedVersion: string = refs.reduce((ref: string, tagItem: string) => {\n          let updatedRef: string = ref;\n\n          if(updatedRef === '' && tagItem.includes('tag: v')) {\n            updatedRef = tagItem.replace('tag: v', '').trim();\n          }\n\n          return updatedRef;\n        }, '');\n\n        if(!isEmpty(updatedVersion)) {\n          version = updatedVersion;\n          commitContent[version] = {date: formatDate, version: updatedVersion};\n        }\n      }\n\n      if(!commitContent[version]) {\n        commitContent[version] = {list: {}};\n      }\n\n      const subjectLines: string[] = comments.split('[lex_break]');\n      const topics = {};\n\n      // eslint-disable-next-line no-plusplus\n      for(let idx: number = 0, len: number = subjectLines.length; idx < len; idx++) {\n        const nextLine: string = subjectLines[idx];\n        const formatLine: string = nextLine.trim();\n        const headerPattern: RegExp = /^(\\w*)(?:\\(([\\w\\$\\.\\-\\* ]*)\\))?\\: (.*)$/;\n        const matches = formatLine.match(headerPattern);\n\n        if(matches) {\n          const itemType: string = capitalize(matches[1]);\n          const itemScope: string = matches[2];\n          const itemDetails: string = matches[3];\n          const details = {\n            authorEmail,\n            authorName,\n            details: itemDetails,\n            hashFull,\n            hashShort,\n            type: itemType\n          };\n\n          if(!topics[itemScope]) {\n            topics[itemScope] = {[itemType]: [details]};\n          } else {\n            topics[itemScope][itemType].push(details);\n          }\n        }\n      }\n\n      commitContent[version] = merge(commitContent[version], {list: topics});\n    });\n\n    const formatLog: string = Object.keys(commitContent).reduce((content: string, versionKey: string) => {\n      const {date, list = {}, version} = commitContent[versionKey];\n      const formatScopes: string[] = Object.keys(list);\n      let updatedContent: string = content;\n\n      const versionLabel: string = version ? version : 'Unreleased';\n      const headerLabels: string[] = [versionLabel];\n      if(date) {\n        headerLabels.push(`(${date})`);\n      }\n\n      updatedContent += `\\n## ${headerLabels.join(' ')}\\n`;\n\n      formatScopes.forEach((scopeName: string) => {\n        updatedContent += `\\n### ${scopeName}\\n\\n`;\n\n        // Get the topic name\n        const itemList = list[scopeName];\n        const itemNames: string[] = Object.keys(itemList);\n\n        itemNames.forEach((itemName: string) => {\n          updatedContent += `* ${itemName}\\n`;\n\n          itemList[itemName].forEach((changes) => {\n            const {authorEmail, authorName, details, hashFull, hashShort} = changes;\n            const {gitUrl} = config;\n            let hash: string = `#${hashShort}`;\n\n            if(!isEmpty(gitUrl)) {\n              let commitPath: string = 'commits';\n\n              if(gitUrl.includes('github.com')) {\n                commitPath = 'commit';\n              }\n\n              hash = `[#${hashShort}](${gitUrl}/${commitPath}/${hashFull})`;\n            }\n\n            updatedContent += `  * ${details} ([${authorName}](mailto:${authorEmail}) in ${hash})\\n`;\n          });\n        });\n      });\n\n      return updatedContent;\n    }, '# Changes\\n');\n\n    const logFile: string = pathJoin(process.cwd(), outputFile);\n    writeFileSync(logFile, formatLog);\n    spinner.succeed('Git change log complete!');\n\n    // Kill process\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('Failed generating change log!');\n\n    // Kill process\n    return error.status;\n  }\n};\n"],
  "mappings": "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",
  "names": ["version"]
}

|