Comparing version 1.0.0 to 1.0.1
@@ -24,12 +24,15 @@ "use strict"; | ||
/** | ||
* Renders help for a specific context, and its parent contexts, to a string. | ||
* Renders help for a specific context, and its parent contexts, to a string. This function is | ||
* passed into the selected command's `action()` as a property called `help()` so that a command | ||
* can render its own help output. | ||
* | ||
* @param {Context} ctx - The context to render help. | ||
* @param {Object} [opts] - Various options to pass into `generateHelp()`. | ||
* @returns {String} | ||
*/ | ||
async function renderHelp(ctx) { | ||
async function renderHelp(ctx, opts) { | ||
const file = ctx.get('helpTemplateFile', _path.default.resolve(__dirname, '..', '..', 'templates', 'help.tpl')); | ||
log(`Rendering help template: ${highlight(file)}`); | ||
return (0, _template.renderFile)(file, await ctx.generateHelp()); | ||
return (0, _template.renderFile)(file, await ctx.generateHelp(opts)); | ||
} | ||
@@ -44,4 +47,19 @@ /** | ||
var _default = { | ||
/** | ||
* Indicates this command is the built-in cli-kit help command so that if the CLI instance this | ||
* command belongs to gets added to another CLI instance, we don't copy it over. | ||
* @type {Boolean} | ||
*/ | ||
clikitHelp: true, | ||
/** | ||
* While this is a command, we don't want to show it since we already show the `--help` flag. | ||
* @type {Boolean} | ||
*/ | ||
hidden: true, | ||
/** | ||
* Output the help as JSON. Neato. | ||
* @type {Object} | ||
*/ | ||
options: { | ||
@@ -58,3 +76,4 @@ '--json': null | ||
* @param {Error} [params.err] - An error object in the event an error occurred. | ||
* @param {Function} params.exit - A function that sets the exit code. | ||
* @param {Function} params.exitCode - A function that sets the exit code. | ||
* @param {Array.<String>} [params.parentContextNames] - An array of parent context names. | ||
* @param {String} [params.unknownCommand] - The name of the unknown command. | ||
@@ -71,2 +90,3 @@ * @param {Array.<Error>} [params.warnings] - A list of warnings (error objects). | ||
exitCode, | ||
parentContextNames, | ||
warnings | ||
@@ -97,2 +117,3 @@ } = {}) { | ||
err, | ||
parentContextNames, | ||
warnings | ||
@@ -155,2 +176,2 @@ }); // check if we should error if passed an invalid command | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["commands/help.js"],"names":["log","highlight","debug","styles","renderHelp","ctx","file","get","path","resolve","__dirname","generateHelp","clikitHelp","hidden","options","action","_","argv","console","contexts","err","exitCode","warnings","formatError","type","constructor","name","code","message","json","meta","stack","help","length","unknownCommand","Error","levenshtein","require","suggestions","commands","entries","map","cmd","desc","dist","filter","s","sort","a","b","r","localeCompare","error","Array","isArray","_stdout","_stderr","write","JSON","stringify","header","footer"],"mappings":"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","sourcesContent":["import debug from '../lib/debug';\nimport path from 'path';\n\nimport { renderFile } from '../render/template';\n\nconst { log } = debug('cli-kit:help');\nconst { highlight } = debug.styles;\n\n/**\n * Renders help for a specific context, and its parent contexts, to a string.\n *\n * @param {Context} ctx - The context to render help.\n * @returns {String}\n */\nexport async function renderHelp(ctx) {\n\tconst file = ctx.get('helpTemplateFile', path.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));\n\tlog(`Rendering help template: ${highlight(file)}`);\n\treturn renderFile(file, await ctx.generateHelp());\n}\n\n/**\n * The built-in help command parameters.\n *\n * @type {Object}\n */\nexport default {\n\tclikitHelp: true,\n\n\thidden: true,\n\n\toptions: {\n\t\t'--json': null\n\t},\n\n\t/**\n\t * Executes the help command.\n\t *\n\t * @param {Object} params - Various parameters.\n\t * @param {Object} [params.argv] - The parsed options.\n\t * @param {Array.<Context>} params.contexts - The stack of contexts found during parsing.\n\t * @param {Error} [params.err] - An error object in the event an error occurred.\n\t * @param {Function} params.exit - A function that sets the exit code.\n\t * @param {String} [params.unknownCommand] - The name of the unknown command.\n\t * @param {Array.<Error>} [params.warnings] - A list of warnings (error objects).\n\t * @returns {Promise}\n\t */\n\tasync action({ _ = [], argv = {}, console, contexts, err, exitCode, warnings } = {}) {\n\t\texitCode(+!!err); // 0=success, 1=error\n\n\t\tconst formatError = err => {\n\t\t\tconst type = err && err.constructor && err.constructor.name || null;\n\t\t\treturn err ? {\n\t\t\t\tcode:    err.code,\n\t\t\t\tmessage: !argv.json && type ? `${type}: ${err.message}` : err.message,\n\t\t\t\tmeta:    err.meta,\n\t\t\t\tstack:   err.stack,\n\t\t\t\ttype\n\t\t\t} : null;\n\t\t};\n\n\t\t// skip the built-in help command and find the first context\n\t\tfor (const ctx of contexts) {\n\t\t\t// we don't display help for the help command\n\t\t\tif (ctx.clikitHelp) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// generate the help object\n\t\t\tconst help = await ctx.generateHelp({ err, warnings });\n\n\t\t\t// check if we should error if passed an invalid command\n\t\t\tif (!err && _.length && (ctx.get('errorIfUnknownCommand') || argv.help)) {\n\t\t\t\tconst unknownCommand = _[0];\n\t\t\t\terr = new Error(`Unknown command \"${unknownCommand}\"`);\n\n\t\t\t\tconst levenshtein = require('fast-levenshtein');\n\t\t\t\thelp.suggestions = help.commands.entries\n\t\t\t\t\t.map(cmd => ({ name: cmd.name, desc: cmd.desc, dist: levenshtein.get(unknownCommand, cmd.name) }))\n\t\t\t\t\t.filter(s => s.dist <= 2)\n\t\t\t\t\t.sort((a, b) => {\n\t\t\t\t\t\tconst r = a.dist - b.dist;\n\t\t\t\t\t\treturn r !== 0 ? r : a.name.localeCompare(b.name);\n\t\t\t\t\t});\n\t\t\t}\n\n\t\t\thelp.error = formatError(err);\n\t\t\thelp.warnings = Array.isArray(warnings) ? warnings.map(formatError) : null;\n\n\t\t\tconst { _stdout, _stderr } = console;\n\n\t\t\t// print the help output\n\t\t\tif (argv.json) {\n\t\t\t\t_stdout.write(JSON.stringify(help, null, '  '));\n\t\t\t\t_stdout.write('\\n');\n\t\t\t} else {\n\t\t\t\tconst file = ctx.get('helpTemplateFile', path.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));\n\t\t\t\tlog(`Rendering help template: ${highlight(file)}`);\n\n\t\t\t\t// only commands have a header and footer, but CLI instances do not and thus we\n\t\t\t\t// need to define them to make the template happy\n\t\t\t\tif (!help.header) {\n\t\t\t\t\thelp.header = null;\n\t\t\t\t}\n\t\t\t\tif (!help.footer) {\n\t\t\t\t\thelp.footer = null;\n\t\t\t\t}\n\n\t\t\t\t// determine the output stream\n\t\t\t\t(err ? _stderr : _stdout).write(renderFile(file, help));\n\t\t\t}\n\n\t\t\t// set the exit code\n\t\t\texitCode(err ? 1 : ctx.get('helpExitCode'));\n\n\t\t\t// we only loop until we hit the first valid context... generateHelp() will recurse\n\t\t\t// parent contexts for us\n\t\t\tbreak;\n\t\t}\n\t}\n};\n"],"file":"commands/help.js"} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["commands/help.js"],"names":["log","highlight","debug","styles","renderHelp","ctx","opts","file","get","path","resolve","__dirname","generateHelp","clikitHelp","hidden","options","action","_","argv","console","contexts","err","exitCode","parentContextNames","warnings","formatError","type","constructor","name","code","message","json","meta","stack","help","length","unknownCommand","Error","levenshtein","require","suggestions","commands","entries","map","cmd","desc","dist","filter","s","sort","a","b","r","localeCompare","error","Array","isArray","_stdout","_stderr","write","JSON","stringify","header","footer"],"mappings":"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","sourcesContent":["import debug from '../lib/debug';\nimport path from 'path';\n\nimport { renderFile } from '../render/template';\n\nconst { log } = debug('cli-kit:help');\nconst { highlight } = debug.styles;\n\n/**\n * Renders help for a specific context, and its parent contexts, to a string. This function is\n * passed into the selected command's `action()` as a property called `help()` so that a command\n * can render its own help output.\n *\n * @param {Context} ctx - The context to render help.\n * @param {Object} [opts] - Various options to pass into `generateHelp()`.\n * @returns {String}\n */\nexport async function renderHelp(ctx, opts) {\n\tconst file = ctx.get('helpTemplateFile', path.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));\n\tlog(`Rendering help template: ${highlight(file)}`);\n\treturn renderFile(file, await ctx.generateHelp(opts));\n}\n\n/**\n * The built-in help command parameters.\n *\n * @type {Object}\n */\nexport default {\n\t/**\n\t * Indicates this command is the built-in cli-kit help command so that if the CLI instance this\n\t * command belongs to gets added to another CLI instance, we don't copy it over.\n\t * @type {Boolean}\n\t */\n\tclikitHelp: true,\n\n\t/**\n\t * While this is a command, we don't want to show it since we already show the `--help` flag.\n\t * @type {Boolean}\n\t */\n\thidden: true,\n\n\t/**\n\t * Output the help as JSON. Neato.\n\t * @type {Object}\n\t */\n\toptions: {\n\t\t'--json': null\n\t},\n\n\t/**\n\t * Executes the help command.\n\t *\n\t * @param {Object} params - Various parameters.\n\t * @param {Object} [params.argv] - The parsed options.\n\t * @param {Array.<Context>} params.contexts - The stack of contexts found during parsing.\n\t * @param {Error} [params.err] - An error object in the event an error occurred.\n\t * @param {Function} params.exitCode - A function that sets the exit code.\n\t * @param {Array.<String>} [params.parentContextNames] - An array of parent context names.\n\t * @param {String} [params.unknownCommand] - The name of the unknown command.\n\t * @param {Array.<Error>} [params.warnings] - A list of warnings (error objects).\n\t * @returns {Promise}\n\t */\n\tasync action({ _ = [], argv = {}, console, contexts, err, exitCode, parentContextNames, warnings } = {}) {\n\t\texitCode(+!!err); // 0=success, 1=error\n\n\t\tconst formatError = err => {\n\t\t\tconst type = err && err.constructor && err.constructor.name || null;\n\t\t\treturn err ? {\n\t\t\t\tcode:    err.code,\n\t\t\t\tmessage: !argv.json && type ? `${type}: ${err.message}` : err.message,\n\t\t\t\tmeta:    err.meta,\n\t\t\t\tstack:   err.stack,\n\t\t\t\ttype\n\t\t\t} : null;\n\t\t};\n\n\t\t// skip the built-in help command and find the first context\n\t\tfor (const ctx of contexts) {\n\t\t\t// we don't display help for the help command\n\t\t\tif (ctx.clikitHelp) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// generate the help object\n\t\t\tconst help = await ctx.generateHelp({ err, parentContextNames, warnings });\n\n\t\t\t// check if we should error if passed an invalid command\n\t\t\tif (!err && _.length && (ctx.get('errorIfUnknownCommand') || argv.help)) {\n\t\t\t\tconst unknownCommand = _[0];\n\t\t\t\terr = new Error(`Unknown command \"${unknownCommand}\"`);\n\n\t\t\t\tconst levenshtein = require('fast-levenshtein');\n\t\t\t\thelp.suggestions = help.commands.entries\n\t\t\t\t\t.map(cmd => ({ name: cmd.name, desc: cmd.desc, dist: levenshtein.get(unknownCommand, cmd.name) }))\n\t\t\t\t\t.filter(s => s.dist <= 2)\n\t\t\t\t\t.sort((a, b) => {\n\t\t\t\t\t\tconst r = a.dist - b.dist;\n\t\t\t\t\t\treturn r !== 0 ? r : a.name.localeCompare(b.name);\n\t\t\t\t\t});\n\t\t\t}\n\n\t\t\thelp.error = formatError(err);\n\t\t\thelp.warnings = Array.isArray(warnings) ? warnings.map(formatError) : null;\n\n\t\t\tconst { _stdout, _stderr } = console;\n\n\t\t\t// print the help output\n\t\t\tif (argv.json) {\n\t\t\t\t_stdout.write(JSON.stringify(help, null, '  '));\n\t\t\t\t_stdout.write('\\n');\n\t\t\t} else {\n\t\t\t\tconst file = ctx.get('helpTemplateFile', path.resolve(__dirname, '..', '..', 'templates', 'help.tpl'));\n\t\t\t\tlog(`Rendering help template: ${highlight(file)}`);\n\n\t\t\t\t// only commands have a header and footer, but CLI instances do not and thus we\n\t\t\t\t// need to define them to make the template happy\n\t\t\t\tif (!help.header) {\n\t\t\t\t\thelp.header = null;\n\t\t\t\t}\n\t\t\t\tif (!help.footer) {\n\t\t\t\t\thelp.footer = null;\n\t\t\t\t}\n\n\t\t\t\t// determine the output stream\n\t\t\t\t(err ? _stderr : _stdout).write(renderFile(file, help));\n\t\t\t}\n\n\t\t\t// set the exit code\n\t\t\texitCode(err ? 1 : ctx.get('helpExitCode'));\n\n\t\t\t// we only loop until we hit the first valid context... generateHelp() will recurse\n\t\t\t// parent contexts for us\n\t\t\tbreak;\n\t\t}\n\t}\n};\n"],"file":"commands/help.js"} |
@@ -154,2 +154,3 @@ "use strict"; | ||
* | ||
* @param {Object} [opts] - Various parameters. | ||
* @returns {Promise<Object>} | ||
@@ -160,3 +161,3 @@ * @access private | ||
generateHelp() { | ||
generateHelp(opts = {}) { | ||
return this.hook('generateHelp', results => { | ||
@@ -245,3 +246,9 @@ const scopes = []; | ||
const usage = results.contexts.slice(); | ||
const usage = []; | ||
if (Array.isArray(opts.parentContextNames)) { | ||
usage.push.apply(usage, opts.parentContextNames); | ||
} | ||
usage.push.apply(usage, results.contexts.slice()); | ||
results.commands.count && usage.push('<command>'); | ||
@@ -422,2 +429,2 @@ results.options.count && usage.push('[options]'); | ||
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","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","slice","map","multiple","required","text","join","error","undefined","suggestions","warnings","get","defaultValue","value","clikit","E","INVALID_ARGUMENT","scope","ArgumentList","banner","CommandMap","ExtensionMap","lookup","Lookup","OptionMap","treatUnknownOptionsAsArguments","option","format","opts","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 * @returns {Promise<Object>}\n\t * @access private\n\t */\n\tgenerateHelp() {\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 = 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.banner     = params.banner;\n\t\tthis.commands   = new CommandMap(),\n\t\tthis.desc       = params.desc;\n\t\tthis.extensions = new ExtensionMap(),\n\t\tthis.lookup     = new Lookup(),\n\t\tthis.name       = params.name;\n\t\tthis.options    = new OptionMap();\n\t\tthis.parent     = params.parent;\n\t\tthis.rev        = 0;\n\t\tthis.title      = params.title || params.name;\n\t\tthis.treatUnknownOptionsAsArguments = !!params.treatUnknownOptionsAsArguments;\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","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","banner","CommandMap","ExtensionMap","lookup","Lookup","OptionMap","treatUnknownOptionsAsArguments","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.banner     = params.banner;\n\t\tthis.commands   = new CommandMap(),\n\t\tthis.desc       = params.desc;\n\t\tthis.extensions = new ExtensionMap(),\n\t\tthis.lookup     = new Lookup(),\n\t\tthis.name       = params.name;\n\t\tthis.options    = new OptionMap();\n\t\tthis.parent     = params.parent;\n\t\tthis.rev        = 0;\n\t\tthis.title      = params.title || params.name;\n\t\tthis.treatUnknownOptionsAsArguments = !!params.treatUnknownOptionsAsArguments;\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"} |
@@ -308,3 +308,3 @@ "use strict"; | ||
if (typeof ctx === 'function') { | ||
ctx = await ctx(); | ||
ctx = await ctx(this); | ||
} | ||
@@ -326,5 +326,5 @@ | ||
this.aliases = ctx.aliases; | ||
this.banner = ctx.banner; | ||
this.camelCase = ctx.camelCase; | ||
this.defaultCommand = ctx.defaultCommand; | ||
this.remoteHelp = ctx.remoteHelp; | ||
this.treatUnknownOptionsAsArguments = ctx.treatUnknownOptionsAsArguments; | ||
@@ -334,2 +334,3 @@ this.version = ctx.version; | ||
args: ctx.args, | ||
banner: ctx.banner, | ||
commands: ctx.commands, | ||
@@ -399,2 +400,2 @@ desc: this.desc || ctx.desc, | ||
exports.default = Extension; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/extension.js"],"names":["log","warn","highlight","debug","styles","Extension","Command","constructor","pathOrParams","params","path","E","INVALID_ARGUMENT","name","scope","value","err","exe","pkg","action","e","root","Error","INVALID_EXTENSION","JSON","stringify","main","desc","json","description","aliases","Array","isArray","includes","push","bin","primary","Object","entries","message","stderr","get","stack","p","indexOf","substring","trim","line","split","write","load","loaded","clikit","process","execPath","__argv","cmd","terminal","args","slice","findIndex","arg","type","extension","i","len","length","apply","input","spawnFn","spawn","cwd","_path","dirname","require","resolve","last","fs","existsSync","join","status","child","stdout","on","data","toString","Promise","code","NO_EXECUTABLE","ctx","__esModule","default","isCLIKitExtension","banner","camelCase","defaultCommand","treatUnknownOptionsAsArguments","version","init","commands","extensions","options","parent","title","versionOption","lookup","long","callback","exitCode","opts","next","parser","helpCommand","schema"],"mappings":"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","sourcesContent":["import Command from './command';\nimport debug from '../lib/debug';\nimport E from '../lib/errors';\nimport fs from 'fs';\nimport helpCommand from '../commands/help';\nimport _path from 'path';\n\nimport { declareCLIKitClass, filename, findPackage, isExecutable } from '../lib/util';\nimport { spawn, spawnSync } from 'child_process';\n\nconst { log, warn } = debug('cli-kit:extension');\nconst { highlight } = debug.styles;\n\n/**\n * Defines a namespace that wraps an external program or script.\n *\n * @extends {Command}\n */\nexport default class Extension extends Command {\n\t/**\n\t * Set to `true` if this extension is a cli-kit extension. It shall remain `false` for native\n\t * binaries and non-cli-kit CLI's.\n\t * @type {Boolean}\n\t */\n\tisCLIKitExtension = false;\n\n\t/**\n\t * Detects the extension defined in the specified path and initializes it.\n\t *\n\t * @param {String|Object} pathOrParams - The path to the extension or a params object. If the\n\t * path is a Node.js package with a `package.json` containing a `\"cli-kit\"` property, it will\n\t * merge the external cli-kit context tree into this namespace.\n\t * @param {Object} [params] - Various parameters when `extensionPath` is a `String`.\n\t * @param {String} [params.name] - The extension name. If not set, it will load it from the\n\t * extension's `package.json` or the filename.\n\t * @param {String} [params.path] - The path to an executable, a JavaScript file, or Node.js\n\t * package.\n\t * @access public\n\t */\n\tconstructor(pathOrParams, params) {\n\t\tlet path = null;\n\n\t\tif (typeof pathOrParams === 'string') {\n\t\t\tpath = pathOrParams;\n\t\t\tif (!params) {\n\t\t\t\tparams = {};\n\t\t\t}\n\t\t} else if (pathOrParams && typeof pathOrParams === 'object') {\n\t\t\t({ path } = params = pathOrParams);\n\t\t}\n\n\t\tif (!path || typeof path !== 'string') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected an extension path or params object', { name: 'pathOrParams', scope: 'Extension.constructor', value: pathOrParams });\n\t\t}\n\n\t\tif (typeof params !== 'object') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected extension params to be an object or Context', { name: 'params', scope: 'Extension.constructor', value: params });\n\t\t}\n\n\t\tlet { name } = params;\n\t\tlet err;\n\t\tlet exe;\n\t\tlet pkg;\n\n\t\t// we always implement our own action\n\t\tdelete params.action;\n\n\t\t// we need to determine if this extension is a binary or if it's a Node package\n\t\ttry {\n\t\t\texe = isExecutable(path);\n\t\t\tif (!name) {\n\t\t\t\tname = filename(exe[0]);\n\t\t\t}\n\t\t} catch (e) {\n\t\t\t// maybe a Node package?\n\t\t\ttry {\n\t\t\t\ttry {\n\t\t\t\t\tpkg = findPackage(path);\n\t\t\t\t\tif (!pkg.root) {\n\t\t\t\t\t\tthrow new Error();\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow E.INVALID_EXTENSION(`Invalid extension: Unable to find executable, script, or package: ${typeof path === 'string' ? `\"${path}\"` : JSON.stringify(path)}`);\n\t\t\t\t}\n\n\t\t\t\tif (!pkg.main) {\n\t\t\t\t\tthrow E.INVALID_EXTENSION(`Invalid extension: Unable to find extension's main file: ${typeof path === 'string' ? `\"${path}\"` : JSON.stringify(path)}`);\n\t\t\t\t}\n\n\t\t\t\tif (!params.desc) {\n\t\t\t\t\tparams.desc = pkg.json.description;\n\t\t\t\t}\n\n\t\t\t\tif (!name) {\n\t\t\t\t\tname = pkg.json.name;\n\t\t\t\t}\n\n\t\t\t\t// init the aliases with any aliases from the package.json\n\t\t\t\tparams.aliases = Array.isArray(pkg.json.aliases) ? pkg.json.aliases : [];\n\n\t\t\t\t// if the name is different than the one in the package.json, add it to the aliases\n\t\t\t\tif (params.name && params.name !== pkg.json.name && !params.aliases.includes(params.name)) {\n\t\t\t\t\tparams.aliases.push(params.name);\n\t\t\t\t}\n\n\t\t\t\t// if the package has a bin script that matches the package name, then add any other\n\t\t\t\t// bin name that aliases the package named bin\n\t\t\t\tif (pkg.json.bin) {\n\t\t\t\t\tconst primary = pkg.json.bin[pkg.json.name];\n\t\t\t\t\tfor (const [ name, bin ] of Object.entries(pkg.json.bin)) {\n\t\t\t\t\t\tif (bin === primary && !params.aliases.includes(name)) {\n\t\t\t\t\t\t\tparams.aliases.push(name);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\terr = e;\n\t\t\t\twarn(err.message);\n\t\t\t\twarn('Found bad extension, creating error action');\n\n\t\t\t\tparams.action = () => {\n\t\t\t\t\tconst { stderr } = this.get('terminal');\n\t\t\t\t\tif (err) {\n\t\t\t\t\t\tlet { stack } = err;\n\t\t\t\t\t\tconst p = stack.indexOf('\\n\\n');\n\t\t\t\t\t\tif (p !== -1) {\n\t\t\t\t\t\t\tstack = stack.substring(0, p).trim();\n\t\t\t\t\t\t}\n\t\t\t\t\t\tfor (const line of stack.split('\\n')) {\n\t\t\t\t\t\t\tstderr.write(`  ${line}\\n`);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tstderr.write(`Invalid extension: ${pkg.json.name}\\n`);\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\n\t\tsuper(name || filename(path), params);\n\t\tdeclareCLIKitClass(this, 'Extension');\n\n\t\tthis.err    = err;\n\t\tthis.exe    = exe;\n\t\tthis.path   = path;\n\t\tthis.pkg    = pkg;\n\t}\n\n\t/**\n\t * Loads the extension.\n\t *\n\t * @returns {Promise}\n\t * @access public\n\t */\n\tasync load() {\n\t\tif (this.loaded) {\n\t\t\treturn;\n\t\t}\n\t\tthis.loaded = true;\n\n\t\tlet { exe, pkg } = this;\n\n\t\t// if we have a JavaScript file or Node package, but not a cli-kit enabled one, then wire\n\t\t// it up to spawn Node\n\t\tif (pkg && pkg.root && !pkg.clikit) {\n\t\t\texe = this.exe = [ process.execPath, pkg.main ];\n\t\t}\n\n\t\tif (exe) {\n\t\t\tthis.action = async ({ __argv, cmd, terminal }) => {\n\t\t\t\tif (Array.isArray(this.exe)) {\n\t\t\t\t\tconst exe = this.exe[0];\n\t\t\t\t\tconst args = this.exe.slice(1);\n\t\t\t\t\tconst p = __argv.findIndex(arg => arg && arg.type === 'extension' && arg.extension === cmd);\n\n\t\t\t\t\tif (p !== -1) {\n\t\t\t\t\t\tfor (let i = p + 1, len = __argv.length; i < len; i++) {\n\t\t\t\t\t\t\targs.push.apply(args, __argv[i].input);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet spawnFn = spawn;\n\n\t\t\t\t\t// check if node-pty exists and that it's compiled for this version of Node.js\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet cwd = _path.dirname(require.resolve('node-pty-prebuilt-multiarch'));\n\t\t\t\t\t\tfor (let last; cwd !== last && !fs.existsSync(_path.join(cwd, 'package.json')); last = cwd, cwd = _path.dirname(cwd)) {}\n\n\t\t\t\t\t\tconst { status } = spawnSync(process.execPath, [\n\t\t\t\t\t\t\t'-e',\n\t\t\t\t\t\t\t'try { require(\\'node-pty-prebuilt-multiarch\\') } catch (e) { process.exit(e.message.includes(\\'NODE_MODULE_VERSION\\') ? 2 : 1) }'\n\t\t\t\t\t\t], { cwd });\n\n\t\t\t\t\t\tif (status !== 1) {\n\t\t\t\t\t\t\t// node-pty exists!\n\t\t\t\t\t\t\tif (status === 2) {\n\t\t\t\t\t\t\t\t// but it's the wrong Node version, rebuild\n\t\t\t\t\t\t\t\twarn(`node-pty built for different Node version, rebuilding: ${highlight(cwd)}`);\n\t\t\t\t\t\t\t\tspawnSync('npm', [ 'rebuild' ], { cwd });\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tspawnFn = require('node-pty-prebuilt-multiarch').spawn;\n\t\t\t\t\t\t}\n\n\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t// not installed\n\t\t\t\t\t}\n\n\t\t\t\t\t// spawn the process\n\t\t\t\t\tlog(`Running: ${highlight(`${exe} ${args.join(' ')}`)}`);\n\t\t\t\t\tconst child = spawnFn(exe, args);\n\t\t\t\t\tif (spawnFn === spawn) {\n\t\t\t\t\t\t// if we're using the built-in spawn, then we need to manually stream the\n\t\t\t\t\t\t// stdio output instead of pipe() because we don't want the child process\n\t\t\t\t\t\t// to close the terminal streams\n\t\t\t\t\t\tchild.stdout.on('data', data => terminal.stdout.write(data.toString()));\n\t\t\t\t\t\tchild.stderr.on('data', data => terminal.stderr.write(data.toString()));\n\t\t\t\t\t}\n\t\t\t\t\tchild.on('data', terminal.stdout.write);\n\t\t\t\t\tawait new Promise(resolve => child.on('close', (code = 0) => resolve({ code })));\n\t\t\t\t} else {\n\t\t\t\t\tthrow E.NO_EXECUTABLE(`Extension \"${this.name}\" has no executable!`);\n\t\t\t\t}\n\t\t\t};\n\n\t\t} else if (pkg && pkg.clikit) {\n\t\t\t// we have a Node package, so require it and see what we have\n\t\t\tlog(`Requiring ${highlight(pkg.main)}`);\n\n\t\t\tlet ctx;\n\t\t\ttry {\n\t\t\t\tctx = require(pkg.main);\n\t\t\t\tif (!ctx || (typeof ctx !== 'object' && typeof ctx !== 'function')) {\n\t\t\t\t\tthrow new Error('Extension must export an object or function');\n\t\t\t\t}\n\t\t\t} catch (err) {\n\t\t\t\tthrow E.INVALID_EXTENSION(`Bad extension \"${this.name}\": ${err.message}`, { name: this.name, path: this, scope: 'Extension.load', value: err });\n\t\t\t}\n\n\t\t\t// if this is an ES6 module, grab the default export\n\t\t\tif (ctx.__esModule) {\n\t\t\t\tctx = ctx.default;\n\t\t\t}\n\n\t\t\t// if the export was a function, call it now to get its CLI definition\n\t\t\ttry {\n\t\t\t\tif (typeof ctx === 'function') {\n\t\t\t\t\tctx = await ctx();\n\t\t\t\t}\n\n\t\t\t\tif (!ctx || typeof ctx !== 'object') {\n\t\t\t\t\tthrow new Error('Extension does not resolve an object');\n\t\t\t\t}\n\t\t\t} catch (err) {\n\t\t\t\tthrow E.INVALID_EXTENSION(`Bad extension \"${this.name}\": ${err.message}`, { name: this.name, path: this, scope: 'Extension.load', value: err });\n\t\t\t}\n\n\t\t\tthis.isCLIKitExtension = true;\n\n\t\t\tthis.aliases        = ctx.aliases;\n\t\t\tthis.banner         = ctx.banner;\n\t\t\tthis.camelCase      = ctx.camelCase;\n\t\t\tthis.defaultCommand = ctx.defaultCommand;\n\t\t\tthis.treatUnknownOptionsAsArguments = ctx.treatUnknownOptionsAsArguments;\n\t\t\tthis.version        = ctx.version;\n\n\t\t\tthis.init({\n\t\t\t\targs:       ctx.args,\n\t\t\t\tcommands:   ctx.commands,\n\t\t\t\tdesc:       this.desc || ctx.desc,\n\t\t\t\textensions: ctx.extensions,\n\t\t\t\tname:       this.name || ctx.name,\n\t\t\t\toptions:    ctx.options,\n\t\t\t\tparent:     this.parent,\n\t\t\t\ttitle:      ctx.title !== 'Global' && ctx.title || this.name\n\t\t\t});\n\n\t\t\tconst versionOption = this.version && this.lookup.long.version;\n\t\t\tif (versionOption && typeof versionOption.callback !== 'function') {\n\t\t\t\tversionOption.callback = async ({ exitCode, opts, next }) => {\n\t\t\t\t\tif (await next()) {\n\t\t\t\t\t\tlet version = this.version;\n\t\t\t\t\t\tif (typeof version === 'function') {\n\t\t\t\t\t\t\tversion = await version(opts);\n\t\t\t\t\t\t}\n\t\t\t\t\t\t(opts.terminal || this.get('terminal')).stdout.write(`${version}\\n`);\n\t\t\t\t\t\texitCode(0);\n\t\t\t\t\t\treturn false;\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tif (typeof ctx.action === 'function') {\n\t\t\t\tthis.action = ctx.action;\n\t\t\t} else {\n\t\t\t\tthis.action = parser => {\n\t\t\t\t\tif (this.defaultCommand !== 'help' || !this.get('help')) {\n\t\t\t\t\t\tconst cmd = this.defaultCommand && this.commands[this.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\treturn helpCommand.action(parser);\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Returns the schema for this extension and all child contexts.\n\t *\n\t * @returns {Object}\n\t * @access public\n\t */\n\tschema() {\n\t\treturn {\n\t\t\t...super.schema,\n\t\t\tpath: this.path\n\t\t};\n\t}\n}\n"],"file":"parser/extension.js"} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["parser/extension.js"],"names":["log","warn","highlight","debug","styles","Extension","Command","constructor","pathOrParams","params","path","E","INVALID_ARGUMENT","name","scope","value","err","exe","pkg","action","e","root","Error","INVALID_EXTENSION","JSON","stringify","main","desc","json","description","aliases","Array","isArray","includes","push","bin","primary","Object","entries","message","stderr","get","stack","p","indexOf","substring","trim","line","split","write","load","loaded","clikit","process","execPath","__argv","cmd","terminal","args","slice","findIndex","arg","type","extension","i","len","length","apply","input","spawnFn","spawn","cwd","_path","dirname","require","resolve","last","fs","existsSync","join","status","child","stdout","on","data","toString","Promise","code","NO_EXECUTABLE","ctx","__esModule","default","isCLIKitExtension","camelCase","defaultCommand","remoteHelp","treatUnknownOptionsAsArguments","version","init","banner","commands","extensions","options","parent","title","versionOption","lookup","long","callback","exitCode","opts","next","parser","helpCommand","schema"],"mappings":"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","sourcesContent":["import Command from './command';\nimport debug from '../lib/debug';\nimport E from '../lib/errors';\nimport fs from 'fs';\nimport helpCommand from '../commands/help';\nimport _path from 'path';\n\nimport { declareCLIKitClass, filename, findPackage, isExecutable } from '../lib/util';\nimport { spawn, spawnSync } from 'child_process';\n\nconst { log, warn } = debug('cli-kit:extension');\nconst { highlight } = debug.styles;\n\n/**\n * Defines a namespace that wraps an external program or script.\n *\n * @extends {Command}\n */\nexport default class Extension extends Command {\n\t/**\n\t * Set to `true` if this extension is a cli-kit extension. It shall remain `false` for native\n\t * binaries and non-cli-kit CLI's.\n\t * @type {Boolean}\n\t */\n\tisCLIKitExtension = false;\n\n\t/**\n\t * Detects the extension defined in the specified path and initializes it.\n\t *\n\t * @param {String|Object} pathOrParams - The path to the extension or a params object. If the\n\t * path is a Node.js package with a `package.json` containing a `\"cli-kit\"` property, it will\n\t * merge the external cli-kit context tree into this namespace.\n\t * @param {Object} [params] - Various parameters when `extensionPath` is a `String`.\n\t * @param {String} [params.name] - The extension name. If not set, it will load it from the\n\t * extension's `package.json` or the filename.\n\t * @param {String} [params.path] - The path to an executable, a JavaScript file, or Node.js\n\t * package.\n\t * @access public\n\t */\n\tconstructor(pathOrParams, params) {\n\t\tlet path = null;\n\n\t\tif (typeof pathOrParams === 'string') {\n\t\t\tpath = pathOrParams;\n\t\t\tif (!params) {\n\t\t\t\tparams = {};\n\t\t\t}\n\t\t} else if (pathOrParams && typeof pathOrParams === 'object') {\n\t\t\t({ path } = params = pathOrParams);\n\t\t}\n\n\t\tif (!path || typeof path !== 'string') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected an extension path or params object', { name: 'pathOrParams', scope: 'Extension.constructor', value: pathOrParams });\n\t\t}\n\n\t\tif (typeof params !== 'object') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected extension params to be an object or Context', { name: 'params', scope: 'Extension.constructor', value: params });\n\t\t}\n\n\t\tlet { name } = params;\n\t\tlet err;\n\t\tlet exe;\n\t\tlet pkg;\n\n\t\t// we always implement our own action\n\t\tdelete params.action;\n\n\t\t// we need to determine if this extension is a binary or if it's a Node package\n\t\ttry {\n\t\t\texe = isExecutable(path);\n\t\t\tif (!name) {\n\t\t\t\tname = filename(exe[0]);\n\t\t\t}\n\t\t} catch (e) {\n\t\t\t// maybe a Node package?\n\t\t\ttry {\n\t\t\t\ttry {\n\t\t\t\t\tpkg = findPackage(path);\n\t\t\t\t\tif (!pkg.root) {\n\t\t\t\t\t\tthrow new Error();\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow E.INVALID_EXTENSION(`Invalid extension: Unable to find executable, script, or package: ${typeof path === 'string' ? `\"${path}\"` : JSON.stringify(path)}`);\n\t\t\t\t}\n\n\t\t\t\tif (!pkg.main) {\n\t\t\t\t\tthrow E.INVALID_EXTENSION(`Invalid extension: Unable to find extension's main file: ${typeof path === 'string' ? `\"${path}\"` : JSON.stringify(path)}`);\n\t\t\t\t}\n\n\t\t\t\tif (!params.desc) {\n\t\t\t\t\tparams.desc = pkg.json.description;\n\t\t\t\t}\n\n\t\t\t\tif (!name) {\n\t\t\t\t\tname = pkg.json.name;\n\t\t\t\t}\n\n\t\t\t\t// init the aliases with any aliases from the package.json\n\t\t\t\tparams.aliases = Array.isArray(pkg.json.aliases) ? pkg.json.aliases : [];\n\n\t\t\t\t// if the name is different than the one in the package.json, add it to the aliases\n\t\t\t\tif (params.name && params.name !== pkg.json.name && !params.aliases.includes(params.name)) {\n\t\t\t\t\tparams.aliases.push(params.name);\n\t\t\t\t}\n\n\t\t\t\t// if the package has a bin script that matches the package name, then add any other\n\t\t\t\t// bin name that aliases the package named bin\n\t\t\t\tif (pkg.json.bin) {\n\t\t\t\t\tconst primary = pkg.json.bin[pkg.json.name];\n\t\t\t\t\tfor (const [ name, bin ] of Object.entries(pkg.json.bin)) {\n\t\t\t\t\t\tif (bin === primary && !params.aliases.includes(name)) {\n\t\t\t\t\t\t\tparams.aliases.push(name);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\terr = e;\n\t\t\t\twarn(err.message);\n\t\t\t\twarn('Found bad extension, creating error action');\n\n\t\t\t\tparams.action = () => {\n\t\t\t\t\tconst { stderr } = this.get('terminal');\n\t\t\t\t\tif (err) {\n\t\t\t\t\t\tlet { stack } = err;\n\t\t\t\t\t\tconst p = stack.indexOf('\\n\\n');\n\t\t\t\t\t\tif (p !== -1) {\n\t\t\t\t\t\t\tstack = stack.substring(0, p).trim();\n\t\t\t\t\t\t}\n\t\t\t\t\t\tfor (const line of stack.split('\\n')) {\n\t\t\t\t\t\t\tstderr.write(`  ${line}\\n`);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tstderr.write(`Invalid extension: ${pkg.json.name}\\n`);\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\n\t\tsuper(name || filename(path), params);\n\t\tdeclareCLIKitClass(this, 'Extension');\n\n\t\tthis.err    = err;\n\t\tthis.exe    = exe;\n\t\tthis.path   = path;\n\t\tthis.pkg    = pkg;\n\t}\n\n\t/**\n\t * Loads the extension.\n\t *\n\t * @returns {Promise}\n\t * @access public\n\t */\n\tasync load() {\n\t\tif (this.loaded) {\n\t\t\treturn;\n\t\t}\n\t\tthis.loaded = true;\n\n\t\tlet { exe, pkg } = this;\n\n\t\t// if we have a JavaScript file or Node package, but not a cli-kit enabled one, then wire\n\t\t// it up to spawn Node\n\t\tif (pkg && pkg.root && !pkg.clikit) {\n\t\t\texe = this.exe = [ process.execPath, pkg.main ];\n\t\t}\n\n\t\tif (exe) {\n\t\t\tthis.action = async ({ __argv, cmd, terminal }) => {\n\t\t\t\tif (Array.isArray(this.exe)) {\n\t\t\t\t\tconst exe = this.exe[0];\n\t\t\t\t\tconst args = this.exe.slice(1);\n\t\t\t\t\tconst p = __argv.findIndex(arg => arg && arg.type === 'extension' && arg.extension === cmd);\n\n\t\t\t\t\tif (p !== -1) {\n\t\t\t\t\t\tfor (let i = p + 1, len = __argv.length; i < len; i++) {\n\t\t\t\t\t\t\targs.push.apply(args, __argv[i].input);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet spawnFn = spawn;\n\n\t\t\t\t\t// check if node-pty exists and that it's compiled for this version of Node.js\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet cwd = _path.dirname(require.resolve('node-pty-prebuilt-multiarch'));\n\t\t\t\t\t\tfor (let last; cwd !== last && !fs.existsSync(_path.join(cwd, 'package.json')); last = cwd, cwd = _path.dirname(cwd)) {}\n\n\t\t\t\t\t\tconst { status } = spawnSync(process.execPath, [\n\t\t\t\t\t\t\t'-e',\n\t\t\t\t\t\t\t'try { require(\\'node-pty-prebuilt-multiarch\\') } catch (e) { process.exit(e.message.includes(\\'NODE_MODULE_VERSION\\') ? 2 : 1) }'\n\t\t\t\t\t\t], { cwd });\n\n\t\t\t\t\t\tif (status !== 1) {\n\t\t\t\t\t\t\t// node-pty exists!\n\t\t\t\t\t\t\tif (status === 2) {\n\t\t\t\t\t\t\t\t// but it's the wrong Node version, rebuild\n\t\t\t\t\t\t\t\twarn(`node-pty built for different Node version, rebuilding: ${highlight(cwd)}`);\n\t\t\t\t\t\t\t\tspawnSync('npm', [ 'rebuild' ], { cwd });\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tspawnFn = require('node-pty-prebuilt-multiarch').spawn;\n\t\t\t\t\t\t}\n\n\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t// not installed\n\t\t\t\t\t}\n\n\t\t\t\t\t// spawn the process\n\t\t\t\t\tlog(`Running: ${highlight(`${exe} ${args.join(' ')}`)}`);\n\t\t\t\t\tconst child = spawnFn(exe, args);\n\t\t\t\t\tif (spawnFn === spawn) {\n\t\t\t\t\t\t// if we're using the built-in spawn, then we need to manually stream the\n\t\t\t\t\t\t// stdio output instead of pipe() because we don't want the child process\n\t\t\t\t\t\t// to close the terminal streams\n\t\t\t\t\t\tchild.stdout.on('data', data => terminal.stdout.write(data.toString()));\n\t\t\t\t\t\tchild.stderr.on('data', data => terminal.stderr.write(data.toString()));\n\t\t\t\t\t}\n\t\t\t\t\tchild.on('data', terminal.stdout.write);\n\t\t\t\t\tawait new Promise(resolve => child.on('close', (code = 0) => resolve({ code })));\n\t\t\t\t} else {\n\t\t\t\t\tthrow E.NO_EXECUTABLE(`Extension \"${this.name}\" has no executable!`);\n\t\t\t\t}\n\t\t\t};\n\n\t\t} else if (pkg && pkg.clikit) {\n\t\t\t// we have a Node package, so require it and see what we have\n\t\t\tlog(`Requiring ${highlight(pkg.main)}`);\n\n\t\t\tlet ctx;\n\t\t\ttry {\n\t\t\t\tctx = require(pkg.main);\n\t\t\t\tif (!ctx || (typeof ctx !== 'object' && typeof ctx !== 'function')) {\n\t\t\t\t\tthrow new Error('Extension must export an object or function');\n\t\t\t\t}\n\t\t\t} catch (err) {\n\t\t\t\tthrow E.INVALID_EXTENSION(`Bad extension \"${this.name}\": ${err.message}`, { name: this.name, path: this, scope: 'Extension.load', value: err });\n\t\t\t}\n\n\t\t\t// if this is an ES6 module, grab the default export\n\t\t\tif (ctx.__esModule) {\n\t\t\t\tctx = ctx.default;\n\t\t\t}\n\n\t\t\t// if the export was a function, call it now to get its CLI definition\n\t\t\ttry {\n\t\t\t\tif (typeof ctx === 'function') {\n\t\t\t\t\tctx = await ctx(this);\n\t\t\t\t}\n\n\t\t\t\tif (!ctx || typeof ctx !== 'object') {\n\t\t\t\t\tthrow new Error('Extension does not resolve an object');\n\t\t\t\t}\n\t\t\t} catch (err) {\n\t\t\t\tthrow E.INVALID_EXTENSION(`Bad extension \"${this.name}\": ${err.message}`, { name: this.name, path: this, scope: 'Extension.load', value: err });\n\t\t\t}\n\n\t\t\tthis.isCLIKitExtension = true;\n\n\t\t\tthis.aliases        = ctx.aliases;\n\t\t\tthis.camelCase      = ctx.camelCase;\n\t\t\tthis.defaultCommand = ctx.defaultCommand;\n\t\t\tthis.remoteHelp     = ctx.remoteHelp;\n\t\t\tthis.treatUnknownOptionsAsArguments = ctx.treatUnknownOptionsAsArguments;\n\t\t\tthis.version        = ctx.version;\n\n\t\t\tthis.init({\n\t\t\t\targs:       ctx.args,\n\t\t\t\tbanner:     ctx.banner,\n\t\t\t\tcommands:   ctx.commands,\n\t\t\t\tdesc:       this.desc || ctx.desc,\n\t\t\t\textensions: ctx.extensions,\n\t\t\t\tname:       this.name || ctx.name,\n\t\t\t\toptions:    ctx.options,\n\t\t\t\tparent:     this.parent,\n\t\t\t\ttitle:      ctx.title !== 'Global' && ctx.title || this.name\n\t\t\t});\n\n\t\t\tconst versionOption = this.version && this.lookup.long.version;\n\t\t\tif (versionOption && typeof versionOption.callback !== 'function') {\n\t\t\t\tversionOption.callback = async ({ exitCode, opts, next }) => {\n\t\t\t\t\tif (await next()) {\n\t\t\t\t\t\tlet version = this.version;\n\t\t\t\t\t\tif (typeof version === 'function') {\n\t\t\t\t\t\t\tversion = await version(opts);\n\t\t\t\t\t\t}\n\t\t\t\t\t\t(opts.terminal || this.get('terminal')).stdout.write(`${version}\\n`);\n\t\t\t\t\t\texitCode(0);\n\t\t\t\t\t\treturn false;\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tif (typeof ctx.action === 'function') {\n\t\t\t\tthis.action = ctx.action;\n\t\t\t} else {\n\t\t\t\tthis.action = parser => {\n\t\t\t\t\tif (this.defaultCommand !== 'help' || !this.get('help')) {\n\t\t\t\t\t\tconst cmd = this.defaultCommand && this.commands[this.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\treturn helpCommand.action(parser);\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Returns the schema for this extension and all child contexts.\n\t *\n\t * @returns {Object}\n\t * @access public\n\t */\n\tschema() {\n\t\treturn {\n\t\t\t...super.schema,\n\t\t\tpath: this.path\n\t\t};\n\t}\n}\n"],"file":"parser/extension.js"} |
{ | ||
"name": "cli-kit", | ||
"version": "1.0.0", | ||
"version": "1.0.1", | ||
"description": "Everything you need to create awesome command line interfaces", | ||
@@ -45,3 +45,3 @@ "main": "./dist/index.js", | ||
"fs-extra": "^9.0.0", | ||
"hook-emitter": "^4.0.2", | ||
"hook-emitter": "^4.1.0", | ||
"lodash.camelcase": "^4.3.0", | ||
@@ -51,3 +51,3 @@ "pkg-dir": "^4.2.0", | ||
"semver": "^7.3.2", | ||
"snooplogg": "^2.3.3", | ||
"snooplogg": "^3.0.0", | ||
"source-map-support": "^0.5.19", | ||
@@ -71,3 +71,3 @@ "which": "^2.0.2", | ||
"esdoc-standard-plugin": "^1.0.0", | ||
"eslint": "^6.8.0", | ||
"eslint": "^7.0.0", | ||
"eslint-plugin-chai-expect": "^2.1.0", | ||
@@ -74,0 +74,0 @@ "eslint-plugin-mocha": "^6.3.0", |
Sorry, the diff of this file is too big to display
556986
6012
+ Addedchalk@4.1.2(transitive)
+ Addedsnooplogg@3.0.2(transitive)
+ Addedsupports-color@8.1.1(transitive)
- Removedchalk@3.0.0(transitive)
- Removedsnooplogg@2.3.3(transitive)
Updatedhook-emitter@^4.1.0
Updatedsnooplogg@^3.0.0