New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

cli-kit

Package Overview
Dependencies
Maintainers
1
Versions
107
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

cli-kit - npm Package Compare versions

Comparing version 1.12.0 to 1.13.0

11

CHANGELOG.md

@@ -0,1 +1,12 @@

# 1.13.0 (Apr 26, 2021)
* feat(help): Added required options to usage on help screen.
* feat(ansi): Added `trim()`, `trimStart()`, and `trimEnd()` functions.
* fix(help): Pass styles as well as header and footer content when rendering help template on
demand via `help()`.
* fix(cli): Moved `help` parameter from `Command` to `Context` so that `CLI` can render custom
help content.
* build: Improved `watch` task to not hang on a lint or build error.
* chore: Updated dev dependencies.
# 1.12.0 (Apr 15, 2021)

@@ -2,0 +13,0 @@

20

dist/commands/help.js

@@ -33,6 +33,10 @@ "use strict";

async function renderHelp(ctx, opts) {
async function renderHelp(ctx, opts = {}) {
const file = ctx.get('helpTemplateFile', _path.default.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));
log(`Rendering help template: ${highlight(file)}`);
return (0, _template.renderFile)(file, await ctx.generateHelp(opts));
return (0, _template.renderFile)(file, Object.assign({
style: (opts === null || opts === void 0 ? void 0 : opts.styles) || {},
header: null,
footer: null
}, await ctx.generateHelp(opts))).trim();
}

@@ -156,5 +160,4 @@ /**

const file = ctx.get('helpTemplateFile', _path.default.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));
log(`Rendering help template: ${highlight(file)}`); // determine the output stream
(err ? _stderr : _stdout).write((0, _template.renderFile)(file, {
log(`Rendering help template: ${highlight(file)}`);
const buf = (0, _template.renderFile)(file, {
style: styles,

@@ -164,3 +167,6 @@ header: null,

...help
}));
}).trim(); // determine the output stream
(err ? _stderr : _stdout).write(buf);
(err ? _stderr : _stdout).write('\n');
} // set the exit code

@@ -178,2 +184,2 @@

exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["commands/help.js"],"names":["log","highlight","debug","styles","renderHelp","ctx","opts","file","get","path","resolve","__dirname","generateHelp","clikitHelp","hidden","options","action","_","argv","console","contexts","err","exitCode","parentContextNames","warnings","formatError","message","type","constructor","name","code","json","meta","stack","help","length","unknownCommand","Error","distance","require","suggestions","commands","entries","map","cmd","desc","dist","filter","s","sort","a","b","r","localeCompare","error","Array","isArray","_stdout","_stderr","write","JSON","stringify","style","header","footer"],"mappings":"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","sourcesContent":["import debug from '../lib/debug';\nimport path from 'path';\n\nimport { renderFile } from '../render/template';\n\nconst { log } = debug('cli-kit:help');\nconst { highlight } = debug.styles;\n\n/**\n * Renders help for a specific context, and its parent contexts, to a string. This function is\n * passed into the selected command's `action()` as a property called `help()` so that a command\n * can render its own help output.\n *\n * @param {Context} ctx - The context to render help.\n * @param {Object} [opts] - Various options to pass into `generateHelp()`.\n * @returns {String}\n */\nexport async function renderHelp(ctx, opts) {\n\tconst file = ctx.get('helpTemplateFile', path.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));\n\tlog(`Rendering help template: ${highlight(file)}`);\n\treturn renderFile(file, await ctx.generateHelp(opts));\n}\n\n/**\n * The built-in help command parameters.\n *\n * @type {Object}\n */\nexport default {\n\t/**\n\t * Indicates this command is the built-in cli-kit help command so that if the CLI instance this\n\t * command belongs to gets added to another CLI instance, we don't copy it over.\n\t * @type {Boolean}\n\t */\n\tclikitHelp: true,\n\n\t/**\n\t * While this is a command, we don't want to show it since we already show the `--help` flag.\n\t * @type {Boolean}\n\t */\n\thidden: true,\n\n\t/**\n\t * Output the help as JSON. Neato.\n\t * @type {Object}\n\t */\n\toptions: {\n\t\t'--json': null\n\t},\n\n\t/**\n\t * Executes the help command.\n\t *\n\t * @param {Object} params - Various parameters.\n\t * @param {Object} [params.argv] - The parsed options.\n\t * @param {Array.<Context>} params.contexts - The stack of contexts found during parsing.\n\t * @param {Error} [params.err] - An error object in the event an error occurred.\n\t * @param {Function} params.exitCode - A function that sets the exit code.\n\t * @param {Array.<String>} [params.parentContextNames] - An array of parent context names.\n\t * @param {String} [params.unknownCommand] - The name of the unknown command.\n\t * @param {Array.<Error>} [params.warnings] - A list of warnings (error objects).\n\t * @returns {Promise}\n\t */\n\tasync action({ _ = [], argv = {}, console, contexts, err, exitCode, parentContextNames, styles, warnings } = {}) {\n\t\texitCode(+!!err); // 0=success, 1=error\n\n\t\tconst formatError = err => {\n\t\t\tif (typeof err === 'string') {\n\t\t\t\treturn { message: err };\n\t\t\t}\n\n\t\t\tconst type = err && err.constructor && err.constructor.name || null;\n\t\t\treturn err ? {\n\t\t\t\tcode:    err.code,\n\t\t\t\tmessage: !argv.json && type ? `${type}: ${err.message}` : err.message,\n\t\t\t\tmeta:    err.meta,\n\t\t\t\tstack:   err.stack,\n\t\t\t\ttype\n\t\t\t} : null;\n\t\t};\n\n\t\t// skip the built-in help command and find the first context\n\t\tfor (const ctx of contexts) {\n\t\t\t// we don't display help for the help command\n\t\t\tif (ctx.clikitHelp) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// generate the help object\n\t\t\tconst help = await ctx.generateHelp({ err, parentContextNames, warnings });\n\n\t\t\t// check if we should error if passed an invalid command\n\t\t\tif (!err && _.length && (ctx.get('errorIfUnknownCommand') || argv.help)) {\n\t\t\t\tconst unknownCommand = _[0];\n\t\t\t\terr = new Error(`Unknown command \"${unknownCommand}\"`);\n\n\t\t\t\tconst { distance } = require('fastest-levenshtein');\n\t\t\t\thelp.suggestions = help.commands.entries\n\t\t\t\t\t.map(cmd => ({ name: cmd.name, desc: cmd.desc, dist: distance(unknownCommand, cmd.name) }))\n\t\t\t\t\t.filter(s => s.dist <= 2)\n\t\t\t\t\t.sort((a, b) => {\n\t\t\t\t\t\tconst r = a.dist - b.dist;\n\t\t\t\t\t\treturn r !== 0 ? r : a.name.localeCompare(b.name);\n\t\t\t\t\t});\n\t\t\t}\n\n\t\t\thelp.error = formatError(err);\n\t\t\thelp.warnings = Array.isArray(warnings) ? warnings.map(formatError) : null;\n\n\t\t\tconst { _stdout, _stderr } = console;\n\n\t\t\t// print the help output\n\t\t\tif (argv.json) {\n\t\t\t\t_stdout.write(JSON.stringify(help, null, '  '));\n\t\t\t\t_stdout.write('\\n');\n\t\t\t} else {\n\t\t\t\tconst file = ctx.get('helpTemplateFile', path.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));\n\t\t\t\tlog(`Rendering help template: ${highlight(file)}`);\n\n\t\t\t\t// determine the output stream\n\t\t\t\t(err ? _stderr : _stdout).write(renderFile(file, {\n\t\t\t\t\tstyle: styles,\n\t\t\t\t\theader: null,\n\t\t\t\t\tfooter: null,\n\t\t\t\t\t...help\n\t\t\t\t}));\n\t\t\t}\n\n\t\t\t// set the exit code\n\t\t\texitCode(err ? 1 : ctx.get('helpExitCode'));\n\n\t\t\t// we only loop until we hit the first valid context... generateHelp() will recurse\n\t\t\t// parent contexts for us\n\t\t\tbreak;\n\t\t}\n\t}\n};\n"],"file":"commands/help.js"}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["commands/help.js"],"names":["log","highlight","debug","styles","renderHelp","ctx","opts","file","get","path","resolve","__dirname","Object","assign","style","header","footer","generateHelp","trim","clikitHelp","hidden","options","action","_","argv","console","contexts","err","exitCode","parentContextNames","warnings","formatError","message","type","constructor","name","code","json","meta","stack","help","length","unknownCommand","Error","distance","require","suggestions","commands","entries","map","cmd","desc","dist","filter","s","sort","a","b","r","localeCompare","error","Array","isArray","_stdout","_stderr","write","JSON","stringify","buf"],"mappings":"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","sourcesContent":["import debug from '../lib/debug';\nimport path from 'path';\n\nimport { renderFile } from '../render/template';\n\nconst { log } = debug('cli-kit:help');\nconst { highlight } = debug.styles;\n\n/**\n * Renders help for a specific context, and its parent contexts, to a string. This function is\n * passed into the selected command's `action()` as a property called `help()` so that a command\n * can render its own help output.\n *\n * @param {Context} ctx - The context to render help.\n * @param {Object} [opts] - Various options to pass into `generateHelp()`.\n * @returns {String}\n */\nexport async function renderHelp(ctx, opts = {}) {\n\tconst file = ctx.get('helpTemplateFile', path.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));\n\tlog(`Rendering help template: ${highlight(file)}`);\n\treturn renderFile(file, Object.assign({\n\t\tstyle: opts?.styles || {},\n\t\theader: null,\n\t\tfooter: null\n\t}, await ctx.generateHelp(opts))).trim();\n}\n\n/**\n * The built-in help command parameters.\n *\n * @type {Object}\n */\nexport default {\n\t/**\n\t * Indicates this command is the built-in cli-kit help command so that if the CLI instance this\n\t * command belongs to gets added to another CLI instance, we don't copy it over.\n\t * @type {Boolean}\n\t */\n\tclikitHelp: true,\n\n\t/**\n\t * While this is a command, we don't want to show it since we already show the `--help` flag.\n\t * @type {Boolean}\n\t */\n\thidden: true,\n\n\t/**\n\t * Output the help as JSON. Neato.\n\t * @type {Object}\n\t */\n\toptions: {\n\t\t'--json': null\n\t},\n\n\t/**\n\t * Executes the help command.\n\t *\n\t * @param {Object} params - Various parameters.\n\t * @param {Object} [params.argv] - The parsed options.\n\t * @param {Array.<Context>} params.contexts - The stack of contexts found during parsing.\n\t * @param {Error} [params.err] - An error object in the event an error occurred.\n\t * @param {Function} params.exitCode - A function that sets the exit code.\n\t * @param {Array.<String>} [params.parentContextNames] - An array of parent context names.\n\t * @param {String} [params.unknownCommand] - The name of the unknown command.\n\t * @param {Array.<Error>} [params.warnings] - A list of warnings (error objects).\n\t * @returns {Promise}\n\t */\n\tasync action({ _ = [], argv = {}, console, contexts, err, exitCode, parentContextNames, styles, warnings } = {}) {\n\t\texitCode(+!!err); // 0=success, 1=error\n\n\t\tconst formatError = err => {\n\t\t\tif (typeof err === 'string') {\n\t\t\t\treturn { message: err };\n\t\t\t}\n\n\t\t\tconst type = err && err.constructor && err.constructor.name || null;\n\t\t\treturn err ? {\n\t\t\t\tcode:    err.code,\n\t\t\t\tmessage: !argv.json && type ? `${type}: ${err.message}` : err.message,\n\t\t\t\tmeta:    err.meta,\n\t\t\t\tstack:   err.stack,\n\t\t\t\ttype\n\t\t\t} : null;\n\t\t};\n\n\t\t// skip the built-in help command and find the first context\n\t\tfor (const ctx of contexts) {\n\t\t\t// we don't display help for the help command\n\t\t\tif (ctx.clikitHelp) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// generate the help object\n\t\t\tconst help = await ctx.generateHelp({ err, parentContextNames, warnings });\n\n\t\t\t// check if we should error if passed an invalid command\n\t\t\tif (!err && _.length && (ctx.get('errorIfUnknownCommand') || argv.help)) {\n\t\t\t\tconst unknownCommand = _[0];\n\t\t\t\terr = new Error(`Unknown command \"${unknownCommand}\"`);\n\n\t\t\t\tconst { distance } = require('fastest-levenshtein');\n\t\t\t\thelp.suggestions = help.commands.entries\n\t\t\t\t\t.map(cmd => ({ name: cmd.name, desc: cmd.desc, dist: distance(unknownCommand, cmd.name) }))\n\t\t\t\t\t.filter(s => s.dist <= 2)\n\t\t\t\t\t.sort((a, b) => {\n\t\t\t\t\t\tconst r = a.dist - b.dist;\n\t\t\t\t\t\treturn r !== 0 ? r : a.name.localeCompare(b.name);\n\t\t\t\t\t});\n\t\t\t}\n\n\t\t\thelp.error = formatError(err);\n\t\t\thelp.warnings = Array.isArray(warnings) ? warnings.map(formatError) : null;\n\n\t\t\tconst { _stdout, _stderr } = console;\n\n\t\t\t// print the help output\n\t\t\tif (argv.json) {\n\t\t\t\t_stdout.write(JSON.stringify(help, null, '  '));\n\t\t\t\t_stdout.write('\\n');\n\t\t\t} else {\n\t\t\t\tconst file = ctx.get('helpTemplateFile', path.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));\n\t\t\t\tlog(`Rendering help template: ${highlight(file)}`);\n\n\t\t\t\tconst buf = renderFile(file, {\n\t\t\t\t\tstyle: styles,\n\t\t\t\t\theader: null,\n\t\t\t\t\tfooter: null,\n\t\t\t\t\t...help\n\t\t\t\t}).trim();\n\n\t\t\t\t// determine the output stream\n\t\t\t\t(err ? _stderr : _stdout).write(buf);\n\t\t\t\t(err ? _stderr : _stdout).write('\\n');\n\t\t\t}\n\n\t\t\t// set the exit code\n\t\t\texitCode(err ? 1 : ctx.get('helpExitCode'));\n\n\t\t\t// we only loop until we hit the first valid context... generateHelp() will recurse\n\t\t\t// parent contexts for us\n\t\t\tbreak;\n\t\t}\n\t}\n};\n"],"file":"commands/help.js"}

@@ -11,2 +11,5 @@ "use strict";

exports.toUpperCase = toUpperCase;
exports.trim = trim;
exports.trimStart = trimStart;
exports.trimEnd = trimEnd;
exports.scroll = exports.esc = exports.erase = exports.custom = exports.cursor = exports.clear = exports.bel = void 0;

@@ -197,2 +200,23 @@

}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/ansi.js"],"names":["bel","clear","cursor","show","hide","save","restore","get","home","left","down","n","up","backward","forward","move","dx","dy","s","to","x","y","position","next","repeat","Math","abs","prev","custom","echo","enabled","exec","command","exit","code","keypress","key","re","erase","line","lines","count","screen","toEnd","toStart","esc","scroll","link","text","url","split","str","results","m","push","index","substring","substr","length","stripRegExp","strip","String","replace","toLowerCase","map","i","join","toUpperCase"],"mappings":"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","sourcesContent":["import { encode } from './util';\n\nexport const bel = '\\x07';\n\nexport const clear = '\\x1bc';\n\nexport const cursor = {\n\tshow:    '\\x1b[?25h',\n\thide:    '\\x1b[?25l',\n\tsave:    '\\x1b7',\n\trestore: '\\x1b8',\n\tget:     '\\x1b[6n',\n\thome:    '\\x1b[H',\n\tleft:    '\\x1b[G',\n\n\tdown(n = 1)  { return n ? `\\x1b[${n}B` : ''; },\n\tup(n = 1)    { return n ? `\\x1b[${n}A` : ''; },\n\n\tbackward(n = 1)  { return n ? `\\x1b[${n}D` : ''; },\n\tforward(n = 1) { return n ? `\\x1b[${n}C` : ''; },\n\n\tmove(dx, dy) {\n\t\tlet s = dx ? `\\x1b[${dx > 0 ? `${dx}C` : `${-dx}D`}` : '';\n\t\tif (dy) {\n\t\t\ts += `\\x1b[${dy > 0 ? `${dy}B` : `${-dy}A`}`;\n\t\t}\n\t\treturn s;\n\t},\n\tto(x, y) {\n\t\treturn y ? `\\x1b[${y + 1};${x + 1}H` : `\\x1b[${x + 1}G`;\n\t},\n\n\tposition: /^\\x1b\\[(\\d+);(\\d+)R$/,\n\n\tnext(n = 1) { return !n ? '' : (n < 0 ? '\\x1b[F' : '\\x1b[E').repeat(Math.abs(n)); },\n\tprev(n = 1) { return !n ? '' : (n > 0 ? '\\x1b[F' : '\\x1b[E').repeat(Math.abs(n)); }\n};\n\nexport const custom = {\n\techo(enabled) {\n\t\treturn `\\x1b]666;Echo=${enabled ? 'on' : 'off'}\\x07`;\n\t},\n\texec(command) {\n\t\treturn `\\x1b]666;Exec=${encode(command)}\\x07`;\n\t},\n\texit(code) {\n\t\treturn `\\x1b]666;Exit=${code}\\x07`;\n\t},\n\tkeypress(key) {\n\t\treturn `\\x1b]666;Keypress=${encode(key)}\\x07`;\n\t}\n};\n\ncustom.echo.re = /^\\x1b\\]666;Echo=(\\w+)\\x07$/;\ncustom.exec.re = /^\\x1b\\]666;Exec=(.+)\\x07$/;\ncustom.exit.re = /^\\x1b\\]666;Exit=(\\d+)\\x07$/;\ncustom.keypress.re = /^\\x1b\\]666;Keypress=(.+)\\x07$/;\n\nexport const erase = {\n\tdown:    '\\x1b[J',\n\tline:    '\\x1b[2K',\n\tlines(count = 0) {\n\t\tlet s = '';\n\t\twhile (count > 0) {\n\t\t\ts += this.line + (--count ? cursor.up() : '');\n\t\t}\n\t\treturn s ? `${s}${cursor.left}` : '';\n\t},\n\tscreen:  '\\x1b[2J',\n\ttoEnd:   '\\x1b[K',\n\ttoStart: '\\x1b[1K',\n\tup:      '\\x1b[1J'\n};\n\nexport const esc = '\\x1b[';\n\nexport const scroll = {\n\tdown: '\\x1b[T',\n\tup:   '\\x1b[S'\n};\n\n/**\n * Creates a hyperlink for rendering in a terminal.\n *\n * @param {String} [text] - The clickable text to display.\n * @param {String} url - The link URL.\n * @returns {String}\n */\nexport function link(text, url) {\n\treturn `\\x1b]8;;${url || text}\\x07${text}\\x1b]8;;\\x07`;\n}\n\n/**\n * Splits a string into an array where even number indices are plain strings and odd number\n * indices are ANSI escape sequences.\n *\n * @param {String} str - The string to split.\n * @returns {Array.<String>}\n */\nexport function split(str) {\n\tif (typeof str !== 'string') {\n\t\treturn str;\n\t}\n\n\tconst results = [];\n\tconst re = /\\x07|\\x1b(?:[a-z\\d]|\\[\\?25[hl]|\\[[A-Za-z]|\\[\\d+[A-Za-z]|\\[\\d+;\\d+H|\\]\\d+[^\\x07]+\\x07)/;\n\tlet m;\n\n\twhile (m = re.exec(str)) {\n\t\tresults.push(m.index ? str.substring(0, m.index) : '');\n\t\tresults.push(str.substr(m.index, m[0].length));\n\t\tstr = str.substring(m.index + m[0].length);\n\t}\n\n\tif (str) {\n\t\tresults.push(str);\n\t}\n\n\treturn results;\n}\n\nconst stripRegExp = /\\x1b\\[(;?\\d+)+m/g;\n\n/**\n * Removes all ansi control sequences from the specified string.\n *\n * @param {String} str - The string to strip.\n * @returns {String}\n */\nexport function strip(str = '') {\n\treturn String(str).replace(stripRegExp, '');\n}\n\n/**\n * Converts a string to lower case without tampering with any ANSI escape sequences.\n *\n * @param {String} str - The string to lower case.\n * @returns {String}\n */\nexport function toLowerCase(str) {\n\treturn split(str).map((s, i) => i % 2 === 0 ? s.toLowerCase() : s).join('');\n}\n\n/**\n * Converts a string to upper case without tampering with any ANSI escape sequences.\n *\n * @param {String} str - The string to upper case.\n * @returns {String}\n */\nexport function toUpperCase(str) {\n\treturn split(str).map((s, i) => i % 2 === 0 ? s.toUpperCase() : s).join('');\n}\n"],"file":"lib/ansi.js"}
function trim(str) {
return trimStart(trimEnd(str));
}
function trimStart(str) {
if (str !== undefined && str !== null) {
str = String(str).replace(/^\s*(\x07|\x1b(?:[a-z\d]|\[\?25[hl]|\[[A-Za-z]|\[\d+[A-Za-z]|\[\d+;\d+H|\]\d+[^\x07]+\x07))?\s*/, '$1');
}
return str;
}
function trimEnd(str) {
if (str !== undefined && str !== null) {
// '\u001b[' + b + 'm'
str = String(str).replace(/\s*(\x07|\x1b(?:[a-z\d]|\[\?25[hl]|\[[A-Za-z]|\[\d+[A-Za-z]|\[\d+;\d+H|\]\d+[^\x07]+\x07))?\s*$/, '$1');
}
return str;
}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/ansi.js"],"names":["bel","clear","cursor","show","hide","save","restore","get","home","left","down","n","up","backward","forward","move","dx","dy","s","to","x","y","position","next","repeat","Math","abs","prev","custom","echo","enabled","exec","command","exit","code","keypress","key","re","erase","line","lines","count","screen","toEnd","toStart","esc","scroll","link","text","url","split","str","results","m","push","index","substring","substr","length","stripRegExp","strip","String","replace","toLowerCase","map","i","join","toUpperCase","trim","trimStart","trimEnd","undefined"],"mappings":"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","sourcesContent":["import { encode } from './util';\n\nexport const bel = '\\x07';\n\nexport const clear = '\\x1bc';\n\nexport const cursor = {\n\tshow:    '\\x1b[?25h',\n\thide:    '\\x1b[?25l',\n\tsave:    '\\x1b7',\n\trestore: '\\x1b8',\n\tget:     '\\x1b[6n',\n\thome:    '\\x1b[H',\n\tleft:    '\\x1b[G',\n\n\tdown(n = 1)  { return n ? `\\x1b[${n}B` : ''; },\n\tup(n = 1)    { return n ? `\\x1b[${n}A` : ''; },\n\n\tbackward(n = 1)  { return n ? `\\x1b[${n}D` : ''; },\n\tforward(n = 1) { return n ? `\\x1b[${n}C` : ''; },\n\n\tmove(dx, dy) {\n\t\tlet s = dx ? `\\x1b[${dx > 0 ? `${dx}C` : `${-dx}D`}` : '';\n\t\tif (dy) {\n\t\t\ts += `\\x1b[${dy > 0 ? `${dy}B` : `${-dy}A`}`;\n\t\t}\n\t\treturn s;\n\t},\n\tto(x, y) {\n\t\treturn y ? `\\x1b[${y + 1};${x + 1}H` : `\\x1b[${x + 1}G`;\n\t},\n\n\tposition: /^\\x1b\\[(\\d+);(\\d+)R$/,\n\n\tnext(n = 1) { return !n ? '' : (n < 0 ? '\\x1b[F' : '\\x1b[E').repeat(Math.abs(n)); },\n\tprev(n = 1) { return !n ? '' : (n > 0 ? '\\x1b[F' : '\\x1b[E').repeat(Math.abs(n)); }\n};\n\nexport const custom = {\n\techo(enabled) {\n\t\treturn `\\x1b]666;Echo=${enabled ? 'on' : 'off'}\\x07`;\n\t},\n\texec(command) {\n\t\treturn `\\x1b]666;Exec=${encode(command)}\\x07`;\n\t},\n\texit(code) {\n\t\treturn `\\x1b]666;Exit=${code}\\x07`;\n\t},\n\tkeypress(key) {\n\t\treturn `\\x1b]666;Keypress=${encode(key)}\\x07`;\n\t}\n};\n\ncustom.echo.re = /^\\x1b\\]666;Echo=(\\w+)\\x07$/;\ncustom.exec.re = /^\\x1b\\]666;Exec=(.+)\\x07$/;\ncustom.exit.re = /^\\x1b\\]666;Exit=(\\d+)\\x07$/;\ncustom.keypress.re = /^\\x1b\\]666;Keypress=(.+)\\x07$/;\n\nexport const erase = {\n\tdown:    '\\x1b[J',\n\tline:    '\\x1b[2K',\n\tlines(count = 0) {\n\t\tlet s = '';\n\t\twhile (count > 0) {\n\t\t\ts += this.line + (--count ? cursor.up() : '');\n\t\t}\n\t\treturn s ? `${s}${cursor.left}` : '';\n\t},\n\tscreen:  '\\x1b[2J',\n\ttoEnd:   '\\x1b[K',\n\ttoStart: '\\x1b[1K',\n\tup:      '\\x1b[1J'\n};\n\nexport const esc = '\\x1b[';\n\nexport const scroll = {\n\tdown: '\\x1b[T',\n\tup:   '\\x1b[S'\n};\n\n/**\n * Creates a hyperlink for rendering in a terminal.\n *\n * @param {String} [text] - The clickable text to display.\n * @param {String} url - The link URL.\n * @returns {String}\n */\nexport function link(text, url) {\n\treturn `\\x1b]8;;${url || text}\\x07${text}\\x1b]8;;\\x07`;\n}\n\n/**\n * Splits a string into an array where even number indices are plain strings and odd number\n * indices are ANSI escape sequences.\n *\n * @param {String} str - The string to split.\n * @returns {Array.<String>}\n */\nexport function split(str) {\n\tif (typeof str !== 'string') {\n\t\treturn str;\n\t}\n\n\tconst results = [];\n\tconst re = /\\x07|\\x1b(?:[a-z\\d]|\\[\\?25[hl]|\\[[A-Za-z]|\\[\\d+[A-Za-z]|\\[\\d+;\\d+H|\\]\\d+[^\\x07]+\\x07)/;\n\tlet m;\n\n\twhile (m = re.exec(str)) {\n\t\tresults.push(m.index ? str.substring(0, m.index) : '');\n\t\tresults.push(str.substr(m.index, m[0].length));\n\t\tstr = str.substring(m.index + m[0].length);\n\t}\n\n\tif (str) {\n\t\tresults.push(str);\n\t}\n\n\treturn results;\n}\n\nconst stripRegExp = /\\x1b\\[(;?\\d+)+m/g;\n\n/**\n * Removes all ansi control sequences from the specified string.\n *\n * @param {String} str - The string to strip.\n * @returns {String}\n */\nexport function strip(str = '') {\n\treturn String(str).replace(stripRegExp, '');\n}\n\n/**\n * Converts a string to lower case without tampering with any ANSI escape sequences.\n *\n * @param {String} str - The string to lower case.\n * @returns {String}\n */\nexport function toLowerCase(str) {\n\treturn split(str).map((s, i) => i % 2 === 0 ? s.toLowerCase() : s).join('');\n}\n\n/**\n * Converts a string to upper case without tampering with any ANSI escape sequences.\n *\n * @param {String} str - The string to upper case.\n * @returns {String}\n */\nexport function toUpperCase(str) {\n\treturn split(str).map((s, i) => i % 2 === 0 ? s.toUpperCase() : s).join('');\n}\n\nexport function trim(str) {\n\treturn trimStart(trimEnd(str));\n}\n\nexport function trimStart(str) {\n\tif (str !== undefined && str !== null) {\n\t\tstr = String(str).replace(/^\\s*(\\x07|\\x1b(?:[a-z\\d]|\\[\\?25[hl]|\\[[A-Za-z]|\\[\\d+[A-Za-z]|\\[\\d+;\\d+H|\\]\\d+[^\\x07]+\\x07))?\\s*/, '$1');\n\t}\n\treturn str;\n}\n\nexport function trimEnd(str) {\n\tif (str !== undefined && str !== null) {\n\t\t// '\\u001b[' + b + 'm'\n\t\tstr = String(str).replace(/\\s*(\\x07|\\x1b(?:[a-z\\d]|\\[\\?25[hl]|\\[[A-Za-z]|\\[\\d+[A-Za-z]|\\[\\d+;\\d+H|\\]\\d+[^\\x07]+\\x07))?\\s*$/, '$1');\n\t}\n\treturn str;\n}\n"],"file":"lib/ansi.js"}

@@ -68,7 +68,2 @@ "use strict";

* If value is a `Function`, it simply invokes it.
* @param {String|Function|Object} [params.help] - Additional help content to display on the
* help screen. When may be an object with the properties `header` and `footer` which values
* that are either a string or an async function that resolves a string. When value is a string
* or function, it is trasnformed into a object with the value being used as the header. Note
* that the command description is not displayed when a header message has been defined.
* @param {Boolean} [params.hidden=false] - When `true`, the option is not displayed on the

@@ -353,20 +348,2 @@ * help screen or auto-suggest.

/**
* Renders the help screen for this context including the parent contexts.
*
* @returns {Promise<Object>}
* @access private
*/
generateHelp() {
this.on('generateHelp', async (ctx, results) => {
const opts = {
style: Object.assign({}, _debug.default.styles, this.get('styles'))
};
results.header = typeof this.help.header === 'function' ? await this.help.header.call(this, opts) : this.help.header;
results.footer = typeof this.help.footer === 'function' ? await this.help.footer.call(this, opts) : this.help.footer;
});
return super.generateHelp();
}
/**
* Custom help header and footer content. A string, function, or object with `header` and

@@ -425,2 +402,2 @@ * `footer` properties may be used to set the `help` property, but the internal value will

exports.default = Command;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/command.js"],"names":["log","highlight","debug","styles","formatRegExp","nameRegExp","Command","Context","constructor","name","params","path","isAbsolute","fs","existsSync","ctx","require","Error","__esModule","default","err","E","INVALID_COMMAND","message","scope","value","INVALID_ARGUMENT","format","trim","m","match","action","aliases","Set","alias","split","n","includes","add","Array","isArray","callback","scop","defaultCommand","undefined","clikit","has","title","terminal","parser","get","helpCommand","cmd","commands","call","INVALID_CLIKIT_OBJECT","args","length","lookup","_aliases","createAliases","clikitHelp","help","hidden","key","Object","entries","prototype","hasOwnProperty","values","result","from","assign","a","INVALID_ALIAS","substring","generateHelp","on","results","opts","style","header","footer","_help","schema","desc"],"mappings":"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","sourcesContent":["import Context from './context';\nimport debug from '../lib/debug';\nimport E from '../lib/errors';\nimport fs from 'fs';\nimport helpCommand from '../commands/help';\nimport path from 'path';\n\nimport { declareCLIKitClass } from '../lib/util';\n\nconst { log } = debug('cli-kit:command');\nconst { highlight } = debug.styles;\n\nconst formatRegExp = /^([@! ]*[\\w-_]+(?:\\s*,\\s*[@! ]*[\\w-_]+)*)((?:\\s*[<[][\\w-_]+[>\\]])*)?$/;\nconst nameRegExp = /^([@! ]*)([\\w-_]+)\\s*$/;\n\n/**\n * Defines a command and its options and arguments.\n *\n * @extends {Context}\n */\nexport default class Command extends Context {\n\t/**\n\t * Internal object for tracking aliases.\n\t *\n\t * @type {Object}\n\t * @private\n\t */\n\t_aliases = {};\n\n\t/**\n\t * Custom help header and footer content.\n\t *\n\t * @type {Object}\n\t * @access private\n\t */\n\t_help = {};\n\n\t/**\n\t * Constructs a command instance.\n\t *\n\t * @param {String} name - The command name or absolute path to a file.\n\t * @param {Object|CLI|Command|Context|Function} [params] - Command parameters or an action\n\t * function.\n\t * @param {Function|Command} [params.action] - A function to call when the command is found.\n\t * @param {Set.<String>|Array.<String>|String|Object} [params.aliases] - An array of command\n\t * aliases.\n\t * @param {Function} [params.callback] - A function to call when the command has been parsed.\n\t * @param {String|Function} [params.defaultCommand] - The default command to execute when this\n\t * command has no `action`. When value is a `String`, it looks up the subcommand and calls it.\n\t * If value is a `Function`, it simply invokes it.\n\t * @param {String|Function|Object} [params.help] - Additional help content to display on the\n\t * help screen. When may be an object with the properties `header` and `footer` which values\n\t * that are either a string or an async function that resolves a string. When value is a string\n\t * or function, it is trasnformed into a object with the value being used as the header. Note\n\t * that the command description is not displayed when a header message has been defined.\n\t * @param {Boolean} [params.hidden=false] - When `true`, the option is not displayed on the\n\t * help screen or auto-suggest.\n\t * @access public\n\t *\n\t * @example\n\t *   new Command('foo')\n\t *   new Command('foo', {})\n\t *   new Command(new Command('foo'))\n\t */\n\tconstructor(name, params = {}) {\n\t\tif (name && typeof name === 'string' && path.isAbsolute(name) && fs.existsSync(name)) {\n\t\t\tlet ctx;\n\t\t\ttry {\n\t\t\t\tlog(`Requiring ${highlight(name)}`);\n\t\t\t\tctx = require(name);\n\t\t\t\tif (!ctx || typeof ctx !== 'object') {\n\t\t\t\t\tthrow new Error('Command must export an object');\n\t\t\t\t}\n\n\t\t\t\t// if this is an ES6 module, grab the default export\n\t\t\t\tif (ctx.__esModule) {\n\t\t\t\t\tctx = ctx.default;\n\t\t\t\t}\n\n\t\t\t\tif (!ctx || typeof ctx !== 'object') {\n\t\t\t\t\tthrow new Error('Command must export an object');\n\t\t\t\t}\n\n\t\t\t\tname = ctx.name;\n\t\t\t\tparams = ctx;\n\t\t\t} catch (err) {\n\t\t\t\tthrow E.INVALID_COMMAND(`Bad command \"${name}\": ${err.message}`, { name: name, scope: 'Command.constructor', value: err });\n\t\t\t}\n\t\t}\n\n\t\tif (!name || typeof name !== 'string') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command name to be a non-empty string', { name: 'name', scope: 'Command.constructor', value: name });\n\t\t}\n\n\t\t// parse the name and create the aliases and args: \"ls, list <bar>\"\n\t\tconst format = name.trim();\n\t\tconst m = format.match(formatRegExp);\n\t\tif (!m || !m[1]) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command name to be a non-empty string', { name: 'name', scope: 'Command.constructor', value: name });\n\t\t}\n\n\t\tif (typeof params === 'function') {\n\t\t\tparams = { action: params };\n\t\t}\n\n\t\t// reset the name\n\t\tname = null;\n\n\t\t// get the aliases from the format and find the command name\n\t\tconst aliases = new Set();\n\t\tfor (let alias of m[1].split(',')) {\n\t\t\tconst n = alias.match(nameRegExp);\n\t\t\tif (!n) {\n\t\t\t\tthrow E.INVALID_ARGUMENT('Invalid command alias format', { name: 'alias', scope: 'Command.constructor', value: alias });\n\t\t\t}\n\t\t\tif (!n[1].includes('@') && !name) {\n\t\t\t\tname = n[2];\n\t\t\t} else {\n\t\t\t\taliases.add(n[1].includes('!') ? `!${n[2]}` : n[2]);\n\t\t\t}\n\t\t}\n\n\t\tif (!name) {\n\t\t\tthrow  E.INVALID_ARGUMENT('Expected command name format to contain at least one non-aliased name', { name: 'format', scope: 'Command.constructor', value: format });\n\t\t}\n\n\t\tif (!params || (typeof params !== 'object' || Array.isArray(params))) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command parameters to be an object', { name: 'params', scope: 'Command.constructor', value: params });\n\t\t}\n\n\t\tif (params.callback && typeof params.callback !== 'function') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command callback to be a function', { name: 'callback', scop: 'Command.constructor', value: params.callback });\n\t\t}\n\n\t\tif (params.defaultCommand !== undefined && (!params.defaultCommand || (typeof params.defaultCommand !== 'string' && typeof params.defaultCommand !== 'function'))) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected default command to be a string or function', { name: 'defaultCommand', scope: 'Command.constructor', value: params.defaultCommand });\n\t\t}\n\n\t\tif (params.clikit instanceof Set) {\n\t\t\t// params is a cli-kit object\n\t\t\tif (params.clikit.has('CLI')) {\n\t\t\t\t// since a command cannot have a title \"global\" (only a `CLI` object can have that),\n\t\t\t\t// we must delete it so that the title is reset to the command name\n\t\t\t\tif (params.title === 'Global') {\n\t\t\t\t\tdelete params.title;\n\t\t\t\t}\n\n\t\t\t\tdelete params.terminal;\n\n\t\t\t\t// add an action handler that eitehr executes a specific command or the help for\n\t\t\t\t// for this command (e.g. this command is an extension)\n\t\t\t\tparams.action = async parser => {\n\t\t\t\t\tconst { defaultCommand } = params;\n\t\t\t\t\tif (defaultCommand === 'help' && this.get('help')) {\n\t\t\t\t\t\tawait helpCommand.action(parser);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tconst cmd = defaultCommand && this.commands[defaultCommand];\n\t\t\t\t\t\tif (cmd) {\n\t\t\t\t\t\t\treturn cmd.action.call(cmd, parser);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t} else if (!params.clikit.has('Command')) {\n\t\t\t\t// must be a command or extension\n\t\t\t\tthrow E.INVALID_CLIKIT_OBJECT('Expected command options to be a CLI or Command object', { name: 'clikit', scope: 'Command.constructor', value: params.clikit });\n\t\t\t}\n\t\t}\n\n\t\tif (params.action && typeof params.action !== 'function' && !(params.action instanceof Command)) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command action to be a function or Command instance', { name: 'action', scope: 'Command.constructor', value: params.action });\n\t\t}\n\n\t\tparams.name = name;\n\n\t\tconst args = m[2] && m[2].trim().split(/\\s+/);\n\t\tif (args?.length) {\n\t\t\tparams.args = params.args ? [ ...args, ...params.args ] : args;\n\t\t}\n\n\t\tsuper(params);\n\t\tdeclareCLIKitClass(this, 'Command');\n\n\t\tif (params.action) {\n\t\t\tthis.action = params.action;\n\t\t} else if (typeof params.defaultCommand === 'function') {\n\t\t\tthis.action = params.defaultCommand;\n\t\t} else if (typeof params.defaultCommand === 'string') {\n\t\t\tthis.action = this.lookup.commands[params.defaultCommand];\n\t\t}\n\n\t\t// mix aliases Set with params.aliases\n\t\tthis._aliases       = this.createAliases(aliases, params.aliases);\n\t\tthis.callback       = params.callback;\n\t\tthis.clikitHelp     = params.clikitHelp;\n\t\tthis.help           = params.help || {};\n\t\tthis.defaultCommand = params.defaultCommand;\n\t\tthis.hidden         = !!params.hidden;\n\n\t\t// mix in any other custom props\n\t\tfor (const [ key, value ] of Object.entries(params)) {\n\t\t\tif (!Object.prototype.hasOwnProperty.call(this, key)) {\n\t\t\t\tthis[key] = value;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * A map of aliases an whether they are visible.\n\t *\n\t * @type {Object}\n\t * @access public\n\t */\n\tget aliases() {\n\t\treturn this._aliases;\n\t}\n\n\tset aliases(value) {\n\t\tthis._aliases = this.createAliases(value);\n\t}\n\n\t/**\n\t * Merges multiple alias constructs into a single alias object.\n\t *\n\t * @param {...Set.<String>|Array.<String>|String|Object} values - One or more alias values.\n\t * @returns {Object}\n\t * @access private\n\t */\n\tcreateAliases(...values) {\n\t\tconst result = {};\n\n\t\tfor (let value of values) {\n\t\t\tif (!value) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (value instanceof Set) {\n\t\t\t\tvalue = Array.from(value);\n\t\t\t}\n\n\t\t\tif (typeof value === 'object' && !Array.isArray(value)) {\n\t\t\t\tObject.assign(result, value);\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (!Array.isArray(value)) {\n\t\t\t\tvalue = [ value ];\n\t\t\t}\n\n\t\t\tfor (const alias of value) {\n\t\t\t\tif (!alias || typeof alias !== 'string') {\n\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected command aliases to be an array of strings', { name: 'aliases.alias', scope: 'Command.constructor', value: alias });\n\t\t\t\t}\n\n\t\t\t\tfor (const a of alias.split(/[ ,|]+/)) {\n\t\t\t\t\tif (a === '!') {\n\t\t\t\t\t\tthrow E.INVALID_ALIAS(`Invalid command alias \"${alias}\"`, { name: 'aliases', scope: 'Command.constructor', value: alias });\n\t\t\t\t\t}\n\t\t\t\t\tif (a[0] === '!') {\n\t\t\t\t\t\tresult[a.substring(1)] = 'hidden';\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult[a] = 'visible';\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn result;\n\t}\n\n\t/**\n\t * Renders the help screen for this context including the parent contexts.\n\t *\n\t * @returns {Promise<Object>}\n\t * @access private\n\t */\n\tgenerateHelp() {\n\t\tthis.on('generateHelp', async (ctx, results) => {\n\t\t\tconst opts = {\n\t\t\t\tstyle: Object.assign({}, debug.styles, this.get('styles'))\n\t\t\t};\n\t\t\tresults.header = typeof this.help.header === 'function' ? await this.help.header.call(this, opts) : this.help.header;\n\t\t\tresults.footer = typeof this.help.footer === 'function' ? await this.help.footer.call(this, opts) : this.help.footer;\n\t\t});\n\n\t\treturn super.generateHelp();\n\t}\n\n\t/**\n\t * Custom help header and footer content. A string, function, or object with `header` and\n\t * `footer` properties may be used to set the `help` property, but the internal value will\n\t * always be an object with `header` and `footer` properties.\n\t *\n\t * @type {Object}\n\t * @access public\n\t */\n\tget help() {\n\t\treturn this._help;\n\t}\n\n\tset help(value) {\n\t\tif (typeof value === 'string' || typeof value === 'function') {\n\t\t\tthis._help.header = value;\n\t\t} else if (typeof value === 'object') {\n\t\t\tif (value.header) {\n\t\t\t\tif (typeof value.header === 'string' || typeof value.header === 'function') {\n\t\t\t\t\tthis._help.header = value.header;\n\t\t\t\t} else {\n\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content header to be a string or function');\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (value.footer) {\n\t\t\t\tif (typeof value.footer === 'string' || typeof value.footer === 'function') {\n\t\t\t\t\tthis._help.footer = value.footer;\n\t\t\t\t} else {\n\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content footer to be a string or function');\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tthis._help = {};\n\t\t}\n\t}\n\n\t/**\n\t * Returns the schema for this command and all child contexts.\n\t *\n\t * @returns {Object}\n\t * @access public\n\t */\n\tschema() {\n\t\treturn {\n\t\t\tdesc: this.desc\n\t\t};\n\t}\n}\n"],"file":"parser/command.js"}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/command.js"],"names":["log","highlight","debug","styles","formatRegExp","nameRegExp","Command","Context","constructor","name","params","path","isAbsolute","fs","existsSync","ctx","require","Error","__esModule","default","err","E","INVALID_COMMAND","message","scope","value","INVALID_ARGUMENT","format","trim","m","match","action","aliases","Set","alias","split","n","includes","add","Array","isArray","callback","scop","defaultCommand","undefined","clikit","has","title","terminal","parser","get","helpCommand","cmd","commands","call","INVALID_CLIKIT_OBJECT","args","length","lookup","_aliases","createAliases","clikitHelp","help","hidden","key","Object","entries","prototype","hasOwnProperty","values","result","from","assign","a","INVALID_ALIAS","substring","_help","header","footer","schema","desc"],"mappings":"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","sourcesContent":["import Context from './context';\nimport debug from '../lib/debug';\nimport E from '../lib/errors';\nimport fs from 'fs';\nimport helpCommand from '../commands/help';\nimport path from 'path';\n\nimport { declareCLIKitClass } from '../lib/util';\n\nconst { log } = debug('cli-kit:command');\nconst { highlight } = debug.styles;\n\nconst formatRegExp = /^([@! ]*[\\w-_]+(?:\\s*,\\s*[@! ]*[\\w-_]+)*)((?:\\s*[<[][\\w-_]+[>\\]])*)?$/;\nconst nameRegExp = /^([@! ]*)([\\w-_]+)\\s*$/;\n\n/**\n * Defines a command and its options and arguments.\n *\n * @extends {Context}\n */\nexport default class Command extends Context {\n\t/**\n\t * Internal object for tracking aliases.\n\t *\n\t * @type {Object}\n\t * @private\n\t */\n\t_aliases = {};\n\n\t/**\n\t * Custom help header and footer content.\n\t *\n\t * @type {Object}\n\t * @access private\n\t */\n\t_help = {};\n\n\t/**\n\t * Constructs a command instance.\n\t *\n\t * @param {String} name - The command name or absolute path to a file.\n\t * @param {Object|CLI|Command|Context|Function} [params] - Command parameters or an action\n\t * function.\n\t * @param {Function|Command} [params.action] - A function to call when the command is found.\n\t * @param {Set.<String>|Array.<String>|String|Object} [params.aliases] - An array of command\n\t * aliases.\n\t * @param {Function} [params.callback] - A function to call when the command has been parsed.\n\t * @param {String|Function} [params.defaultCommand] - The default command to execute when this\n\t * command has no `action`. When value is a `String`, it looks up the subcommand and calls it.\n\t * If value is a `Function`, it simply invokes it.\n\t * @param {Boolean} [params.hidden=false] - When `true`, the option is not displayed on the\n\t * help screen or auto-suggest.\n\t * @access public\n\t *\n\t * @example\n\t *   new Command('foo')\n\t *   new Command('foo', {})\n\t *   new Command(new Command('foo'))\n\t */\n\tconstructor(name, params = {}) {\n\t\tif (name && typeof name === 'string' && path.isAbsolute(name) && fs.existsSync(name)) {\n\t\t\tlet ctx;\n\t\t\ttry {\n\t\t\t\tlog(`Requiring ${highlight(name)}`);\n\t\t\t\tctx = require(name);\n\t\t\t\tif (!ctx || typeof ctx !== 'object') {\n\t\t\t\t\tthrow new Error('Command must export an object');\n\t\t\t\t}\n\n\t\t\t\t// if this is an ES6 module, grab the default export\n\t\t\t\tif (ctx.__esModule) {\n\t\t\t\t\tctx = ctx.default;\n\t\t\t\t}\n\n\t\t\t\tif (!ctx || typeof ctx !== 'object') {\n\t\t\t\t\tthrow new Error('Command must export an object');\n\t\t\t\t}\n\n\t\t\t\tname = ctx.name;\n\t\t\t\tparams = ctx;\n\t\t\t} catch (err) {\n\t\t\t\tthrow E.INVALID_COMMAND(`Bad command \"${name}\": ${err.message}`, { name: name, scope: 'Command.constructor', value: err });\n\t\t\t}\n\t\t}\n\n\t\tif (!name || typeof name !== 'string') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command name to be a non-empty string', { name: 'name', scope: 'Command.constructor', value: name });\n\t\t}\n\n\t\t// parse the name and create the aliases and args: \"ls, list <bar>\"\n\t\tconst format = name.trim();\n\t\tconst m = format.match(formatRegExp);\n\t\tif (!m || !m[1]) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command name to be a non-empty string', { name: 'name', scope: 'Command.constructor', value: name });\n\t\t}\n\n\t\tif (typeof params === 'function') {\n\t\t\tparams = { action: params };\n\t\t}\n\n\t\t// reset the name\n\t\tname = null;\n\n\t\t// get the aliases from the format and find the command name\n\t\tconst aliases = new Set();\n\t\tfor (let alias of m[1].split(',')) {\n\t\t\tconst n = alias.match(nameRegExp);\n\t\t\tif (!n) {\n\t\t\t\tthrow E.INVALID_ARGUMENT('Invalid command alias format', { name: 'alias', scope: 'Command.constructor', value: alias });\n\t\t\t}\n\t\t\tif (!n[1].includes('@') && !name) {\n\t\t\t\tname = n[2];\n\t\t\t} else {\n\t\t\t\taliases.add(n[1].includes('!') ? `!${n[2]}` : n[2]);\n\t\t\t}\n\t\t}\n\n\t\tif (!name) {\n\t\t\tthrow  E.INVALID_ARGUMENT('Expected command name format to contain at least one non-aliased name', { name: 'format', scope: 'Command.constructor', value: format });\n\t\t}\n\n\t\tif (!params || (typeof params !== 'object' || Array.isArray(params))) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command parameters to be an object', { name: 'params', scope: 'Command.constructor', value: params });\n\t\t}\n\n\t\tif (params.callback && typeof params.callback !== 'function') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command callback to be a function', { name: 'callback', scop: 'Command.constructor', value: params.callback });\n\t\t}\n\n\t\tif (params.defaultCommand !== undefined && (!params.defaultCommand || (typeof params.defaultCommand !== 'string' && typeof params.defaultCommand !== 'function'))) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected default command to be a string or function', { name: 'defaultCommand', scope: 'Command.constructor', value: params.defaultCommand });\n\t\t}\n\n\t\tif (params.clikit instanceof Set) {\n\t\t\t// params is a cli-kit object\n\t\t\tif (params.clikit.has('CLI')) {\n\t\t\t\t// since a command cannot have a title \"global\" (only a `CLI` object can have that),\n\t\t\t\t// we must delete it so that the title is reset to the command name\n\t\t\t\tif (params.title === 'Global') {\n\t\t\t\t\tdelete params.title;\n\t\t\t\t}\n\n\t\t\t\tdelete params.terminal;\n\n\t\t\t\t// add an action handler that eitehr executes a specific command or the help for\n\t\t\t\t// for this command (e.g. this command is an extension)\n\t\t\t\tparams.action = async parser => {\n\t\t\t\t\tconst { defaultCommand } = params;\n\t\t\t\t\tif (defaultCommand === 'help' && this.get('help')) {\n\t\t\t\t\t\tawait helpCommand.action(parser);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tconst cmd = defaultCommand && this.commands[defaultCommand];\n\t\t\t\t\t\tif (cmd) {\n\t\t\t\t\t\t\treturn cmd.action.call(cmd, parser);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t} else if (!params.clikit.has('Command')) {\n\t\t\t\t// must be a command or extension\n\t\t\t\tthrow E.INVALID_CLIKIT_OBJECT('Expected command options to be a CLI or Command object', { name: 'clikit', scope: 'Command.constructor', value: params.clikit });\n\t\t\t}\n\t\t}\n\n\t\tif (params.action && typeof params.action !== 'function' && !(params.action instanceof Command)) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected command action to be a function or Command instance', { name: 'action', scope: 'Command.constructor', value: params.action });\n\t\t}\n\n\t\tparams.name = name;\n\n\t\tconst args = m[2] && m[2].trim().split(/\\s+/);\n\t\tif (args?.length) {\n\t\t\tparams.args = params.args ? [ ...args, ...params.args ] : args;\n\t\t}\n\n\t\tsuper(params);\n\t\tdeclareCLIKitClass(this, 'Command');\n\n\t\tif (params.action) {\n\t\t\tthis.action = params.action;\n\t\t} else if (typeof params.defaultCommand === 'function') {\n\t\t\tthis.action = params.defaultCommand;\n\t\t} else if (typeof params.defaultCommand === 'string') {\n\t\t\tthis.action = this.lookup.commands[params.defaultCommand];\n\t\t}\n\n\t\t// mix aliases Set with params.aliases\n\t\tthis._aliases       = this.createAliases(aliases, params.aliases);\n\t\tthis.callback       = params.callback;\n\t\tthis.clikitHelp     = params.clikitHelp;\n\t\tthis.help           = params.help || {};\n\t\tthis.defaultCommand = params.defaultCommand;\n\t\tthis.hidden         = !!params.hidden;\n\n\t\t// mix in any other custom props\n\t\tfor (const [ key, value ] of Object.entries(params)) {\n\t\t\tif (!Object.prototype.hasOwnProperty.call(this, key)) {\n\t\t\t\tthis[key] = value;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * A map of aliases an whether they are visible.\n\t *\n\t * @type {Object}\n\t * @access public\n\t */\n\tget aliases() {\n\t\treturn this._aliases;\n\t}\n\n\tset aliases(value) {\n\t\tthis._aliases = this.createAliases(value);\n\t}\n\n\t/**\n\t * Merges multiple alias constructs into a single alias object.\n\t *\n\t * @param {...Set.<String>|Array.<String>|String|Object} values - One or more alias values.\n\t * @returns {Object}\n\t * @access private\n\t */\n\tcreateAliases(...values) {\n\t\tconst result = {};\n\n\t\tfor (let value of values) {\n\t\t\tif (!value) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (value instanceof Set) {\n\t\t\t\tvalue = Array.from(value);\n\t\t\t}\n\n\t\t\tif (typeof value === 'object' && !Array.isArray(value)) {\n\t\t\t\tObject.assign(result, value);\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (!Array.isArray(value)) {\n\t\t\t\tvalue = [ value ];\n\t\t\t}\n\n\t\t\tfor (const alias of value) {\n\t\t\t\tif (!alias || typeof alias !== 'string') {\n\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected command aliases to be an array of strings', { name: 'aliases.alias', scope: 'Command.constructor', value: alias });\n\t\t\t\t}\n\n\t\t\t\tfor (const a of alias.split(/[ ,|]+/)) {\n\t\t\t\t\tif (a === '!') {\n\t\t\t\t\t\tthrow E.INVALID_ALIAS(`Invalid command alias \"${alias}\"`, { name: 'aliases', scope: 'Command.constructor', value: alias });\n\t\t\t\t\t}\n\t\t\t\t\tif (a[0] === '!') {\n\t\t\t\t\t\tresult[a.substring(1)] = 'hidden';\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult[a] = 'visible';\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn result;\n\t}\n\n\t/**\n\t * Custom help header and footer content. A string, function, or object with `header` and\n\t * `footer` properties may be used to set the `help` property, but the internal value will\n\t * always be an object with `header` and `footer` properties.\n\t *\n\t * @type {Object}\n\t * @access public\n\t */\n\tget help() {\n\t\treturn this._help;\n\t}\n\n\tset help(value) {\n\t\tif (typeof value === 'string' || typeof value === 'function') {\n\t\t\tthis._help.header = value;\n\t\t} else if (typeof value === 'object') {\n\t\t\tif (value.header) {\n\t\t\t\tif (typeof value.header === 'string' || typeof value.header === 'function') {\n\t\t\t\t\tthis._help.header = value.header;\n\t\t\t\t} else {\n\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content header to be a string or function');\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (value.footer) {\n\t\t\t\tif (typeof value.footer === 'string' || typeof value.footer === 'function') {\n\t\t\t\t\tthis._help.footer = value.footer;\n\t\t\t\t} else {\n\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content footer to be a string or function');\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tthis._help = {};\n\t\t}\n\t}\n\n\t/**\n\t * Returns the schema for this command and all child contexts.\n\t *\n\t * @returns {Object}\n\t * @access public\n\t */\n\tschema() {\n\t\treturn {\n\t\t\tdesc: this.desc\n\t\t};\n\t}\n}\n"],"file":"parser/command.js"}

@@ -14,2 +14,4 @@ "use strict";

var _ansi = require("../lib/ansi");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

@@ -137,3 +139,3 @@

fn(data, (str, linebreaks, flags) => {
str = flags !== null && flags !== void 0 && flags.includes('|') ? String(str).replace(/\s*$/g, '') : String(str).trim();
str = flags !== null && flags !== void 0 && flags.includes('|') ? (0, _ansi.trimEnd)(str) : (0, _ansi.trim)(str);

@@ -170,2 +172,2 @@ if (!(flags !== null && flags !== void 0 && flags.includes('?')) || str) {

}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["render/template.js"],"names":["breakRegExp","printRegExp","escapeTildes","str","state","s","i","l","length","unshift","shift","render","template","data","RegExp","e","E","INVALID_NODE_JS","vars","Object","keys","body","join","replace","_","ws","lines","flags","undefined","fn","Function","output","linebreaks","includes","String","trim","repeat","renderFile","file","fs","readFileSync","TEMPLATE_NOT_FOUND","name","scope","value"],"mappings":"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","sourcesContent":["// import debug from '../lib/debug';\nimport E from '../lib/errors';\nimport fs from 'fs';\n\n// const logger = debug('cli-kit:template:in');\n// const { log } = logger;\n// const log2 = logger('out').log;\n\n/**\n * Matches intentional line breaks in multiline strings.\n *\n * @type {RegExp}\n */\nconst breakRegExp = /[ \\t]?\\\\\\n/g;\n\n/**\n * Finds output statements and formats them into print statements.\n *\n * Regex breakdown:\n *   `(?<=^|\\n)([ \\t]*)(>+)`: Find one or more contiguous `>` characters where they are at the\n *                            beginning of template or line. We capture each `>` so that we can\n *                            determine how many line returns to add after the line is printed.\n *   `(\\|\\?|\\?\\||\\||\\?)?`:    Detect modifier flags. These control rendering such as trimming the\n *                            output.\n *   `(.*?)(?:(?<!\\\\)\\n|$)`:  Capture the entire message, including multiline `\\` tokens, up to the\n *                            first line break.\n *   `/gs`:                   Set the `global` and `dot all` flags. `global` will find all matches.\n *                            `dot all` (introduced in ES2018), allows us to capture intentional\n *                            line breaks.\n *\n * @type {RegExp}\n */\nlet printRegExp;\n\n/**\n * Escapes tildes in a string that is to be evaluated as a template literal. It uses a simple state\n * machine to keep track of whether it's in an expression or template literal.\n *\n * @param {String} str - The string to escape.\n * @returns {String}\n */\nexport function escapeTildes(str) {\n\tlet state = [ 0 ];\n\tlet s = '';\n\tfor (let i = 0, l = str.length; i < l; i++) {\n\t\tswitch (state[0]) {\n\t\t\tcase 0: // not in an expression\n\t\t\t\tif ((i === 0 || str[i - 1] !== '\\\\') && str[i] === '$' && str[i + 1] === '{') {\n\t\t\t\t\ts += str[i++]; // $\n\t\t\t\t\ts += str[i];   // {\n\t\t\t\t\tstate.unshift(1);\n\t\t\t\t} else if (str[i] === '`') {\n\t\t\t\t\ts += '\\\\`';\n\t\t\t\t} else {\n\t\t\t\t\ts += str[i];\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 1: // in an expression\n\t\t\t\tif (str[i] === '}') {\n\t\t\t\t\tstate.shift();\n\t\t\t\t} else if (str[i] === '`') {\n\t\t\t\t\tstate.unshift(2);\n\t\t\t\t}\n\t\t\t\ts += str[i];\n\t\t\t\tbreak;\n\n\t\t\tcase 2: // in template literal\n\t\t\t\tif (str[i] === '`') {\n\t\t\t\t\tstate.shift();\n\t\t\t\t}\n\t\t\t\ts += str[i];\n\t\t\t\tbreak;\n\t\t}\n\t}\n\treturn s;\n}\n\n/**\n * Renders a template with the supplied data.\n *\n * @param {String} template - The template to render.\n * @param {Object} [data] - An object to inject into the template.\n * @returns {String}\n */\nexport function render(template, data) {\n\tif (!printRegExp) {\n\t\ttry {\n\t\t\tprintRegExp = new RegExp('(?<=^|\\\\n)([ \\\\t]*)(>+)(\\\\|\\\\?|\\\\?\\\\||\\\\||\\\\?)?(.*?)(?:(?<!\\\\\\\\)\\\\n|$)', 'gs');\n\t\t} catch (e) {\n\t\t\t// istanbul ignore next\n\t\t\tthrow E.INVALID_NODE_JS('Node.js version is too old; must be v8.10 or newer');\n\t\t}\n\t}\n\n\tif (!data || typeof data !== 'object') {\n\t\tdata = {};\n\t}\n\n\t// log(template);\n\t// log(Object.keys(data));\n\n\tconst vars = Object.keys(data);\n\tlet body = (vars.length ? `let { ${vars.join(', ')} } = __data;\\n\\n` : '') +\n\t\ttemplate.replace(printRegExp, (_, ws, lines, flags, str) => {\n\t\t\tstr = str.replace(/\\\\(?!\\n)/g, '\\\\\\\\');\n\t\t\tstr = escapeTildes(str);\n\t\t\tstr = str.replace(breakRegExp, '\\\\n');\n\t\t\treturn `${ws}__print(\\`${str}\\`, ${lines.length - 1}${flags === undefined ? '' : `, '${flags}'`});\\n`;\n\t\t});\n\n\t// log2(body);\n\n\tconst fn = new Function('__data', '__print', body);\n\tlet output = '';\n\n\tfn(data, (str, linebreaks, flags) => {\n\t\tstr = flags?.includes('|') ? String(str).replace(/\\s*$/g, '') : String(str).trim();\n\t\tif (!flags?.includes('?') || str) {\n\t\t\toutput += `${str}${linebreaks ? '\\n'.repeat(linebreaks) : ''}`;\n\t\t}\n\t});\n\n\treturn output.replace(/(\\r\\n|\\r|\\n)+$/g, '\\n');\n}\n\n/**\n * Reads in a template file and renders it.\n *\n * @param {String} file - The path to the template file.\n * @param {Object} [data] - An object to inject into the template.\n * @returns {String}\n */\nexport function renderFile(file, data) {\n\tlet template;\n\n\ttry {\n\t\ttemplate = fs.readFileSync(file, 'utf8');\n\t} catch (e) {\n\t\tthrow E.TEMPLATE_NOT_FOUND(`Unable to find template: ${file}`, { name: 'file', scope: 'template.renderFile', value: file });\n\t}\n\n\treturn render(template, data);\n}\n"],"file":"render/template.js"}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["render/template.js"],"names":["breakRegExp","printRegExp","escapeTildes","str","state","s","i","l","length","unshift","shift","render","template","data","RegExp","e","E","INVALID_NODE_JS","vars","Object","keys","body","join","replace","_","ws","lines","flags","undefined","fn","Function","output","linebreaks","includes","repeat","renderFile","file","fs","readFileSync","TEMPLATE_NOT_FOUND","name","scope","value"],"mappings":"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","sourcesContent":["// import debug from '../lib/debug';\nimport E from '../lib/errors';\nimport fs from 'fs';\nimport { trim, trimEnd } from '../lib/ansi';\n\n// const logger = debug('cli-kit:template:in');\n// const { log } = logger;\n// const log2 = logger('out').log;\n\n/**\n * Matches intentional line breaks in multiline strings.\n *\n * @type {RegExp}\n */\nconst breakRegExp = /[ \\t]?\\\\\\n/g;\n\n/**\n * Finds output statements and formats them into print statements.\n *\n * Regex breakdown:\n *   `(?<=^|\\n)([ \\t]*)(>+)`: Find one or more contiguous `>` characters where they are at the\n *                            beginning of template or line. We capture each `>` so that we can\n *                            determine how many line returns to add after the line is printed.\n *   `(\\|\\?|\\?\\||\\||\\?)?`:    Detect modifier flags. These control rendering such as trimming the\n *                            output.\n *   `(.*?)(?:(?<!\\\\)\\n|$)`:  Capture the entire message, including multiline `\\` tokens, up to the\n *                            first line break.\n *   `/gs`:                   Set the `global` and `dot all` flags. `global` will find all matches.\n *                            `dot all` (introduced in ES2018), allows us to capture intentional\n *                            line breaks.\n *\n * @type {RegExp}\n */\nlet printRegExp;\n\n/**\n * Escapes tildes in a string that is to be evaluated as a template literal. It uses a simple state\n * machine to keep track of whether it's in an expression or template literal.\n *\n * @param {String} str - The string to escape.\n * @returns {String}\n */\nexport function escapeTildes(str) {\n\tlet state = [ 0 ];\n\tlet s = '';\n\tfor (let i = 0, l = str.length; i < l; i++) {\n\t\tswitch (state[0]) {\n\t\t\tcase 0: // not in an expression\n\t\t\t\tif ((i === 0 || str[i - 1] !== '\\\\') && str[i] === '$' && str[i + 1] === '{') {\n\t\t\t\t\ts += str[i++]; // $\n\t\t\t\t\ts += str[i];   // {\n\t\t\t\t\tstate.unshift(1);\n\t\t\t\t} else if (str[i] === '`') {\n\t\t\t\t\ts += '\\\\`';\n\t\t\t\t} else {\n\t\t\t\t\ts += str[i];\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 1: // in an expression\n\t\t\t\tif (str[i] === '}') {\n\t\t\t\t\tstate.shift();\n\t\t\t\t} else if (str[i] === '`') {\n\t\t\t\t\tstate.unshift(2);\n\t\t\t\t}\n\t\t\t\ts += str[i];\n\t\t\t\tbreak;\n\n\t\t\tcase 2: // in template literal\n\t\t\t\tif (str[i] === '`') {\n\t\t\t\t\tstate.shift();\n\t\t\t\t}\n\t\t\t\ts += str[i];\n\t\t\t\tbreak;\n\t\t}\n\t}\n\treturn s;\n}\n\n/**\n * Renders a template with the supplied data.\n *\n * @param {String} template - The template to render.\n * @param {Object} [data] - An object to inject into the template.\n * @returns {String}\n */\nexport function render(template, data) {\n\tif (!printRegExp) {\n\t\ttry {\n\t\t\tprintRegExp = new RegExp('(?<=^|\\\\n)([ \\\\t]*)(>+)(\\\\|\\\\?|\\\\?\\\\||\\\\||\\\\?)?(.*?)(?:(?<!\\\\\\\\)\\\\n|$)', 'gs');\n\t\t} catch (e) {\n\t\t\t// istanbul ignore next\n\t\t\tthrow E.INVALID_NODE_JS('Node.js version is too old; must be v8.10 or newer');\n\t\t}\n\t}\n\n\tif (!data || typeof data !== 'object') {\n\t\tdata = {};\n\t}\n\n\t// log(template);\n\t// log(Object.keys(data));\n\n\tconst vars = Object.keys(data);\n\tlet body = (vars.length ? `let { ${vars.join(', ')} } = __data;\\n\\n` : '') +\n\t\ttemplate.replace(printRegExp, (_, ws, lines, flags, str) => {\n\t\t\tstr = str.replace(/\\\\(?!\\n)/g, '\\\\\\\\');\n\t\t\tstr = escapeTildes(str);\n\t\t\tstr = str.replace(breakRegExp, '\\\\n');\n\t\t\treturn `${ws}__print(\\`${str}\\`, ${lines.length - 1}${flags === undefined ? '' : `, '${flags}'`});\\n`;\n\t\t});\n\n\t// log2(body);\n\n\tconst fn = new Function('__data', '__print', body);\n\tlet output = '';\n\n\tfn(data, (str, linebreaks, flags) => {\n\t\tstr = flags?.includes('|') ? trimEnd(str) : trim(str);\n\t\tif (!flags?.includes('?') || str) {\n\t\t\toutput += `${str}${linebreaks ? '\\n'.repeat(linebreaks) : ''}`;\n\t\t}\n\t});\n\n\treturn output.replace(/(\\r\\n|\\r|\\n)+$/g, '\\n');\n}\n\n/**\n * Reads in a template file and renders it.\n *\n * @param {String} file - The path to the template file.\n * @param {Object} [data] - An object to inject into the template.\n * @returns {String}\n */\nexport function renderFile(file, data) {\n\tlet template;\n\n\ttry {\n\t\ttemplate = fs.readFileSync(file, 'utf8');\n\t} catch (e) {\n\t\tthrow E.TEMPLATE_NOT_FOUND(`Unable to find template: ${file}`, { name: 'file', scope: 'template.renderFile', value: file });\n\t}\n\n\treturn render(template, data);\n}\n"],"file":"render/template.js"}
{
"name": "cli-kit",
"version": "1.12.0",
"version": "1.13.0",
"description": "Everything you need to create awesome command line interfaces",

@@ -53,10 +53,10 @@ "main": "./dist/index.js",

"which": "^2.0.2",
"ws": "^7.4.4"
"ws": "^7.4.5"
},
"devDependencies": {
"@babel/core": "^7.13.15",
"@babel/core": "^7.13.16",
"@babel/plugin-proposal-class-properties": "^7.13.0",
"@babel/plugin-proposal-optional-chaining": "^7.13.12",
"@babel/plugin-transform-modules-commonjs": "^7.13.8",
"@babel/register": "^7.13.14",
"@babel/register": "^7.13.16",
"babel-eslint": "^10.1.0",

@@ -71,6 +71,6 @@ "babel-loader": "^8.2.2",

"esdoc-standard-plugin": "^1.0.0",
"eslint": "^7.24.0",
"eslint": "^7.25.0",
"eslint-plugin-chai-expect": "^2.2.0",
"eslint-plugin-mocha": "^8.1.0",
"eslint-plugin-promise": "^4.3.1",
"eslint-plugin-promise": "^5.1.0",
"eslint-plugin-security": "^1.4.0",

@@ -87,3 +87,3 @@ "gulp": "^4.0.2",

"nyc": "^15.1.0",
"sinon": "^9.2.4",
"sinon": "^10.0.0",
"sinon-chai": "^3.6.0",

@@ -90,0 +90,0 @@ "tmp": "^0.2.1"

@@ -7,5 +7,3 @@ # cli-kit

[![NPM Downloads][downloads-image]][downloads-url]
[![Travis CI Build][travis-image]][travis-url]
[![Appveyor CI Build][appveyor-image]][appveyor-url]
[![Test Coverage][coveralls-image]][coveralls-url]
[![Build][build-image]][build-url]
[![Deps][david-image]][david-url]

@@ -286,8 +284,4 @@ [![Dev Deps][david-dev-image]][david-dev-url]

[downloads-url]: https://npmjs.org/package/cli-kit
[travis-image]: https://travis-ci.org/cb1kenobi/cli-kit.svg?branch=master
[travis-url]: https://travis-ci.org/cb1kenobi/cli-kit
[appveyor-image]: https://ci.appveyor.com/api/projects/status/nhbqpsx6jc10xnjw?svg=true
[appveyor-url]: https://ci.appveyor.com/project/cb1kenobi/cli-kit
[coveralls-image]: https://img.shields.io/coveralls/cb1kenobi/cli-kit/master.svg
[coveralls-url]: https://coveralls.io/r/cb1kenobi/cli-kit
[build-image]: https://github.com/cb1kenobi/cli-kit/actions/workflows/build.yml/badge.svg
[build-url]: https://github.com/cb1kenobi/cli-kit/actions/workflows/build.yml
[david-image]: https://img.shields.io/david/cb1kenobi/cli-kit.svg

@@ -294,0 +288,0 @@ [david-url]: https://david-dm.org/cb1kenobi/cli-kit

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc