Comparing version 1.1.1 to 1.2.0
@@ -0,1 +1,10 @@ | ||
# 1.2.0 (Jun 3, 2020) | ||
* feat(commands): Added syntactic sugar for declaring commands with aliases and arguments. | ||
* feat(help): Added command aliases to the help screen. | ||
* fix(cli): Dynamically resolve 'showHelpOnError'. | ||
* fix(parser): Correctly resolve the parsed argument name in the debug logging. | ||
* style(cli): Capitalized `--version` description. | ||
* chore: Updated dev dependencies. | ||
# 1.1.1 (May 26, 2020) | ||
@@ -2,0 +11,0 @@ |
@@ -72,3 +72,3 @@ "use strict"; | ||
if (typeof cmd !== 'string') { | ||
throw _errors.default.INVALID_ARGUMENT('Command parameters are not allowed when cmd is a string', { | ||
throw _errors.default.INVALID_ARGUMENT('Command parameters are only allowed when command is a string', { | ||
name: 'cmd', | ||
@@ -103,3 +103,3 @@ scope: 'CommandMap.add', | ||
for (let it of commands) { | ||
let cmd = null; | ||
cmd = null; | ||
@@ -145,3 +145,3 @@ if (it instanceof Command) { | ||
if (it.clikit.has('Extension')) { | ||
// extensions not supported here | ||
// actions and extensions not supported here | ||
continue; | ||
@@ -208,3 +208,3 @@ } else if (it.clikit.has('Command')) { | ||
for (const cmd of Array.from(this.keys()).sort()) { | ||
for (const cmd of Array.from(this.keys())) { | ||
const { | ||
@@ -219,5 +219,17 @@ aliases, | ||
if (!hidden && !clikitHelp) { | ||
const labels = [name]; | ||
for (const [alias, display] of Object.entries(aliases)) { | ||
if (display === 'visible') { | ||
labels.push(alias); | ||
} | ||
} | ||
labels.sort((a, b) => { | ||
return a.length === b.length ? a.localeCompare(b) : a.length - b.length; | ||
}); | ||
entries.push({ | ||
name, | ||
desc, | ||
label: labels.join(', '), | ||
aliases: aliases ? Object.keys(aliases) : null | ||
@@ -228,2 +240,3 @@ }); | ||
entries.sort((a, b) => a.label.localeCompare(b.label)); | ||
return { | ||
@@ -238,2 +251,2 @@ count: entries.length, | ||
exports.default = CommandMap; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/command-map.js"],"names":["Command","jsRegExp","CommandMap","Map","constructor","add","cmd","params","E","INVALID_ARGUMENT","name","scope","value","require","default","undefined","action","results","commands","clikit","Set","has","values","Array","isArray","it","path","resolve","stat","fs","statSync","dir","isDirectory","files","readdirSync","m","filename","match","module","join","__esModule","set","push","e","code","FILE_NOT_FOUND","INVALID_COMMAND","from","Object","entries","count","size","generateHelp","keys","sort","aliases","clikitHelp","desc","hidden","get","length"],"mappings":"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","sourcesContent":["import E from '../lib/errors';\nimport fs from 'fs';\nimport path from 'path';\n\nimport { declareCLIKitClass } from '../lib/util';\n\nlet Command;\n\n/**\n * Matches\n *\n * @type {RegExp}\n */\nconst jsRegExp = /^(.+)\\.js$/;\n\n/**\n * Stores a map of `Command` instances that have been registered for a context.\n *\n * @extends {Map}\n */\nexport default class CommandMap extends Map {\n\t/**\n\t * Declares the class name.\n\t *\n\t * @access public\n\t */\n\tconstructor() {\n\t\tsuper();\n\t\tdeclareCLIKitClass(this, 'CommandMap');\n\t}\n\n\t/**\n\t * Adds a command to the map.\n\t *\n\t * @param {Object|String|Command|CommandMap|Array.<Object|String|Command>} cmd - An object used\n\t * for `Command` constructor params, a path to a directory or a `.js` file, a `Command`\n\t * instance, or an array of those types. May also be a `CommandMap` instance. If `cmd` is a\n\t * `String` and `params` is present, then it will treat `cmd` as the command name, not a file\n\t * path.\n\t * @param {Object|Function} [params] - When `cmd` is the command name, then this is the options\n\t * to pass into the `Command` constructor.\n\t * @returns {Array.<Command>}\n\t * @access public\n\t */\n\tadd(cmd, params) {\n\t\tif (!cmd) {\n\t\t\tthrow E.INVALID_ARGUMENT('Invalid command', { name: 'cmd', scope: 'CommandMap.add', value: cmd });\n\t\t}\n\n\t\tif (!Command) {\n\t\t\tCommand = require('./command').default;\n\t\t}\n\n\t\tif (params !== undefined) {\n\t\t\tif (typeof cmd !== 'string') {\n\t\t\t\tthrow E.INVALID_ARGUMENT('Command parameters are not allowed when cmd is a string', { name: 'cmd', scope: 'CommandMap.add', value: { cmd, params } });\n\t\t\t} else if (typeof params === 'function') {\n\t\t\t\tparams = { action: params };\n\t\t\t} else if (typeof params !== 'object') {\n\t\t\t\tthrow E.INVALID_ARGUMENT('Expected command parameters to be an object or function', { name: 'params', scope: 'CommandMap.add', value: { cmd, params } });\n\t\t\t}\n\t\t\tcmd = new Command(cmd, params);\n\t\t}\n\n\t\tconst results = [];\n\t\tconst commands = typeof cmd === 'object' && cmd.clikit instanceof Set && (cmd.clikit.has('CommandList') || cmd.clikit.has('CommandMap')) ?\n\t\t\tcmd.values() :\n\t\t\tArray.isArray(cmd) ? cmd : [ cmd ];\n\n\t\tfor (let it of commands) {\n\t\t\tlet cmd = null;\n\n\t\t\tif (it instanceof Command) {\n\t\t\t\tcmd = it;\n\t\t\t} else if (typeof it === 'string') {\n\t\t\t\t// path\n\t\t\t\tit = path.resolve(it);\n\n\t\t\t\ttry {\n\t\t\t\t\tconst stat = fs.statSync(it);\n\t\t\t\t\tconst dir = stat.isDirectory() ? it : '';\n\t\t\t\t\tconst files = dir ? fs.readdirSync(it) : [ it ];\n\t\t\t\t\tlet m;\n\t\t\t\t\tfor (const filename of files) {\n\t\t\t\t\t\tif (m = filename.match(jsRegExp)) {\n\t\t\t\t\t\t\tconst module = require(path.join(dir, filename));\n\t\t\t\t\t\t\tcmd = new Command(m[1], module.__esModule ? module.default : module);\n\t\t\t\t\t\t\tthis.set(cmd.name, cmd);\n\t\t\t\t\t\t\tresults.push(cmd);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {\n\t\t\t\t\tif (e.code === 'ENOENT') {\n\t\t\t\t\t\tthrow E.FILE_NOT_FOUND(`Command path does not exist: ${it}`, { name: 'command', scope: 'CommandMap.add', value: it });\n\t\t\t\t\t}\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\n\t\t\t\tcontinue;\n\n\t\t\t} else if (it && typeof it === 'object') {\n\t\t\t\t// ctor params or Command-like\n\t\t\t\tif (it.clikit instanceof Set) {\n\t\t\t\t\tif (it.clikit.has('Extension')) {\n\t\t\t\t\t\t// extensions not supported here\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t} else if (it.clikit.has('Command')) {\n\t\t\t\t\t\tcmd = new Command(it.name, it);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthrow E.INVALID_COMMAND(`Invalid command: cli-kit type \"${Array.from(it.clikit)[0]}\" not supported`, { name: 'command', scope: 'CommandMap.add', value: it });\n\t\t\t\t\t}\n\t\t\t\t} else if (it.name && typeof it.name === 'string') {\n\t\t\t\t\t// the object is command ctor params\n\t\t\t\t\tcmd = new Command(it.name, it);\n\t\t\t\t} else {\n\t\t\t\t\t// an object of command names to a path, ctor params, Command object, or Command-like object\n\n\t\t\t\t\tfor (const [ name, value ] of Object.entries(it)) {\n\t\t\t\t\t\tcmd = new Command(name, value);\n\t\t\t\t\t\tthis.set(cmd.name, cmd);\n\t\t\t\t\t\tresults.push(cmd);\n\t\t\t\t\t}\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (cmd instanceof Command) {\n\t\t\t\tthis.set(cmd.name, cmd);\n\t\t\t\tresults.push(cmd);\n\t\t\t} else {\n\t\t\t\tthrow E.INVALID_ARGUMENT(`Invalid command \"${it}\", expected an object`, { name: 'command', scope: 'CommandMap.add', value: it });\n\t\t\t}\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Returns the number of commands.\n\t *\n\t * @returns {Number}\n\t * @access public\n\t */\n\tget count() {\n\t\treturn this.size;\n\t}\n\n\t/**\n\t * Generates an object containing the commands for the help screen.\n\t *\n\t * @returns {Object}\n\t * @access public\n\t */\n\tgenerateHelp() {\n\t\tconst entries = [];\n\n\t\tfor (const cmd of Array.from(this.keys()).sort()) {\n\t\t\tconst { aliases, clikitHelp, desc, hidden, name } = this.get(cmd);\n\t\t\tif (!hidden && !clikitHelp) {\n\t\t\t\tentries.push({\n\t\t\t\t\tname,\n\t\t\t\t\tdesc,\n\t\t\t\t\taliases: aliases ? Object.keys(aliases) : null\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\treturn {\n\t\t\tcount: entries.length,\n\t\t\tentries\n\t\t};\n\t}\n}\n"],"file":"parser/command-map.js"} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/command-map.js"],"names":["Command","jsRegExp","CommandMap","Map","constructor","add","cmd","params","E","INVALID_ARGUMENT","name","scope","value","require","default","undefined","action","results","commands","clikit","Set","has","values","Array","isArray","it","path","resolve","stat","fs","statSync","dir","isDirectory","files","readdirSync","m","filename","match","module","join","__esModule","set","push","e","code","FILE_NOT_FOUND","INVALID_COMMAND","from","Object","entries","count","size","generateHelp","keys","aliases","clikitHelp","desc","hidden","get","labels","alias","display","sort","a","b","length","localeCompare","label"],"mappings":"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","sourcesContent":["import E from '../lib/errors';\nimport fs from 'fs';\nimport path from 'path';\n\nimport { declareCLIKitClass } from '../lib/util';\n\nlet Command;\n\n/**\n * Matches\n *\n * @type {RegExp}\n */\nconst jsRegExp = /^(.+)\\.js$/;\n\n/**\n * Stores a map of `Command` instances that have been registered for a context.\n *\n * @extends {Map}\n */\nexport default class CommandMap extends Map {\n\t/**\n\t * Declares the class name.\n\t *\n\t * @access public\n\t */\n\tconstructor() {\n\t\tsuper();\n\t\tdeclareCLIKitClass(this, 'CommandMap');\n\t}\n\n\t/**\n\t * Adds a command to the map.\n\t *\n\t * @param {Object|String|Command|CommandMap|Array.<Object|String|Command>} cmd - An object used\n\t * for `Command` constructor params, a path to a directory or a `.js` file, a `Command`\n\t * instance, or an array of those types. May also be a `CommandMap` instance. If `cmd` is a\n\t * `String` and `params` is present, then it will treat `cmd` as the command name, not a file\n\t * path.\n\t * @param {Object|Function} [params] - When `cmd` is the command name, then this is the options\n\t * to pass into the `Command` constructor.\n\t * @returns {Array.<Command>}\n\t * @access public\n\t */\n\tadd(cmd, params) {\n\t\tif (!cmd) {\n\t\t\tthrow E.INVALID_ARGUMENT('Invalid command', { name: 'cmd', scope: 'CommandMap.add', value: cmd });\n\t\t}\n\n\t\tif (!Command) {\n\t\t\tCommand = require('./command').default;\n\t\t}\n\n\t\tif (params !== undefined) {\n\t\t\tif (typeof cmd !== 'string') {\n\t\t\t\tthrow E.INVALID_ARGUMENT('Command parameters are only allowed when command is a string', { name: 'cmd', scope: 'CommandMap.add', value: { cmd, params } });\n\t\t\t} else if (typeof params === 'function') {\n\t\t\t\tparams = { action: params };\n\t\t\t} else if (typeof params !== 'object') {\n\t\t\t\tthrow E.INVALID_ARGUMENT('Expected command parameters to be an object or function', { name: 'params', scope: 'CommandMap.add', value: { cmd, params } });\n\t\t\t}\n\t\t\tcmd = new Command(cmd, params);\n\t\t}\n\n\t\tconst results = [];\n\t\tconst commands = typeof cmd === 'object' && cmd.clikit instanceof Set && (cmd.clikit.has('CommandList') || cmd.clikit.has('CommandMap')) ?\n\t\t\tcmd.values() :\n\t\t\tArray.isArray(cmd) ? cmd : [ cmd ];\n\n\t\tfor (let it of commands) {\n\t\t\tcmd = null;\n\n\t\t\tif (it instanceof Command) {\n\t\t\t\tcmd = it;\n\t\t\t} else if (typeof it === 'string') {\n\t\t\t\t// path\n\t\t\t\tit = path.resolve(it);\n\n\t\t\t\ttry {\n\t\t\t\t\tconst stat = fs.statSync(it);\n\t\t\t\t\tconst dir = stat.isDirectory() ? it : '';\n\t\t\t\t\tconst files = dir ? fs.readdirSync(it) : [ it ];\n\t\t\t\t\tlet m;\n\t\t\t\t\tfor (const filename of files) {\n\t\t\t\t\t\tif (m = filename.match(jsRegExp)) {\n\t\t\t\t\t\t\tconst module = require(path.join(dir, filename));\n\t\t\t\t\t\t\tcmd = new Command(m[1], module.__esModule ? module.default : module);\n\t\t\t\t\t\t\tthis.set(cmd.name, cmd);\n\t\t\t\t\t\t\tresults.push(cmd);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {\n\t\t\t\t\tif (e.code === 'ENOENT') {\n\t\t\t\t\t\tthrow E.FILE_NOT_FOUND(`Command path does not exist: ${it}`, { name: 'command', scope: 'CommandMap.add', value: it });\n\t\t\t\t\t}\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\n\t\t\t\tcontinue;\n\n\t\t\t} else if (it && typeof it === 'object') {\n\t\t\t\t// ctor params or Command-like\n\t\t\t\tif (it.clikit instanceof Set) {\n\t\t\t\t\tif (it.clikit.has('Extension')) {\n\t\t\t\t\t\t// actions and extensions not supported here\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t} else if (it.clikit.has('Command')) {\n\t\t\t\t\t\tcmd = new Command(it.name, it);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthrow E.INVALID_COMMAND(`Invalid command: cli-kit type \"${Array.from(it.clikit)[0]}\" not supported`, { name: 'command', scope: 'CommandMap.add', value: it });\n\t\t\t\t\t}\n\t\t\t\t} else if (it.name && typeof it.name === 'string') {\n\t\t\t\t\t// the object is command ctor params\n\t\t\t\t\tcmd = new Command(it.name, it);\n\t\t\t\t} else {\n\t\t\t\t\t// an object of command names to a path, ctor params, Command object, or Command-like object\n\n\t\t\t\t\tfor (const [ name, value ] of Object.entries(it)) {\n\t\t\t\t\t\tcmd = new Command(name, value);\n\t\t\t\t\t\tthis.set(cmd.name, cmd);\n\t\t\t\t\t\tresults.push(cmd);\n\t\t\t\t\t}\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (cmd instanceof Command) {\n\t\t\t\tthis.set(cmd.name, cmd);\n\t\t\t\tresults.push(cmd);\n\t\t\t} else {\n\t\t\t\tthrow E.INVALID_ARGUMENT(`Invalid command \"${it}\", expected an object`, { name: 'command', scope: 'CommandMap.add', value: it });\n\t\t\t}\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Returns the number of commands.\n\t *\n\t * @returns {Number}\n\t * @access public\n\t */\n\tget count() {\n\t\treturn this.size;\n\t}\n\n\t/**\n\t * Generates an object containing the commands for the help screen.\n\t *\n\t * @returns {Object}\n\t * @access public\n\t */\n\tgenerateHelp() {\n\t\tconst entries = [];\n\n\t\tfor (const cmd of Array.from(this.keys())) {\n\t\t\tconst { aliases, clikitHelp, desc, hidden, name } = this.get(cmd);\n\t\t\tif (!hidden && !clikitHelp) {\n\t\t\t\tconst labels = [ name ];\n\t\t\t\tfor (const [ alias, display ] of Object.entries(aliases)) {\n\t\t\t\t\tif (display === 'visible') {\n\t\t\t\t\t\tlabels.push(alias);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tlabels.sort((a, b) => {\n\t\t\t\t\treturn a.length === b.length ? a.localeCompare(b) : a.length - b.length;\n\t\t\t\t});\n\n\t\t\t\tentries.push({\n\t\t\t\t\tname,\n\t\t\t\t\tdesc,\n\t\t\t\t\tlabel: labels.join(', '),\n\t\t\t\t\taliases: aliases ? Object.keys(aliases) : null\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tentries.sort((a, b) => a.label.localeCompare(b.label));\n\n\t\treturn {\n\t\t\tcount: entries.length,\n\t\t\tentries\n\t\t};\n\t}\n}\n"],"file":"parser/command-map.js"} |
@@ -22,2 +22,4 @@ "use strict"; | ||
const formatRegExp = /^([@! ]*[\w-_]+(?:\s*,\s*[@! ]*[\w-_]+)*)((?:\s*[<[][\w-_]+[>\]])*)?$/; | ||
const nameRegExp = /^([@! ]*)([\w-_]+)\s*$/; | ||
/** | ||
@@ -28,2 +30,3 @@ * Defines a command and its options and arguments. | ||
*/ | ||
class Command extends _context.default { | ||
@@ -44,3 +47,4 @@ /** | ||
* @param {Function|Command} [params.action] - A function to call when the command is found. | ||
* @param {Array.<String>|String} [params.aliases] - An array of command aliases. | ||
* @param {Set.<String>|Array.<String>|String|Object} [params.aliases] - An array of command | ||
* aliases. | ||
* @param {String|Function} [params.defaultCommand] - The default command to execute when this | ||
@@ -65,3 +69,3 @@ * command has no `action`. When value is a `String`, it looks up the subcommand and calls it. | ||
if (!name || typeof name !== 'string') { | ||
throw _errors.default.INVALID_ARGUMENT('Expected name to be a non-empty string', { | ||
throw _errors.default.INVALID_ARGUMENT('Expected command name to be a non-empty string', { | ||
name: 'name', | ||
@@ -71,2 +75,14 @@ scope: 'Command.constructor', | ||
}); | ||
} // parse the name and create the aliases and args: "ls, list <bar>" | ||
const format = name.trim(); | ||
const m = format.match(formatRegExp); | ||
if (!m || !m[1]) { | ||
throw _errors.default.INVALID_ARGUMENT('Expected command name to be a non-empty string', { | ||
name: 'name', | ||
scope: 'Command.constructor', | ||
value: name | ||
}); | ||
} | ||
@@ -78,4 +94,35 @@ | ||
}; | ||
} // reset the name | ||
name = null; // get the aliases from the format and find the command name | ||
const aliases = new Set(); | ||
for (let alias of m[1].split(',')) { | ||
const n = alias.match(nameRegExp); | ||
if (!n) { | ||
throw _errors.default.INVALID_ARGUMENT('Invalid command alias format', { | ||
name: 'alias', | ||
scope: 'Command.constructor', | ||
value: alias | ||
}); | ||
} | ||
if (!n[1].includes('@') && !name) { | ||
name = n[2]; | ||
} else { | ||
aliases.add(n[1].includes('!') ? `!${n[2]}` : n[2]); | ||
} | ||
} | ||
if (!name) { | ||
throw _errors.default.INVALID_ARGUMENT('Expected command name format to contain at least one non-aliased name', { | ||
name: 'format', | ||
scope: 'Command.constructor', | ||
value: format | ||
}); | ||
} | ||
if (!params || typeof params !== 'object' || Array.isArray(params)) { | ||
@@ -169,2 +216,8 @@ throw _errors.default.INVALID_ARGUMENT('Expected command parameters to be an object', { | ||
params.name = name; | ||
const args = m[2] && m[2].trim().split(/\s+/); | ||
if (args === null || args === void 0 ? void 0 : args.length) { | ||
params.args = params.args ? [...args, ...params.args] : args; | ||
} | ||
super(params); | ||
@@ -182,5 +235,6 @@ | ||
this.action = this.lookup.commands[params.defaultCommand]; | ||
} | ||
} // mix aliases Set with params.aliases | ||
this.aliases = params.aliases; | ||
this._aliases = this.createAliases(aliases, params.aliases); | ||
this.clikitHelp = params.clikitHelp; | ||
@@ -204,16 +258,47 @@ this.help = help; | ||
set aliases(value) { | ||
this._aliases = this.createAliases(value); | ||
} | ||
/** | ||
* Merges multiple alias constructs into a single alias object. | ||
* | ||
* @param {...Set.<String>|Array.<String>|String|Object} values - One or more alias values. | ||
* @returns {Object} | ||
* @access private | ||
*/ | ||
createAliases(...values) { | ||
const result = {}; | ||
if (value) { | ||
for (let value of values) { | ||
if (!value) { | ||
continue; | ||
} | ||
if (value instanceof Set) { | ||
value = Array.from(value); | ||
} | ||
if (typeof value === 'object' && !Array.isArray(value)) { | ||
Object.assign(result, value); | ||
} else { | ||
if (!Array.isArray(value)) { | ||
value = [value]; | ||
continue; | ||
} | ||
if (!Array.isArray(value)) { | ||
value = [value]; | ||
} | ||
for (const alias of value) { | ||
if (!alias || typeof alias !== 'string') { | ||
throw _errors.default.INVALID_ARGUMENT('Expected command aliases to be an array of strings', { | ||
name: 'aliases.alias', | ||
scope: 'Command.constructor', | ||
value: alias | ||
}); | ||
} | ||
for (const alias of value) { | ||
if (!alias || typeof alias !== 'string') { | ||
throw _errors.default.INVALID_ARGUMENT('Expected command aliases to be an array of strings', { | ||
name: 'aliases.alias', | ||
for (const a of alias.split(/[ ,|]+/)) { | ||
if (a === '!') { | ||
throw _errors.default.INVALID_ALIAS(`Invalid command alias "${alias}"`, { | ||
name: 'aliases', | ||
scope: 'Command.constructor', | ||
@@ -224,16 +309,6 @@ value: alias | ||
for (const a of alias.split(/[ ,|]+/)) { | ||
if (a === '!') { | ||
throw _errors.default.INVALID_ALIAS(`Invalid command alias "${alias}"`, { | ||
name: 'aliases', | ||
scope: 'Command.constructor', | ||
value: alias | ||
}); | ||
} | ||
if (a[0] === '!') { | ||
result[a.substring(1)] = 'hidden'; | ||
} else { | ||
result[a] = 'visible'; | ||
} | ||
if (a[0] === '!') { | ||
result[a.substring(1)] = 'hidden'; | ||
} else { | ||
result[a] = 'visible'; | ||
} | ||
@@ -244,3 +319,3 @@ } | ||
this._aliases = result; | ||
return result; | ||
} | ||
@@ -282,2 +357,2 @@ /** | ||
exports.default = Command; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/command.js"],"names":["Command","Context","constructor","name","params","E","INVALID_ARGUMENT","scope","value","action","Array","isArray","defaultCommand","undefined","clikit","Set","has","title","terminal","parser","get","helpCommand","cmd","commands","INVALID_CLIKIT_OBJECT","help","header","footer","lookup","aliases","clikitHelp","hidden","_aliases","result","Object","assign","alias","a","split","INVALID_ALIAS","substring","generateHelp","on","results","opts","style","debug","styles","call","schema","desc"],"mappings":"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","sourcesContent":["import Context from './context';\nimport debug from '../lib/debug';\nimport E from '../lib/errors';\nimport helpCommand from '../commands/help';\n\nimport { declareCLIKitClass } from '../lib/util';\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 * Constructs a command instance.\n\t *\n\t * @param {String} name - The command name.\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 {Array.<String>|String} [params.aliases] - An array of command aliases.\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') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected 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\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.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(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\tconst help = {};\n\t\tif (params.help) {\n\t\t\tif (typeof params.help === 'string' || typeof params.help === 'function') {\n\t\t\t\thelp.header = params.help;\n\t\t\t} else if (typeof params.help === 'object') {\n\t\t\t\tif (params.help.header) {\n\t\t\t\t\tif (typeof params.help.header === 'string' || typeof params.help.header === 'function') {\n\t\t\t\t\t\thelp.header = params.help.header;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content header to be a string or function');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (params.help.footer) {\n\t\t\t\t\tif (typeof params.help.footer === 'string' || typeof params.help.footer === 'function') {\n\t\t\t\t\t\thelp.footer = params.help.footer;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content footer to be a string or function');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content to be a string, function, or object containing a header or footer');\n\t\t\t}\n\t\t}\n\n\t\tparams.name = name;\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\tthis.aliases        = params.aliases;\n\t\tthis.clikitHelp     = params.clikitHelp;\n\t\tthis.help           = help;\n\t\tthis.defaultCommand = params.defaultCommand;\n\t\tthis.hidden         = !!params.hidden;\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\tconst result = {};\n\t\tif (value) {\n\t\t\tif (typeof value === 'object' && !Array.isArray(value)) {\n\t\t\t\tObject.assign(result, value);\n\t\t\t} else {\n\t\t\t\tif (!Array.isArray(value)) {\n\t\t\t\t\tvalue = [ value ];\n\t\t\t\t}\n\n\t\t\t\tfor (const alias of value) {\n\t\t\t\t\tif (!alias || typeof alias !== 'string') {\n\t\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\t}\n\n\t\t\t\t\tfor (const a of alias.split(/[ ,|]+/)) {\n\t\t\t\t\t\tif (a === '!') {\n\t\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\t}\n\t\t\t\t\t\tif (a[0] === '!') {\n\t\t\t\t\t\t\tresult[a.substring(1)] = 'hidden';\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tresult[a] = 'visible';\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tthis._aliases = 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 results => {\n\t\t\tconst opts = {\n\t\t\t\tstyle: debug.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 * 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":["formatRegExp","nameRegExp","Command","Context","constructor","name","params","E","INVALID_ARGUMENT","scope","value","format","trim","m","match","action","aliases","Set","alias","split","n","includes","add","Array","isArray","defaultCommand","undefined","clikit","has","title","terminal","parser","get","helpCommand","cmd","commands","INVALID_CLIKIT_OBJECT","help","header","footer","args","length","lookup","_aliases","createAliases","clikitHelp","hidden","values","result","from","Object","assign","a","INVALID_ALIAS","substring","generateHelp","on","results","opts","style","debug","styles","call","schema","desc"],"mappings":"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","sourcesContent":["import Context from './context';\nimport debug from '../lib/debug';\nimport E from '../lib/errors';\nimport helpCommand from '../commands/help';\n\nimport { declareCLIKitClass } from '../lib/util';\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 * Constructs a command instance.\n\t *\n\t * @param {String} name - The command name.\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 {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') {\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.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(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\tconst help = {};\n\t\tif (params.help) {\n\t\t\tif (typeof params.help === 'string' || typeof params.help === 'function') {\n\t\t\t\thelp.header = params.help;\n\t\t\t} else if (typeof params.help === 'object') {\n\t\t\t\tif (params.help.header) {\n\t\t\t\t\tif (typeof params.help.header === 'string' || typeof params.help.header === 'function') {\n\t\t\t\t\t\thelp.header = params.help.header;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content header to be a string or function');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (params.help.footer) {\n\t\t\t\t\tif (typeof params.help.footer === 'string' || typeof params.help.footer === 'function') {\n\t\t\t\t\t\thelp.footer = params.help.footer;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content footer to be a string or function');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthrow E.INVALID_ARGUMENT('Expected help content to be a string, function, or object containing a header or footer');\n\t\t\t}\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.clikitHelp     = params.clikitHelp;\n\t\tthis.help           = help;\n\t\tthis.defaultCommand = params.defaultCommand;\n\t\tthis.hidden         = !!params.hidden;\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 results => {\n\t\t\tconst opts = {\n\t\t\t\tstyle: debug.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 * 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"} |
@@ -32,3 +32,4 @@ "use strict"; | ||
const { | ||
highlight | ||
highlight, | ||
note | ||
} = _debug.default.styles; | ||
@@ -119,3 +120,3 @@ /** | ||
for (const cmd of cmds) { | ||
log(`Adding command: ${highlight(cmd.name)}`); | ||
log(`Adding command: ${highlight(cmd.name)} ${note(`(${this.name})`)}`); | ||
this.register(cmd); | ||
@@ -146,3 +147,3 @@ } | ||
for (const ext of exts) { | ||
log(`Adding extension: ${highlight(ext.name)}`); | ||
log(`Adding extension: ${highlight(ext.name)} ${note(`(${this.name})`)}`); | ||
this.register(ext); | ||
@@ -225,3 +226,3 @@ } | ||
results.commands.count += ext.count; | ||
results.commands.entries.push.apply(results.commands.entries, ext.entries); // update the default command | ||
results.commands.entries.push(...ext.entries); // update the default command | ||
@@ -429,3 +430,14 @@ if (this.defaultCommand) { | ||
register(it) { | ||
const dest = it.clikit.has('Extension') ? 'extensions' : 'commands'; | ||
let dest; | ||
if (it.clikit.has('Extension')) { | ||
dest = 'extensions'; | ||
} else if (it.clikit.has('Command')) { | ||
dest = 'commands'; | ||
} | ||
if (!dest) { | ||
return; | ||
} | ||
it.parent = this; | ||
@@ -446,2 +458,2 @@ this.lookup[dest][it.name] = it; | ||
exports.default = Context; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/context.js"],"names":["log","highlight","debug","styles","Context","HookEmitter","constructor","params","init","argument","arg","args","add","rev","command","cmd","cmds","commands","name","register","extension","ext","exts","extensions","generateHelp","opts","hook","results","scopes","ctx","push","title","options","contexts","unshift","parent","longs","Set","shorts","j","length","Object","values","groups","i","long","short","nuke","has","count","splice","desc","String","trim","replace","c","toLocaleUpperCase","entries","apply","defaultCommand","default","arguments","reduce","p","usage","Array","isArray","parentContextNames","slice","map","multiple","required","text","join","error","undefined","suggestions","warnings","get","defaultValue","value","clikit","E","INVALID_ARGUMENT","scope","ArgumentList","autoHideBanner","banner","CommandMap","errorIfUnknownCommand","ExtensionMap","helpExitCode","helpTemplateFile","hideNoBannerOption","hideNoColorOption","lookup","Lookup","nodeVersion","OptionMap","showBannerForExternalCLIs","showHelpOnError","treatUnknownOptionsAsArguments","version","option","format","opt","alias","visible","aliases","prop","it","dest","keys"],"mappings":"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","sourcesContent":["import ArgumentList from './argument-list';\nimport CommandMap from './command-map';\nimport debug from '../lib/debug';\nimport E from '../lib/errors';\nimport ExtensionMap from './extension-map';\nimport HookEmitter from 'hook-emitter';\nimport Lookup from './lookup';\nimport OptionMap from './option-map';\n\nimport { declareCLIKitClass } from '../lib/util';\n\nconst { log } = debug('cli-kit:context');\nconst { highlight } = debug.styles;\n\n/**\n * Defines a context that contains commands, options, and args. Serves as the\n * base class for `CLI` and `Context` objects.\n *\n * @extends {HookEmitter}\n */\nexport default class Context extends HookEmitter {\n\t/**\n\t * Constructs a context instance.\n\t *\n\t * @param {Object|Context} [params] - Various parameters.\n\t * @param {Object|String|Argument|ArgumentList|Array<Object|String|Argument>} [params.args] -\n\t * An object of argument names to argument descriptors, an argument name, an `Argument`\n\t * instance, an `ArgumentList` instance, or array of object descriptors, argument names, and\n\t * `Argument` instances.\n\t * @param {Boolean} [params.camelCase=true] - Camel case option names.\n\t * @param {Object|String|Command|CommandMap|Array.<Object|String|Command>} [params.commands] -\n\t * An object used for `Command` constructor params, a path to a directory or a `.js` file, a\n\t * `Command` instance, or an array of those types. May also be a `CommandMap` instance. If\n\t * `cmd` is a `String` and `params` is present, then it will treat `cmd` as the command name,\n\t * not a file path.\n\t * @param {String} [params.desc] - The description of the CLI or command displayed in the help\n\t * output. If context is a command with a help header defined, this description is not\n\t * displayed.\n\t * @param {Object|String|Extension|ExtensionMap|Array.<String|Extension>} [params.extensions] -\n\t * An object of extension names to extension paths or instances, an extension path, an\n\t * `Extension` instance, or an array of those types. An extension path may be a directory\n\t * containing a Node.js module, a path to a `.js` file, or the name of a executable. May also\n\t * be an `ExtensionMap` instance.\n\t * @param {String} [params.name] - The name of the context such as the program or the command\n\t * name.\n\t * @param {Object|Option|OptionMap|Array<Object|Option|String>} [params.options] - An object of\n\t * format to `Option` constructor params, an `Option` instance, or an array of `Option`\n\t * constructor params and `Option` instances grouped by `String` labels.\n\t * @param {Context} [params.parent] - The parent context.\n\t * @param {String} [params.title] - The context title.\n\t * @param {Boolean} [params.treatUnknownOptionsAsArguments=false] - When `true`, any argument is\n\t * encountered during parsing that resembles a option that does not exist, it will add it\n\t * untouched to `_` as an argument as well as to `argv` as a boolean flag. When `false`, it will\n\t * only add the argument to `argv` as a boolean flag.\n\t * @access public\n\t */\n\tconstructor(params = {}) {\n\t\tsuper();\n\t\tdeclareCLIKitClass(this, 'Context');\n\t\tthis.init(params);\n\t}\n\n\t/**\n\t * Adds an argument to this context.\n\t *\n\t * @param {Object|String|Argument|ArgumentList|Array<Object|String|Argument>} arg - An object\n\t * of argument names to argument descriptors, an argument name, an `Argument` instance, an\n\t * `ArgumentList` instance, or array of object descriptors, argument names, and `Argument`\n\t * instances.\n\t * @returns {Context}\n\t * @access public\n\t */\n\targument(arg) {\n\t\tthis.args.add(arg);\n\t\tthis.rev++;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds a command to this context.\n\t *\n\t * @param {Object|String|Command|CommandMap|Array.<Object|String|Command>} cmd - An object\n\t * used for `Command` constructor params, a path to a directory or a `.js` file, a `Command`\n\t * instance, or an array of those types. May also be a `CommandMap` instance. If `cmd` is a\n\t * `String` and `params` is present, then it will treat `cmd` as the command name, not a file\n\t * path.\n\t * @param {Object} [params] - When `cmd` is the command name, then this is the options to pass\n\t * into the `Command` constructor.\n\t * @returns {Context}\n\t * @access public\n\t */\n\tcommand(cmd, params) {\n\t\tconst cmds = this.commands.add(cmd, params);\n\t\tfor (const cmd of cmds) {\n\t\t\tlog(`Adding command: ${highlight(cmd.name)}`);\n\t\t\tthis.register(cmd);\n\t\t}\n\t\tthis.rev++;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Registers an external package as a command context that invokes the package.\n\t *\n\t * @param {Object|String|Extension|ExtensionMap|Array.<String|Extension>} ext - An object of\n\t * extension names to extension paths or instances, an extension path, an `Extension` instance,\n\t * or an array of those types. An extension path may be a directory containing a Node.js\n\t * module, a path to a `.js` file, or the name of a executable. May also be an `ExtensionMap`\n\t * instance.\n\t * @param {String} [name] - The extension name used for the context name. If not set, it will\n\t * attempt to find a `package.json` with a `cli-kit.name` value.\n\t * @returns {Context}\n\t * @access public\n\t */\n\textension(ext, name) {\n\t\tconst exts = this.extensions.add(ext, name);\n\t\tfor (const ext of exts) {\n\t\t\tlog(`Adding extension: ${highlight(ext.name)}`);\n\t\t\tthis.register(ext);\n\t\t}\n\t\tthis.rev++;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Renders the help screen for this context including the parent contexts.\n\t *\n\t * @param {Object} [opts] - Various parameters.\n\t * @returns {Promise<Object>}\n\t * @access private\n\t */\n\tgenerateHelp(opts = {}) {\n\t\treturn this.hook('generateHelp', results => {\n\t\t\tconst scopes = [];\n\t\t\tlet ctx = this;\n\n\t\t\twhile (ctx) {\n\t\t\t\tscopes.push({\n\t\t\t\t\ttitle: `${ctx.title} options`,\n\t\t\t\t\tname: ctx.name,\n\t\t\t\t\t...ctx.options.generateHelp()\n\t\t\t\t});\n\t\t\t\tresults.contexts.unshift(ctx.name);\n\t\t\t\tctx = ctx.parent;\n\t\t\t}\n\n\t\t\t// remove duplicate options\n\t\t\tconst longs = new Set();\n\t\t\tconst shorts = new Set();\n\t\t\tlet j = scopes.length;\n\t\t\twhile (j--) {\n\t\t\t\tfor (const options of Object.values(scopes[j].groups)) {\n\t\t\t\t\tfor (let i = 0; i < options.length; i++) {\n\t\t\t\t\t\tconst { long, short } = options[i];\n\t\t\t\t\t\tlet nuke = false;\n\t\t\t\t\t\tif (long !== null) {\n\t\t\t\t\t\t\tif (longs.has(long)) {\n\t\t\t\t\t\t\t\tnuke = true;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tlongs.add(long);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (short !== null) {\n\t\t\t\t\t\t\tif (shorts.has(short)) {\n\t\t\t\t\t\t\t\tnuke = true;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tshorts.add(short);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (nuke) {\n\t\t\t\t\t\t\tscopes[j].count--;\n\t\t\t\t\t\t\toptions.splice(i--, 1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// set the description\n\t\t\tresults.desc = this.desc ? String(this.desc).trim().replace(/^\\w/, c => c.toLocaleUpperCase()) : null;\n\n\t\t\t// set the commands\n\t\t\tresults.commands = {\n\t\t\t\ttitle: this.parent ? `${this.title} commands` : 'Commands',\n\t\t\t\t...this.commands.generateHelp()\n\t\t\t};\n\n\t\t\tconst ext = this.extensions.generateHelp();\n\t\t\tresults.commands.count += ext.count;\n\t\t\tresults.commands.entries.push.apply(results.commands.entries, ext.entries);\n\n\t\t\t// update the default command\n\t\t\tif (this.defaultCommand) {\n\t\t\t\tfor (const cmd of results.commands.entries) {\n\t\t\t\t\tif (cmd.name === this.defaultCommand) {\n\t\t\t\t\t\tcmd.default = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// set the arguments\n\t\t\tresults.arguments = {\n\t\t\t\ttitle: this.parent ? `${this.title} arguments` : 'Arguments',\n\t\t\t\t...this.args.generateHelp()\n\t\t\t};\n\n\t\t\t// set the options\n\t\t\tresults.options = {\n\t\t\t\tcount: scopes.reduce((p, c) => p + c.count, 0),\n\t\t\t\tscopes\n\t\t\t};\n\n\t\t\t// set the usage line\n\t\t\tconst usage = [];\n\t\t\tif (Array.isArray(opts.parentContextNames)) {\n\t\t\t\tusage.push.apply(usage, opts.parentContextNames);\n\t\t\t}\n\t\t\tusage.push.apply(usage, results.contexts.slice());\n\t\t\tresults.commands.count && usage.push('<command>');\n\t\t\tresults.options.count && usage.push('[options]');\n\t\t\tusage.push.apply(usage, results.arguments.entries.map(arg => {\n\t\t\t\tconst name = `<${arg.name}${arg.multiple ? '...' : ''}>`;\n\t\t\t\treturn arg.required ? name : `[${name}]`;\n\t\t\t}));\n\t\t\tresults.usage = {\n\t\t\t\ttitle: 'Usage',\n\t\t\t\ttext: usage.join(' ')\n\t\t\t};\n\n\t\t\treturn results;\n\t\t})({\n\t\t\tcontexts: [],\n\t\t\terror: undefined,\n\t\t\tsuggestions: [],\n\t\t\twarnings: undefined\n\t\t});\n\t}\n\n\t/**\n\t * Scan parent contexts to find the specified property in the top-most context.\n\t *\n\t * @param {String} name - The property name.\n\t * @param {*} defaultValue - A default value if no value is found.\n\t * @returns {*}\n\t * @access private\n\t */\n\tget(name, defaultValue) {\n\t\tlet value = this[name];\n\t\tfor (let p = this.parent; p; p = p.parent) {\n\t\t\tvalue = p.get(name, value);\n\t\t}\n\t\treturn value !== undefined ? value : defaultValue;\n\t}\n\n\t/**\n\t * Initializes this context with params.\n\t *\n\t * @param {Object|Context} params - Various parameters\n\t * @access private\n\t */\n\tinit(params) {\n\t\tif (!params || typeof params !== 'object' || (params.clikit instanceof Set && !params.clikit.has('Context'))) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected parameters to be an object or Context', { name: 'params', scope: 'Context.init', value: params });\n\t\t}\n\n\t\tif (params.clikit instanceof Set && !params.clikit.has('Context')) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected parameters to be an object or Context', { name: 'params', scope: 'Context.init', value: params });\n\t\t}\n\n\t\tthis.args                           = new ArgumentList();\n\t\tthis.autoHideBanner                 = params.autoHideBanner;\n\t\tthis.banner                         = params.banner;\n\t\tthis.commands                       = new CommandMap();\n\t\tthis.defaultCommand                 = params.defaultCommand;\n\t\tthis.desc                           = params.desc;\n\t\tthis.errorIfUnknownCommand          = params.errorIfUnknownCommand;\n\t\tthis.extensions                     = new ExtensionMap();\n\t\tthis.helpExitCode                   = params.helpExitCode;\n\t\tthis.helpTemplateFile               = params.helpTemplateFile;\n\t\tthis.hideNoBannerOption             = params.hideNoBannerOption;\n\t\tthis.hideNoColorOption              = params.hideNoColorOption;\n\t\tthis.lookup                         = new Lookup();\n\t\tthis.name                           = params.name;\n\t\tthis.nodeVersion                    = params.nodeVersion;\n\t\tthis.options                        = new OptionMap();\n\t\tthis.parent                         = params.parent;\n\t\tthis.rev                            = 0;\n\t\tthis.showBannerForExternalCLIs      = params.showBannerForExternalCLIs;\n\t\tthis.showHelpOnError                = params.showHelpOnError;\n\t\tthis.title                          = params.title || params.name;\n\t\tthis.treatUnknownOptionsAsArguments = !!params.treatUnknownOptionsAsArguments;\n\t\tthis.version                        = params.version;\n\n\t\tparams.args       && this.argument(params.args);\n\t\tparams.commands   && this.command(params.commands);\n\t\tparams.extensions && this.extension(params.extensions);\n\t\tparams.options    && this.option(params.options);\n\t}\n\n\t/**\n\t * Adds an option to this context.\n\t *\n\t * @param {String|Object|Option|OptionMap|Array<Object|Option|String>} format - An option\n\t * format, an object of format to option descriptions, `Option` constructor params or `Option`\n\t * instances, an `Option` instance, an `OptionMap` instance, or an array of `Option`\n\t * constructor params and `Option` instances grouped by `String` labels.\n\t * @param {Object|Option|String} [params] - When `format` is a format string, then this\n\t * argument is either `Option` constructor parameters, an `Option` instance, or an option\n\t * description.\n\t * @returns {Context}\n\t * @access public\n\t *\n\t * @example\n\t *   ctx.option('--foo'); // format flag\n\t *   ctx.option('--foo', 'enables foo mode'); // format with description\n\t *   ctx.option('--foo', { desc: 'enables foo mode' }); // format with Option ctor params\n\t *   ctx.option({ '--foo': null }); // object with format flag\n\t *   ctx.option({ '--foo': { desc: 'enables foo mode' } }); // object with Option ctor params\n\t *   ctx.option({ '--foo': new Option() }); // object of `Option` instance\n\t *   ctx.option(new Option('--foo')); // `Option` instance\n\t *   ctx.option(new OptionMap()); // `OptionMap` from another instance\n\t *   ctx.option([ 'Some Group', new Option('--foo'), 'Another Group', { '--bar': null } ]); // an array of grouped options\n\t */\n\toption(format, params) {\n\t\tconst opts = this.options.add(format, params);\n\n\t\tfor (const opt of opts) {\n\t\t\topt.parent = this;\n\n\t\t\tif (opt.long) {\n\t\t\t\tthis.lookup.long[opt.long] = opt;\n\t\t\t}\n\n\t\t\tif (opt.short) {\n\t\t\t\tthis.lookup.short[opt.short] = opt;\n\t\t\t}\n\n\t\t\tfor (const [ alias, visible ] of Object.entries(opt.aliases.long)) {\n\t\t\t\tif (visible) {\n\t\t\t\t\tthis.lookup.long[alias] = opt;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor (const [ alias, visible ] of Object.entries(opt.aliases.short)) {\n\t\t\t\tif (visible) {\n\t\t\t\t\tthis.lookup.short[alias] = opt;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.rev++;\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Scan parent contexts to find the specified property in the bottom-most context.\n\t *\n\t * @param {String} name - The property name.\n\t * @param {*} defaultValue - A default value if no value is found.\n\t * @returns {*}\n\t * @access private\n\t */\n\tprop(name, defaultValue) {\n\t\tlet value = this[name];\n\t\tfor (let p = this.parent; value === undefined && p; p = p.parent) {\n\t\t\tvalue = p.prop(name, value);\n\t\t}\n\t\treturn value !== undefined ? value : defaultValue;\n\t}\n\n\t/**\n\t * Registers a command or extension to add to the lookup.\n\t *\n\t * @param {Command|Extension} it - The command or extension instance.\n\t * @access private\n\t */\n\tregister(it) {\n\t\tconst dest = it.clikit.has('Extension') ? 'extensions' : 'commands';\n\t\tit.parent = this;\n\t\tthis.lookup[dest][it.name] = it;\n\n\t\tif (it.aliases) {\n\t\t\tfor (const alias of Object.keys(it.aliases)) {\n\t\t\t\tif (!this[dest].has(alias)) {\n\t\t\t\t\tthis.lookup[dest][alias] = it;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n"],"file":"parser/context.js"} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/context.js"],"names":["log","highlight","note","debug","styles","Context","HookEmitter","constructor","params","init","argument","arg","args","add","rev","command","cmd","cmds","commands","name","register","extension","ext","exts","extensions","generateHelp","opts","hook","results","scopes","ctx","push","title","options","contexts","unshift","parent","longs","Set","shorts","j","length","Object","values","groups","i","long","short","nuke","has","count","splice","desc","String","trim","replace","c","toLocaleUpperCase","entries","defaultCommand","default","arguments","reduce","p","usage","Array","isArray","parentContextNames","apply","slice","map","multiple","required","text","join","error","undefined","suggestions","warnings","get","defaultValue","value","clikit","E","INVALID_ARGUMENT","scope","ArgumentList","autoHideBanner","banner","CommandMap","errorIfUnknownCommand","ExtensionMap","helpExitCode","helpTemplateFile","hideNoBannerOption","hideNoColorOption","lookup","Lookup","nodeVersion","OptionMap","showBannerForExternalCLIs","showHelpOnError","treatUnknownOptionsAsArguments","version","option","format","opt","alias","visible","aliases","prop","it","dest","keys"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;AAEA,MAAM;AAAEA,EAAAA;AAAF,IAAU,oBAAM,iBAAN,CAAhB;AACA,MAAM;AAAEC,EAAAA,SAAF;AAAaC,EAAAA;AAAb,IAAsBC,eAAMC,MAAlC;AAEA;;;;;;;AAMe,MAAMC,OAAN,SAAsBC,oBAAtB,CAAkC;AAChD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmCAC,EAAAA,WAAW,CAACC,MAAM,GAAG,EAAV,EAAc;AACxB;AACA,kCAAmB,IAAnB,EAAyB,SAAzB;AACA,SAAKC,IAAL,CAAUD,MAAV;AACA;AAED;;;;;;;;;;;;AAUAE,EAAAA,QAAQ,CAACC,GAAD,EAAM;AACb,SAAKC,IAAL,CAAUC,GAAV,CAAcF,GAAd;AACA,SAAKG,GAAL;AACA,WAAO,IAAP;AACA;AAED;;;;;;;;;;;;;;;AAaAC,EAAAA,OAAO,CAACC,GAAD,EAAMR,MAAN,EAAc;AACpB,UAAMS,IAAI,GAAG,KAAKC,QAAL,CAAcL,GAAd,CAAkBG,GAAlB,EAAuBR,MAAvB,CAAb;;AACA,SAAK,MAAMQ,GAAX,IAAkBC,IAAlB,EAAwB;AACvBjB,MAAAA,GAAG,CAAE,mBAAkBC,SAAS,CAACe,GAAG,CAACG,IAAL,CAAW,IAAGjB,IAAI,CAAE,IAAG,KAAKiB,IAAK,GAAf,CAAmB,EAAlE,CAAH;AACA,WAAKC,QAAL,CAAcJ,GAAd;AACA;;AACD,SAAKF,GAAL;AACA,WAAO,IAAP;AACA;AAED;;;;;;;;;;;;;;;AAaAO,EAAAA,SAAS,CAACC,GAAD,EAAMH,IAAN,EAAY;AACpB,UAAMI,IAAI,GAAG,KAAKC,UAAL,CAAgBX,GAAhB,CAAoBS,GAApB,EAAyBH,IAAzB,CAAb;;AACA,SAAK,MAAMG,GAAX,IAAkBC,IAAlB,EAAwB;AACvBvB,MAAAA,GAAG,CAAE,qBAAoBC,SAAS,CAACqB,GAAG,CAACH,IAAL,CAAW,IAAGjB,IAAI,CAAE,IAAG,KAAKiB,IAAK,GAAf,CAAmB,EAApE,CAAH;AACA,WAAKC,QAAL,CAAcE,GAAd;AACA;;AACD,SAAKR,GAAL;AACA,WAAO,IAAP;AACA;AAED;;;;;;;;;AAOAW,EAAAA,YAAY,CAACC,IAAI,GAAG,EAAR,EAAY;AACvB,WAAO,KAAKC,IAAL,CAAU,cAAV,EAA0BC,OAAO,IAAI;AAC3C,YAAMC,MAAM,GAAG,EAAf;AACA,UAAIC,GAAG,GAAG,IAAV;;AAEA,aAAOA,GAAP,EAAY;AACXD,QAAAA,MAAM,CAACE,IAAP,CAAY;AACXC,UAAAA,KAAK,EAAG,GAAEF,GAAG,CAACE,KAAM,UADT;AAEXb,UAAAA,IAAI,EAAEW,GAAG,CAACX,IAFC;AAGX,aAAGW,GAAG,CAACG,OAAJ,CAAYR,YAAZ;AAHQ,SAAZ;AAKAG,QAAAA,OAAO,CAACM,QAAR,CAAiBC,OAAjB,CAAyBL,GAAG,CAACX,IAA7B;AACAW,QAAAA,GAAG,GAAGA,GAAG,CAACM,MAAV;AACA,OAZ0C,CAc3C;;;AACA,YAAMC,KAAK,GAAG,IAAIC,GAAJ,EAAd;AACA,YAAMC,MAAM,GAAG,IAAID,GAAJ,EAAf;AACA,UAAIE,CAAC,GAAGX,MAAM,CAACY,MAAf;;AACA,aAAOD,CAAC,EAAR,EAAY;AACX,aAAK,MAAMP,OAAX,IAAsBS,MAAM,CAACC,MAAP,CAAcd,MAAM,CAACW,CAAD,CAAN,CAAUI,MAAxB,CAAtB,EAAuD;AACtD,eAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGZ,OAAO,CAACQ,MAA5B,EAAoCI,CAAC,EAArC,EAAyC;AACxC,kBAAM;AAAEC,cAAAA,IAAF;AAAQC,cAAAA;AAAR,gBAAkBd,OAAO,CAACY,CAAD,CAA/B;AACA,gBAAIG,IAAI,GAAG,KAAX;;AACA,gBAAIF,IAAI,KAAK,IAAb,EAAmB;AAClB,kBAAIT,KAAK,CAACY,GAAN,CAAUH,IAAV,CAAJ,EAAqB;AACpBE,gBAAAA,IAAI,GAAG,IAAP;AACA,eAFD,MAEO;AACNX,gBAAAA,KAAK,CAACxB,GAAN,CAAUiC,IAAV;AACA;AACD;;AACD,gBAAIC,KAAK,KAAK,IAAd,EAAoB;AACnB,kBAAIR,MAAM,CAACU,GAAP,CAAWF,KAAX,CAAJ,EAAuB;AACtBC,gBAAAA,IAAI,GAAG,IAAP;AACA,eAFD,MAEO;AACNT,gBAAAA,MAAM,CAAC1B,GAAP,CAAWkC,KAAX;AACA;AACD;;AACD,gBAAIC,IAAJ,EAAU;AACTnB,cAAAA,MAAM,CAACW,CAAD,CAAN,CAAUU,KAAV;AACAjB,cAAAA,OAAO,CAACkB,MAAR,CAAeN,CAAC,EAAhB,EAAoB,CAApB;AACA;AACD;AACD;AACD,OA3C0C,CA6C3C;;;AACAjB,MAAAA,OAAO,CAACwB,IAAR,GAAe,KAAKA,IAAL,GAAYC,MAAM,CAAC,KAAKD,IAAN,CAAN,CAAkBE,IAAlB,GAAyBC,OAAzB,CAAiC,KAAjC,EAAwCC,CAAC,IAAIA,CAAC,CAACC,iBAAF,EAA7C,CAAZ,GAAkF,IAAjG,CA9C2C,CAgD3C;;AACA7B,MAAAA,OAAO,CAACV,QAAR,GAAmB;AAClBc,QAAAA,KAAK,EAAE,KAAKI,MAAL,GAAe,GAAE,KAAKJ,KAAM,WAA5B,GAAyC,UAD9B;AAElB,WAAG,KAAKd,QAAL,CAAcO,YAAd;AAFe,OAAnB;AAKA,YAAMH,GAAG,GAAG,KAAKE,UAAL,CAAgBC,YAAhB,EAAZ;AACAG,MAAAA,OAAO,CAACV,QAAR,CAAiBgC,KAAjB,IAA0B5B,GAAG,CAAC4B,KAA9B;AACAtB,MAAAA,OAAO,CAACV,QAAR,CAAiBwC,OAAjB,CAAyB3B,IAAzB,CAA8B,GAAGT,GAAG,CAACoC,OAArC,EAxD2C,CA0D3C;;AACA,UAAI,KAAKC,cAAT,EAAyB;AACxB,aAAK,MAAM3C,GAAX,IAAkBY,OAAO,CAACV,QAAR,CAAiBwC,OAAnC,EAA4C;AAC3C,cAAI1C,GAAG,CAACG,IAAJ,KAAa,KAAKwC,cAAtB,EAAsC;AACrC3C,YAAAA,GAAG,CAAC4C,OAAJ,GAAc,IAAd;AACA;AACA;AACD;AACD,OAlE0C,CAoE3C;;;AACAhC,MAAAA,OAAO,CAACiC,SAAR,GAAoB;AACnB7B,QAAAA,KAAK,EAAE,KAAKI,MAAL,GAAe,GAAE,KAAKJ,KAAM,YAA5B,GAA0C,WAD9B;AAEnB,WAAG,KAAKpB,IAAL,CAAUa,YAAV;AAFgB,OAApB,CArE2C,CA0E3C;;AACAG,MAAAA,OAAO,CAACK,OAAR,GAAkB;AACjBiB,QAAAA,KAAK,EAAErB,MAAM,CAACiC,MAAP,CAAc,CAACC,CAAD,EAAIP,CAAJ,KAAUO,CAAC,GAAGP,CAAC,CAACN,KAA9B,EAAqC,CAArC,CADU;AAEjBrB,QAAAA;AAFiB,OAAlB,CA3E2C,CAgF3C;;AACA,YAAMmC,KAAK,GAAG,EAAd;;AACA,UAAIC,KAAK,CAACC,OAAN,CAAcxC,IAAI,CAACyC,kBAAnB,CAAJ,EAA4C;AAC3CH,QAAAA,KAAK,CAACjC,IAAN,CAAWqC,KAAX,CAAiBJ,KAAjB,EAAwBtC,IAAI,CAACyC,kBAA7B;AACA;;AACDH,MAAAA,KAAK,CAACjC,IAAN,CAAWqC,KAAX,CAAiBJ,KAAjB,EAAwBpC,OAAO,CAACM,QAAR,CAAiBmC,KAAjB,EAAxB;AACAzC,MAAAA,OAAO,CAACV,QAAR,CAAiBgC,KAAjB,IAA0Bc,KAAK,CAACjC,IAAN,CAAW,WAAX,CAA1B;AACAH,MAAAA,OAAO,CAACK,OAAR,CAAgBiB,KAAhB,IAAyBc,KAAK,CAACjC,IAAN,CAAW,WAAX,CAAzB;AACAiC,MAAAA,KAAK,CAACjC,IAAN,CAAWqC,KAAX,CAAiBJ,KAAjB,EAAwBpC,OAAO,CAACiC,SAAR,CAAkBH,OAAlB,CAA0BY,GAA1B,CAA8B3D,GAAG,IAAI;AAC5D,cAAMQ,IAAI,GAAI,IAAGR,GAAG,CAACQ,IAAK,GAAER,GAAG,CAAC4D,QAAJ,GAAe,KAAf,GAAuB,EAAG,GAAtD;AACA,eAAO5D,GAAG,CAAC6D,QAAJ,GAAerD,IAAf,GAAuB,IAAGA,IAAK,GAAtC;AACA,OAHuB,CAAxB;AAIAS,MAAAA,OAAO,CAACoC,KAAR,GAAgB;AACfhC,QAAAA,KAAK,EAAE,OADQ;AAEfyC,QAAAA,IAAI,EAAET,KAAK,CAACU,IAAN,CAAW,GAAX;AAFS,OAAhB;AAKA,aAAO9C,OAAP;AACA,KAlGM,EAkGJ;AACFM,MAAAA,QAAQ,EAAE,EADR;AAEFyC,MAAAA,KAAK,EAAEC,SAFL;AAGFC,MAAAA,WAAW,EAAE,EAHX;AAIFC,MAAAA,QAAQ,EAAEF;AAJR,KAlGI,CAAP;AAwGA;AAED;;;;;;;;;;AAQAG,EAAAA,GAAG,CAAC5D,IAAD,EAAO6D,YAAP,EAAqB;AACvB,QAAIC,KAAK,GAAG,KAAK9D,IAAL,CAAZ;;AACA,SAAK,IAAI4C,CAAC,GAAG,KAAK3B,MAAlB,EAA0B2B,CAA1B,EAA6BA,CAAC,GAAGA,CAAC,CAAC3B,MAAnC,EAA2C;AAC1C6C,MAAAA,KAAK,GAAGlB,CAAC,CAACgB,GAAF,CAAM5D,IAAN,EAAY8D,KAAZ,CAAR;AACA;;AACD,WAAOA,KAAK,KAAKL,SAAV,GAAsBK,KAAtB,GAA8BD,YAArC;AACA;AAED;;;;;;;;AAMAvE,EAAAA,IAAI,CAACD,MAAD,EAAS;AACZ,QAAI,CAACA,MAAD,IAAW,OAAOA,MAAP,KAAkB,QAA7B,IAA0CA,MAAM,CAAC0E,MAAP,YAAyB5C,GAAzB,IAAgC,CAAC9B,MAAM,CAAC0E,MAAP,CAAcjC,GAAd,CAAkB,SAAlB,CAA/E,EAA8G;AAC7G,YAAMkC,gBAAEC,gBAAF,CAAmB,gDAAnB,EAAqE;AAAEjE,QAAAA,IAAI,EAAE,QAAR;AAAkBkE,QAAAA,KAAK,EAAE,cAAzB;AAAyCJ,QAAAA,KAAK,EAAEzE;AAAhD,OAArE,CAAN;AACA;;AAED,QAAIA,MAAM,CAAC0E,MAAP,YAAyB5C,GAAzB,IAAgC,CAAC9B,MAAM,CAAC0E,MAAP,CAAcjC,GAAd,CAAkB,SAAlB,CAArC,EAAmE;AAClE,YAAMkC,gBAAEC,gBAAF,CAAmB,gDAAnB,EAAqE;AAAEjE,QAAAA,IAAI,EAAE,QAAR;AAAkBkE,QAAAA,KAAK,EAAE,cAAzB;AAAyCJ,QAAAA,KAAK,EAAEzE;AAAhD,OAArE,CAAN;AACA;;AAED,SAAKI,IAAL,GAAsC,IAAI0E,qBAAJ,EAAtC;AACA,SAAKC,cAAL,GAAsC/E,MAAM,CAAC+E,cAA7C;AACA,SAAKC,MAAL,GAAsChF,MAAM,CAACgF,MAA7C;AACA,SAAKtE,QAAL,GAAsC,IAAIuE,mBAAJ,EAAtC;AACA,SAAK9B,cAAL,GAAsCnD,MAAM,CAACmD,cAA7C;AACA,SAAKP,IAAL,GAAsC5C,MAAM,CAAC4C,IAA7C;AACA,SAAKsC,qBAAL,GAAsClF,MAAM,CAACkF,qBAA7C;AACA,SAAKlE,UAAL,GAAsC,IAAImE,qBAAJ,EAAtC;AACA,SAAKC,YAAL,GAAsCpF,MAAM,CAACoF,YAA7C;AACA,SAAKC,gBAAL,GAAsCrF,MAAM,CAACqF,gBAA7C;AACA,SAAKC,kBAAL,GAAsCtF,MAAM,CAACsF,kBAA7C;AACA,SAAKC,iBAAL,GAAsCvF,MAAM,CAACuF,iBAA7C;AACA,SAAKC,MAAL,GAAsC,IAAIC,eAAJ,EAAtC;AACA,SAAK9E,IAAL,GAAsCX,MAAM,CAACW,IAA7C;AACA,SAAK+E,WAAL,GAAsC1F,MAAM,CAAC0F,WAA7C;AACA,SAAKjE,OAAL,GAAsC,IAAIkE,kBAAJ,EAAtC;AACA,SAAK/D,MAAL,GAAsC5B,MAAM,CAAC4B,MAA7C;AACA,SAAKtB,GAAL,GAAsC,CAAtC;AACA,SAAKsF,yBAAL,GAAsC5F,MAAM,CAAC4F,yBAA7C;AACA,SAAKC,eAAL,GAAsC7F,MAAM,CAAC6F,eAA7C;AACA,SAAKrE,KAAL,GAAsCxB,MAAM,CAACwB,KAAP,IAAgBxB,MAAM,CAACW,IAA7D;AACA,SAAKmF,8BAAL,GAAsC,CAAC,CAAC9F,MAAM,CAAC8F,8BAA/C;AACA,SAAKC,OAAL,GAAsC/F,MAAM,CAAC+F,OAA7C;AAEA/F,IAAAA,MAAM,CAACI,IAAP,IAAqB,KAAKF,QAAL,CAAcF,MAAM,CAACI,IAArB,CAArB;AACAJ,IAAAA,MAAM,CAACU,QAAP,IAAqB,KAAKH,OAAL,CAAaP,MAAM,CAACU,QAApB,CAArB;AACAV,IAAAA,MAAM,CAACgB,UAAP,IAAqB,KAAKH,SAAL,CAAeb,MAAM,CAACgB,UAAtB,CAArB;AACAhB,IAAAA,MAAM,CAACyB,OAAP,IAAqB,KAAKuE,MAAL,CAAYhG,MAAM,CAACyB,OAAnB,CAArB;AACA;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;AAwBAuE,EAAAA,MAAM,CAACC,MAAD,EAASjG,MAAT,EAAiB;AACtB,UAAMkB,IAAI,GAAG,KAAKO,OAAL,CAAapB,GAAb,CAAiB4F,MAAjB,EAAyBjG,MAAzB,CAAb;;AAEA,SAAK,MAAMkG,GAAX,IAAkBhF,IAAlB,EAAwB;AACvBgF,MAAAA,GAAG,CAACtE,MAAJ,GAAa,IAAb;;AAEA,UAAIsE,GAAG,CAAC5D,IAAR,EAAc;AACb,aAAKkD,MAAL,CAAYlD,IAAZ,CAAiB4D,GAAG,CAAC5D,IAArB,IAA6B4D,GAA7B;AACA;;AAED,UAAIA,GAAG,CAAC3D,KAAR,EAAe;AACd,aAAKiD,MAAL,CAAYjD,KAAZ,CAAkB2D,GAAG,CAAC3D,KAAtB,IAA+B2D,GAA/B;AACA;;AAED,WAAK,MAAM,CAAEC,KAAF,EAASC,OAAT,CAAX,IAAiClE,MAAM,CAACgB,OAAP,CAAegD,GAAG,CAACG,OAAJ,CAAY/D,IAA3B,CAAjC,EAAmE;AAClE,YAAI8D,OAAJ,EAAa;AACZ,eAAKZ,MAAL,CAAYlD,IAAZ,CAAiB6D,KAAjB,IAA0BD,GAA1B;AACA;AACD;;AAED,WAAK,MAAM,CAAEC,KAAF,EAASC,OAAT,CAAX,IAAiClE,MAAM,CAACgB,OAAP,CAAegD,GAAG,CAACG,OAAJ,CAAY9D,KAA3B,CAAjC,EAAoE;AACnE,YAAI6D,OAAJ,EAAa;AACZ,eAAKZ,MAAL,CAAYjD,KAAZ,CAAkB4D,KAAlB,IAA2BD,GAA3B;AACA;AACD;AACD;;AAED,SAAK5F,GAAL;AAEA,WAAO,IAAP;AACA;AAED;;;;;;;;;;AAQAgG,EAAAA,IAAI,CAAC3F,IAAD,EAAO6D,YAAP,EAAqB;AACxB,QAAIC,KAAK,GAAG,KAAK9D,IAAL,CAAZ;;AACA,SAAK,IAAI4C,CAAC,GAAG,KAAK3B,MAAlB,EAA0B6C,KAAK,KAAKL,SAAV,IAAuBb,CAAjD,EAAoDA,CAAC,GAAGA,CAAC,CAAC3B,MAA1D,EAAkE;AACjE6C,MAAAA,KAAK,GAAGlB,CAAC,CAAC+C,IAAF,CAAO3F,IAAP,EAAa8D,KAAb,CAAR;AACA;;AACD,WAAOA,KAAK,KAAKL,SAAV,GAAsBK,KAAtB,GAA8BD,YAArC;AACA;AAED;;;;;;;;AAMA5D,EAAAA,QAAQ,CAAC2F,EAAD,EAAK;AACZ,QAAIC,IAAJ;;AACA,QAAID,EAAE,CAAC7B,MAAH,CAAUjC,GAAV,CAAc,WAAd,CAAJ,EAAgC;AAC/B+D,MAAAA,IAAI,GAAG,YAAP;AACA,KAFD,MAEO,IAAID,EAAE,CAAC7B,MAAH,CAAUjC,GAAV,CAAc,SAAd,CAAJ,EAA8B;AACpC+D,MAAAA,IAAI,GAAG,UAAP;AACA;;AAED,QAAI,CAACA,IAAL,EAAW;AACV;AACA;;AAEDD,IAAAA,EAAE,CAAC3E,MAAH,GAAY,IAAZ;AACA,SAAK4D,MAAL,CAAYgB,IAAZ,EAAkBD,EAAE,CAAC5F,IAArB,IAA6B4F,EAA7B;;AAEA,QAAIA,EAAE,CAACF,OAAP,EAAgB;AACf,WAAK,MAAMF,KAAX,IAAoBjE,MAAM,CAACuE,IAAP,CAAYF,EAAE,CAACF,OAAf,CAApB,EAA6C;AAC5C,YAAI,CAAC,KAAKG,IAAL,EAAW/D,GAAX,CAAe0D,KAAf,CAAL,EAA4B;AAC3B,eAAKX,MAAL,CAAYgB,IAAZ,EAAkBL,KAAlB,IAA2BI,EAA3B;AACA;AACD;AACD;AACD;;AA3X+C","sourcesContent":["import ArgumentList from './argument-list';\nimport CommandMap from './command-map';\nimport debug from '../lib/debug';\nimport E from '../lib/errors';\nimport ExtensionMap from './extension-map';\nimport HookEmitter from 'hook-emitter';\nimport Lookup from './lookup';\nimport OptionMap from './option-map';\n\nimport { declareCLIKitClass } from '../lib/util';\n\nconst { log } = debug('cli-kit:context');\nconst { highlight, note } = debug.styles;\n\n/**\n * Defines a context that contains commands, options, and args. Serves as the\n * base class for `CLI` and `Context` objects.\n *\n * @extends {HookEmitter}\n */\nexport default class Context extends HookEmitter {\n\t/**\n\t * Constructs a context instance.\n\t *\n\t * @param {Object|Context} [params] - Various parameters.\n\t * @param {Object|String|Argument|ArgumentList|Array<Object|String|Argument>} [params.args] -\n\t * An object of argument names to argument descriptors, an argument name, an `Argument`\n\t * instance, an `ArgumentList` instance, or array of object descriptors, argument names, and\n\t * `Argument` instances.\n\t * @param {Boolean} [params.camelCase=true] - Camel case option names.\n\t * @param {Object|String|Command|CommandMap|Array.<Object|String|Command>} [params.commands] -\n\t * An object used for `Command` constructor params, a path to a directory or a `.js` file, a\n\t * `Command` instance, or an array of those types. May also be a `CommandMap` instance. If\n\t * `cmd` is a `String` and `params` is present, then it will treat `cmd` as the command name,\n\t * not a file path.\n\t * @param {String} [params.desc] - The description of the CLI or command displayed in the help\n\t * output. If context is a command with a help header defined, this description is not\n\t * displayed.\n\t * @param {Object|String|Extension|ExtensionMap|Array.<String|Extension>} [params.extensions] -\n\t * An object of extension names to extension paths or instances, an extension path, an\n\t * `Extension` instance, or an array of those types. An extension path may be a directory\n\t * containing a Node.js module, a path to a `.js` file, or the name of a executable. May also\n\t * be an `ExtensionMap` instance.\n\t * @param {String} [params.name] - The name of the context such as the program or the command\n\t * name.\n\t * @param {Object|Option|OptionMap|Array<Object|Option|String>} [params.options] - An object of\n\t * format to `Option` constructor params, an `Option` instance, or an array of `Option`\n\t * constructor params and `Option` instances grouped by `String` labels.\n\t * @param {Context} [params.parent] - The parent context.\n\t * @param {String} [params.title] - The context title.\n\t * @param {Boolean} [params.treatUnknownOptionsAsArguments=false] - When `true`, any argument is\n\t * encountered during parsing that resembles a option that does not exist, it will add it\n\t * untouched to `_` as an argument as well as to `argv` as a boolean flag. When `false`, it will\n\t * only add the argument to `argv` as a boolean flag.\n\t * @access public\n\t */\n\tconstructor(params = {}) {\n\t\tsuper();\n\t\tdeclareCLIKitClass(this, 'Context');\n\t\tthis.init(params);\n\t}\n\n\t/**\n\t * Adds an argument to this context.\n\t *\n\t * @param {Object|String|Argument|ArgumentList|Array<Object|String|Argument>} arg - An object\n\t * of argument names to argument descriptors, an argument name, an `Argument` instance, an\n\t * `ArgumentList` instance, or array of object descriptors, argument names, and `Argument`\n\t * instances.\n\t * @returns {Context}\n\t * @access public\n\t */\n\targument(arg) {\n\t\tthis.args.add(arg);\n\t\tthis.rev++;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds a command to this context.\n\t *\n\t * @param {Object|String|Command|CommandMap|Array.<Object|String|Command>} cmd - An object\n\t * used for `Command` constructor params, a path to a directory or a `.js` file, a `Command`\n\t * instance, or an array of those types. May also be a `CommandMap` instance. If `cmd` is a\n\t * `String` and `params` is present, then it will treat `cmd` as the command name, not a file\n\t * path.\n\t * @param {Object} [params] - When `cmd` is the command name, then this is the options to pass\n\t * into the `Command` constructor.\n\t * @returns {Context}\n\t * @access public\n\t */\n\tcommand(cmd, params) {\n\t\tconst cmds = this.commands.add(cmd, params);\n\t\tfor (const cmd of cmds) {\n\t\t\tlog(`Adding command: ${highlight(cmd.name)} ${note(`(${this.name})`)}`);\n\t\t\tthis.register(cmd);\n\t\t}\n\t\tthis.rev++;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Registers an external package as a command context that invokes the package.\n\t *\n\t * @param {Object|String|Extension|ExtensionMap|Array.<String|Extension>} ext - An object of\n\t * extension names to extension paths or instances, an extension path, an `Extension` instance,\n\t * or an array of those types. An extension path may be a directory containing a Node.js\n\t * module, a path to a `.js` file, or the name of a executable. May also be an `ExtensionMap`\n\t * instance.\n\t * @param {String} [name] - The extension name used for the context name. If not set, it will\n\t * attempt to find a `package.json` with a `cli-kit.name` value.\n\t * @returns {Context}\n\t * @access public\n\t */\n\textension(ext, name) {\n\t\tconst exts = this.extensions.add(ext, name);\n\t\tfor (const ext of exts) {\n\t\t\tlog(`Adding extension: ${highlight(ext.name)} ${note(`(${this.name})`)}`);\n\t\t\tthis.register(ext);\n\t\t}\n\t\tthis.rev++;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Renders the help screen for this context including the parent contexts.\n\t *\n\t * @param {Object} [opts] - Various parameters.\n\t * @returns {Promise<Object>}\n\t * @access private\n\t */\n\tgenerateHelp(opts = {}) {\n\t\treturn this.hook('generateHelp', results => {\n\t\t\tconst scopes = [];\n\t\t\tlet ctx = this;\n\n\t\t\twhile (ctx) {\n\t\t\t\tscopes.push({\n\t\t\t\t\ttitle: `${ctx.title} options`,\n\t\t\t\t\tname: ctx.name,\n\t\t\t\t\t...ctx.options.generateHelp()\n\t\t\t\t});\n\t\t\t\tresults.contexts.unshift(ctx.name);\n\t\t\t\tctx = ctx.parent;\n\t\t\t}\n\n\t\t\t// remove duplicate options\n\t\t\tconst longs = new Set();\n\t\t\tconst shorts = new Set();\n\t\t\tlet j = scopes.length;\n\t\t\twhile (j--) {\n\t\t\t\tfor (const options of Object.values(scopes[j].groups)) {\n\t\t\t\t\tfor (let i = 0; i < options.length; i++) {\n\t\t\t\t\t\tconst { long, short } = options[i];\n\t\t\t\t\t\tlet nuke = false;\n\t\t\t\t\t\tif (long !== null) {\n\t\t\t\t\t\t\tif (longs.has(long)) {\n\t\t\t\t\t\t\t\tnuke = true;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tlongs.add(long);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (short !== null) {\n\t\t\t\t\t\t\tif (shorts.has(short)) {\n\t\t\t\t\t\t\t\tnuke = true;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tshorts.add(short);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (nuke) {\n\t\t\t\t\t\t\tscopes[j].count--;\n\t\t\t\t\t\t\toptions.splice(i--, 1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// set the description\n\t\t\tresults.desc = this.desc ? String(this.desc).trim().replace(/^\\w/, c => c.toLocaleUpperCase()) : null;\n\n\t\t\t// set the commands\n\t\t\tresults.commands = {\n\t\t\t\ttitle: this.parent ? `${this.title} commands` : 'Commands',\n\t\t\t\t...this.commands.generateHelp()\n\t\t\t};\n\n\t\t\tconst ext = this.extensions.generateHelp();\n\t\t\tresults.commands.count += ext.count;\n\t\t\tresults.commands.entries.push(...ext.entries);\n\n\t\t\t// update the default command\n\t\t\tif (this.defaultCommand) {\n\t\t\t\tfor (const cmd of results.commands.entries) {\n\t\t\t\t\tif (cmd.name === this.defaultCommand) {\n\t\t\t\t\t\tcmd.default = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// set the arguments\n\t\t\tresults.arguments = {\n\t\t\t\ttitle: this.parent ? `${this.title} arguments` : 'Arguments',\n\t\t\t\t...this.args.generateHelp()\n\t\t\t};\n\n\t\t\t// set the options\n\t\t\tresults.options = {\n\t\t\t\tcount: scopes.reduce((p, c) => p + c.count, 0),\n\t\t\t\tscopes\n\t\t\t};\n\n\t\t\t// set the usage line\n\t\t\tconst usage = [];\n\t\t\tif (Array.isArray(opts.parentContextNames)) {\n\t\t\t\tusage.push.apply(usage, opts.parentContextNames);\n\t\t\t}\n\t\t\tusage.push.apply(usage, results.contexts.slice());\n\t\t\tresults.commands.count && usage.push('<command>');\n\t\t\tresults.options.count && usage.push('[options]');\n\t\t\tusage.push.apply(usage, results.arguments.entries.map(arg => {\n\t\t\t\tconst name = `<${arg.name}${arg.multiple ? '...' : ''}>`;\n\t\t\t\treturn arg.required ? name : `[${name}]`;\n\t\t\t}));\n\t\t\tresults.usage = {\n\t\t\t\ttitle: 'Usage',\n\t\t\t\ttext: usage.join(' ')\n\t\t\t};\n\n\t\t\treturn results;\n\t\t})({\n\t\t\tcontexts: [],\n\t\t\terror: undefined,\n\t\t\tsuggestions: [],\n\t\t\twarnings: undefined\n\t\t});\n\t}\n\n\t/**\n\t * Scan parent contexts to find the specified property in the top-most context.\n\t *\n\t * @param {String} name - The property name.\n\t * @param {*} defaultValue - A default value if no value is found.\n\t * @returns {*}\n\t * @access private\n\t */\n\tget(name, defaultValue) {\n\t\tlet value = this[name];\n\t\tfor (let p = this.parent; p; p = p.parent) {\n\t\t\tvalue = p.get(name, value);\n\t\t}\n\t\treturn value !== undefined ? value : defaultValue;\n\t}\n\n\t/**\n\t * Initializes this context with params.\n\t *\n\t * @param {Object|Context} params - Various parameters\n\t * @access private\n\t */\n\tinit(params) {\n\t\tif (!params || typeof params !== 'object' || (params.clikit instanceof Set && !params.clikit.has('Context'))) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected parameters to be an object or Context', { name: 'params', scope: 'Context.init', value: params });\n\t\t}\n\n\t\tif (params.clikit instanceof Set && !params.clikit.has('Context')) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected parameters to be an object or Context', { name: 'params', scope: 'Context.init', value: params });\n\t\t}\n\n\t\tthis.args                           = new ArgumentList();\n\t\tthis.autoHideBanner                 = params.autoHideBanner;\n\t\tthis.banner                         = params.banner;\n\t\tthis.commands                       = new CommandMap();\n\t\tthis.defaultCommand                 = params.defaultCommand;\n\t\tthis.desc                           = params.desc;\n\t\tthis.errorIfUnknownCommand          = params.errorIfUnknownCommand;\n\t\tthis.extensions                     = new ExtensionMap();\n\t\tthis.helpExitCode                   = params.helpExitCode;\n\t\tthis.helpTemplateFile               = params.helpTemplateFile;\n\t\tthis.hideNoBannerOption             = params.hideNoBannerOption;\n\t\tthis.hideNoColorOption              = params.hideNoColorOption;\n\t\tthis.lookup                         = new Lookup();\n\t\tthis.name                           = params.name;\n\t\tthis.nodeVersion                    = params.nodeVersion;\n\t\tthis.options                        = new OptionMap();\n\t\tthis.parent                         = params.parent;\n\t\tthis.rev                            = 0;\n\t\tthis.showBannerForExternalCLIs      = params.showBannerForExternalCLIs;\n\t\tthis.showHelpOnError                = params.showHelpOnError;\n\t\tthis.title                          = params.title || params.name;\n\t\tthis.treatUnknownOptionsAsArguments = !!params.treatUnknownOptionsAsArguments;\n\t\tthis.version                        = params.version;\n\n\t\tparams.args       && this.argument(params.args);\n\t\tparams.commands   && this.command(params.commands);\n\t\tparams.extensions && this.extension(params.extensions);\n\t\tparams.options    && this.option(params.options);\n\t}\n\n\t/**\n\t * Adds an option to this context.\n\t *\n\t * @param {String|Object|Option|OptionMap|Array<Object|Option|String>} format - An option\n\t * format, an object of format to option descriptions, `Option` constructor params or `Option`\n\t * instances, an `Option` instance, an `OptionMap` instance, or an array of `Option`\n\t * constructor params and `Option` instances grouped by `String` labels.\n\t * @param {Object|Option|String} [params] - When `format` is a format string, then this\n\t * argument is either `Option` constructor parameters, an `Option` instance, or an option\n\t * description.\n\t * @returns {Context}\n\t * @access public\n\t *\n\t * @example\n\t *   ctx.option('--foo'); // format flag\n\t *   ctx.option('--foo', 'enables foo mode'); // format with description\n\t *   ctx.option('--foo', { desc: 'enables foo mode' }); // format with Option ctor params\n\t *   ctx.option({ '--foo': null }); // object with format flag\n\t *   ctx.option({ '--foo': { desc: 'enables foo mode' } }); // object with Option ctor params\n\t *   ctx.option({ '--foo': new Option() }); // object of `Option` instance\n\t *   ctx.option(new Option('--foo')); // `Option` instance\n\t *   ctx.option(new OptionMap()); // `OptionMap` from another instance\n\t *   ctx.option([ 'Some Group', new Option('--foo'), 'Another Group', { '--bar': null } ]); // an array of grouped options\n\t */\n\toption(format, params) {\n\t\tconst opts = this.options.add(format, params);\n\n\t\tfor (const opt of opts) {\n\t\t\topt.parent = this;\n\n\t\t\tif (opt.long) {\n\t\t\t\tthis.lookup.long[opt.long] = opt;\n\t\t\t}\n\n\t\t\tif (opt.short) {\n\t\t\t\tthis.lookup.short[opt.short] = opt;\n\t\t\t}\n\n\t\t\tfor (const [ alias, visible ] of Object.entries(opt.aliases.long)) {\n\t\t\t\tif (visible) {\n\t\t\t\t\tthis.lookup.long[alias] = opt;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor (const [ alias, visible ] of Object.entries(opt.aliases.short)) {\n\t\t\t\tif (visible) {\n\t\t\t\t\tthis.lookup.short[alias] = opt;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.rev++;\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Scan parent contexts to find the specified property in the bottom-most context.\n\t *\n\t * @param {String} name - The property name.\n\t * @param {*} defaultValue - A default value if no value is found.\n\t * @returns {*}\n\t * @access private\n\t */\n\tprop(name, defaultValue) {\n\t\tlet value = this[name];\n\t\tfor (let p = this.parent; value === undefined && p; p = p.parent) {\n\t\t\tvalue = p.prop(name, value);\n\t\t}\n\t\treturn value !== undefined ? value : defaultValue;\n\t}\n\n\t/**\n\t * Registers a command or extension to add to the lookup.\n\t *\n\t * @param {Command|Extension} it - The command or extension instance.\n\t * @access private\n\t */\n\tregister(it) {\n\t\tlet dest;\n\t\tif (it.clikit.has('Extension')) {\n\t\t\tdest = 'extensions';\n\t\t} else if (it.clikit.has('Command')) {\n\t\t\tdest = 'commands';\n\t\t}\n\n\t\tif (!dest) {\n\t\t\treturn;\n\t\t}\n\n\t\tit.parent = this;\n\t\tthis.lookup[dest][it.name] = it;\n\n\t\tif (it.aliases) {\n\t\t\tfor (const alias of Object.keys(it.aliases)) {\n\t\t\t\tif (!this[dest].has(alias)) {\n\t\t\t\t\tthis.lookup[dest][alias] = it;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n"],"file":"parser/context.js"} |
@@ -132,3 +132,3 @@ "use strict"; | ||
for (const cmd of Array.from(this.keys()).sort()) { | ||
for (const cmd of Array.from(this.keys())) { | ||
const { | ||
@@ -143,5 +143,17 @@ aliases, | ||
if (!hidden && !clikitHelp) { | ||
const labels = [name]; | ||
for (const [alias, display] of Object.entries(aliases)) { | ||
if (display === 'visible') { | ||
labels.push(alias); | ||
} | ||
} | ||
labels.sort((a, b) => { | ||
return a.length === b.length ? a.localeCompare(b) : a.length - b.length; | ||
}); | ||
entries.push({ | ||
name, | ||
desc, | ||
label: labels.join(', '), | ||
aliases: aliases ? Object.keys(aliases) : null | ||
@@ -152,2 +164,3 @@ }); | ||
entries.sort((a, b) => a.label.localeCompare(b.label)); | ||
return { | ||
@@ -162,2 +175,2 @@ count: entries.length, | ||
exports.default = ExtensionMap; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/extension-map.js"],"names":["Extension","ExtensionMap","Map","constructor","add","ext","name","E","INVALID_ARGUMENT","scope","value","require","default","results","extensions","clikit","Set","has","entries","Object","Array","isArray","it","pathOrExt","set","push","count","size","generateHelp","cmd","from","keys","sort","aliases","clikitHelp","desc","hidden","get","length"],"mappings":"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","sourcesContent":["import E from '../lib/errors';\n\nimport { declareCLIKitClass } from '../lib/util';\n\nlet Extension;\n\n/**\n * Stores a map of `Extension` instances that have been registered for a context.\n *\n * @extends {Map}\n */\nexport default class ExtensionMap extends Map {\n\t/**\n\t * Declares the class name.\n\t *\n\t * @access public\n\t */\n\tconstructor() {\n\t\tsuper();\n\t\tdeclareCLIKitClass(this, 'ExtensionMap');\n\t}\n\n\t/**\n\t * Adds an extension to the map.\n\t *\n\t * @param {Object|String|Extension|ExtensionMap|Array.<String|Extension>} ext - An object of\n\t * extension names to extension paths or instances, an extension path, an `Extension` instance,\n\t * or an array of those types. An extension path may be a directory containing a Node.js\n\t * module, a path to a `.js` file, or the name of a executable. May also be an `ExtensionMap`\n\t * instance.\n\t * @param {String} [name] - The extension name used for the context name. If not set, it will\n\t * attempt to find a `package.json` with a `cli-kit.name` value.\n\t * @returns {Array.<Extension>}\n\t * @access public\n\t *\n\t * @example\n\t *   .add({ foo: '/path/to/ext', bar: new Extension() })\n\t *   .add('/path/to/ext');\n\t *   .add('/path/to/ext', 'foo');\n\t *   .add(new Extension())\n\t *   .add(new ExtensionMap())\n\t *   .add([ '/path/to/ext', new Extension() ])\n\t */\n\tadd(ext, name) {\n\t\tif (!ext) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected extension to be an extension instance or a path', { name: 'ext', scope: 'ExtensionMap.add', value: ext });\n\t\t}\n\n\t\tif (name && typeof name !== 'string') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected extension name to be a string', { name: 'name', scope: 'ExtensionMap.add', value: name });\n\t\t}\n\n\t\tif (!Extension) {\n\t\t\tExtension = require('./extension').default;\n\t\t}\n\n\t\tconst results = [];\n\t\tconst extensions = typeof ext === 'object'\n\t\t\t? (\n\t\t\t\text.clikit instanceof Set && ext.clikit.has('Extension')\n\t\t\t\t\t? [ ext ]\n\t\t\t\t\t: ext.clikit instanceof Set && ext.clikit.has('ExtensionMap')\n\t\t\t\t\t\t? ext.entries()\n\t\t\t\t\t\t: Object.entries(ext)\n\t\t\t)\n\t\t\t: Array.isArray(ext) ? ext : [ ext ];\n\n\t\t// at this point, we have an array of `Strings` (paths), Array [name,ext], and Extension instances\n\n\t\tfor (let it of extensions) {\n\t\t\tlet ext = null;\n\n\t\t\tif (it instanceof Extension) {\n\t\t\t\text = it;\n\t\t\t} else if (Array.isArray(it)) {\n\t\t\t\t// [name,ext]\n\t\t\t\tconst [ name, pathOrExt ] = it;\n\t\t\t\text = pathOrExt instanceof Extension ? pathOrExt : new Extension(pathOrExt, { name });\n\t\t\t} else if (it && (typeof it === 'string' || (typeof it === 'object' && it.clikit instanceof Set && it.clikit.has('Extension')))) {\n\t\t\t\t// path or params\n\t\t\t\text = new Extension(it, { name });\n\t\t\t}\n\n\t\t\tif (ext) {\n\t\t\t\tthis.set(ext.name, ext);\n\t\t\t\tresults.push(ext);\n\t\t\t} else {\n\t\t\t\tthrow E.INVALID_ARGUMENT(`Invalid extension \"${it}\", expected a valid path or an object`, { name: 'extension', scope: 'ExtensionMap.add', value: it });\n\t\t\t}\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Returns the number of extensions.\n\t *\n\t * @returns {Number}\n\t * @access public\n\t */\n\tget count() {\n\t\treturn this.size;\n\t}\n\n\t/**\n\t * Generates an object containing the extensions for the help screen.\n\t *\n\t * @returns {Object}\n\t * @access public\n\t */\n\tgenerateHelp() {\n\t\tconst entries = [];\n\n\t\tfor (const cmd of Array.from(this.keys()).sort()) {\n\t\t\tconst { aliases, clikitHelp, desc, hidden, name } = this.get(cmd);\n\t\t\tif (!hidden && !clikitHelp) {\n\t\t\t\tentries.push({\n\t\t\t\t\tname,\n\t\t\t\t\tdesc,\n\t\t\t\t\taliases: aliases ? Object.keys(aliases) : null\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\treturn {\n\t\t\tcount: entries.length,\n\t\t\tentries\n\t\t};\n\t}\n}\n"],"file":"parser/extension-map.js"} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/extension-map.js"],"names":["Extension","ExtensionMap","Map","constructor","add","ext","name","E","INVALID_ARGUMENT","scope","value","require","default","results","extensions","clikit","Set","has","entries","Object","Array","isArray","it","pathOrExt","set","push","count","size","generateHelp","cmd","from","keys","aliases","clikitHelp","desc","hidden","get","labels","alias","display","sort","a","b","length","localeCompare","label","join"],"mappings":"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","sourcesContent":["import E from '../lib/errors';\n\nimport { declareCLIKitClass } from '../lib/util';\n\nlet Extension;\n\n/**\n * Stores a map of `Extension` instances that have been registered for a context.\n *\n * @extends {Map}\n */\nexport default class ExtensionMap extends Map {\n\t/**\n\t * Declares the class name.\n\t *\n\t * @access public\n\t */\n\tconstructor() {\n\t\tsuper();\n\t\tdeclareCLIKitClass(this, 'ExtensionMap');\n\t}\n\n\t/**\n\t * Adds an extension to the map.\n\t *\n\t * @param {Object|String|Extension|ExtensionMap|Array.<String|Extension>} ext - An object of\n\t * extension names to extension paths or instances, an extension path, an `Extension` instance,\n\t * or an array of those types. An extension path may be a directory containing a Node.js\n\t * module, a path to a `.js` file, or the name of a executable. May also be an `ExtensionMap`\n\t * instance.\n\t * @param {String} [name] - The extension name used for the context name. If not set, it will\n\t * attempt to find a `package.json` with a `cli-kit.name` value.\n\t * @returns {Array.<Extension>}\n\t * @access public\n\t *\n\t * @example\n\t *   .add({ foo: '/path/to/ext', bar: new Extension() })\n\t *   .add('/path/to/ext');\n\t *   .add('/path/to/ext', 'foo');\n\t *   .add(new Extension())\n\t *   .add(new ExtensionMap())\n\t *   .add([ '/path/to/ext', new Extension() ])\n\t */\n\tadd(ext, name) {\n\t\tif (!ext) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected extension to be an extension instance or a path', { name: 'ext', scope: 'ExtensionMap.add', value: ext });\n\t\t}\n\n\t\tif (name && typeof name !== 'string') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected extension name to be a string', { name: 'name', scope: 'ExtensionMap.add', value: name });\n\t\t}\n\n\t\tif (!Extension) {\n\t\t\tExtension = require('./extension').default;\n\t\t}\n\n\t\tconst results = [];\n\t\tconst extensions = typeof ext === 'object'\n\t\t\t? (\n\t\t\t\text.clikit instanceof Set && ext.clikit.has('Extension')\n\t\t\t\t\t? [ ext ]\n\t\t\t\t\t: ext.clikit instanceof Set && ext.clikit.has('ExtensionMap')\n\t\t\t\t\t\t? ext.entries()\n\t\t\t\t\t\t: Object.entries(ext)\n\t\t\t)\n\t\t\t: Array.isArray(ext) ? ext : [ ext ];\n\n\t\t// at this point, we have an array of `Strings` (paths), Array [name,ext], and Extension instances\n\n\t\tfor (let it of extensions) {\n\t\t\tlet ext = null;\n\n\t\t\tif (it instanceof Extension) {\n\t\t\t\text = it;\n\t\t\t} else if (Array.isArray(it)) {\n\t\t\t\t// [name,ext]\n\t\t\t\tconst [ name, pathOrExt ] = it;\n\t\t\t\text = pathOrExt instanceof Extension ? pathOrExt : new Extension(pathOrExt, { name });\n\t\t\t} else if (it && (typeof it === 'string' || (typeof it === 'object' && it.clikit instanceof Set && it.clikit.has('Extension')))) {\n\t\t\t\t// path or params\n\t\t\t\text = new Extension(it, { name });\n\t\t\t}\n\n\t\t\tif (ext) {\n\t\t\t\tthis.set(ext.name, ext);\n\t\t\t\tresults.push(ext);\n\t\t\t} else {\n\t\t\t\tthrow E.INVALID_ARGUMENT(`Invalid extension \"${it}\", expected a valid path or an object`, { name: 'extension', scope: 'ExtensionMap.add', value: it });\n\t\t\t}\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Returns the number of extensions.\n\t *\n\t * @returns {Number}\n\t * @access public\n\t */\n\tget count() {\n\t\treturn this.size;\n\t}\n\n\t/**\n\t * Generates an object containing the extensions for the help screen.\n\t *\n\t * @returns {Object}\n\t * @access public\n\t */\n\tgenerateHelp() {\n\t\tconst entries = [];\n\n\t\tfor (const cmd of Array.from(this.keys())) {\n\t\t\tconst { aliases, clikitHelp, desc, hidden, name } = this.get(cmd);\n\t\t\tif (!hidden && !clikitHelp) {\n\t\t\t\tconst labels = [ name ];\n\t\t\t\tfor (const [ alias, display ] of Object.entries(aliases)) {\n\t\t\t\t\tif (display === 'visible') {\n\t\t\t\t\t\tlabels.push(alias);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tlabels.sort((a, b) => {\n\t\t\t\t\treturn a.length === b.length ? a.localeCompare(b) : a.length - b.length;\n\t\t\t\t});\n\n\t\t\t\tentries.push({\n\t\t\t\t\tname,\n\t\t\t\t\tdesc,\n\t\t\t\t\tlabel: labels.join(', '),\n\t\t\t\t\taliases: aliases ? Object.keys(aliases) : null\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tentries.sort((a, b) => a.label.localeCompare(b.label));\n\n\t\treturn {\n\t\t\tcount: entries.length,\n\t\t\tentries\n\t\t};\n\t}\n}\n"],"file":"parser/extension-map.js"} |
{ | ||
"name": "cli-kit", | ||
"version": "1.1.1", | ||
"version": "1.2.0", | ||
"description": "Everything you need to create awesome command line interfaces", | ||
@@ -56,6 +56,7 @@ "main": "./dist/index.js", | ||
"devDependencies": { | ||
"@babel/core": "^7.10.0", | ||
"@babel/plugin-proposal-class-properties": "^7.8.3", | ||
"@babel/plugin-transform-modules-commonjs": "^7.9.6", | ||
"@babel/register": "^7.9.0", | ||
"@babel/core": "^7.10.1", | ||
"@babel/plugin-proposal-class-properties": "^7.10.1", | ||
"@babel/plugin-proposal-optional-chaining": "^7.10.1", | ||
"@babel/plugin-transform-modules-commonjs": "^7.10.1", | ||
"@babel/register": "^7.10.1", | ||
"babel-eslint": "^10.1.0", | ||
@@ -62,0 +63,0 @@ "babel-loader": "^8.1.0", |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
588374
6310
32