A Node library to parse commands of structure:
cmd [global-options] [command] [command-options] [arguments]
Can be used for simple argument parsing too:
cmd [options] [arguments]
Was primarily written after getting disillusioned by existing libraries like commander.js. This aims to be the cli parsing library that Node deserves.
npm install wiz-cliparse --save
yarn:
yarn add wiz-cliparse
var Program = require('wiz-cliparse');
// Defining the program and its global options:
var prg = new Program('mycli',
'short description.', // required.
'[global-options] [command] [command-options] [arguments]', // usage. for rendering help o/p. optional.
'long description.'); // optional.
prg.addOpt('v', // short form. Usage: -v
'verbose', // long form. Usage: --verbose
'enable verbose output.'); // description.
// Adding commands and their options:
var cmdA = prg.addCmd('abc', // command name.
'abc command short description.', // required.
'[-c, --comprehensive]', // usage. for rendering help o/p. optional.
'abc command long description.'); // optional.
cmdA.addOpt('c', 'comprehensive', 'comprehensive details.');
var cmdX = prg.addCmd('xyz', null, 'xyz command.');
// Parsing:
// 1. Success:
var res = prg.parse(['-v', 'abc', '-c', 'arg1', 'arg2']);
console.log(res.gopts.has('v')); // prints `true`
console.log(res.cmd); // prints `abc`
console.log(res.opts.has('c')); // prints `true`
console.log(res.opts.has('comprehensive')); // prints `true`
console.log(res.args); // prints `['arg1', 'arg2']`
// 2. Failures:
// Will throw error:
prg.parse(['-x']); // Unrecognized global option: x.
prg.parse(['def']); // Unrecognized command: def.
prg.parse(['abc', '--frugal']); // Unrecognized option frugal for command abc.
Has following elements:
cmd
(String): The command that was called.gopts
(Set): Global options. Has both the short and long options.opts
(Set): Command options. Has both the short and long options.goptArg
(Map): A map of arguments to global options.optArg
(Map): A map of arguments to command options.args
(Array): List of arguments.
For developers who don't like using try/catch
:
prg.parseCb(['abc'], function(res, err){
if(err) { // Error object
console.error(err.message);
}
else {
// do your logic here!
}
});
var res = prg.parse();
For callback:
prg.parseCb(null, function(res, err){/*...*/});
It is possible to combine multiple short options as one. For example, instead of giving -a -b
, it can be given as -ab
.
Options can have configurations:
prg.addOpt('x', 'exception', 'print exception trace.',
{
isMandatory: true,
hasArg: true,
defaultArg: 'X',
multiArg: true,
noMandatoryOptCheck: true
});
Both global and command option can have these configurations:
isMandatory
: Is a mandatory option. Check will happen in all cases except one: whenhelp
option / command is passed. We wanthelp
to be accessible even when mandatory option is not provided.hasArg
: Option has argument.defaultArg
: Default value to assign when an when an option supporting argument is not passed argument.multiArg
: Support multiple arguments like-H value1 -H value2
.noMandatoryOptCheck
: When few options like-v
(version) /-h
(help) is passed, mandatory option check should not be performed. Use along with similar options.
defaultArg
and multiArg
will be ignored if hasArg
is not set to true
.
For global option:
if(res.gopts.has('s')) {
var arg = res.goptArg.get('s'); // or:
arg = res.goptArg.get('long');
}
For command option:
if(res.opts.has('s')) {
var arg = res.optArg.get('s'); // or:
arg = res.optArg.get('long');
}
Note, both the retrievals above will return an array if the option multiArg
is set to true
. Otherwise, it returns the last string that is set.
To add help option -h, --help
:
prg.addHelpOpt();
To add help command:
prg.addHelpCmd();
To add both help option and command:
prg.addHelp();
All the three above commands accept a optional description
string to override the default short description.
// ...
prg.addHelp();
// ...
var res = prg.parse(/*...*/);
// From option:
if(res.gopts.has('h') || res.cmd === 'help') {
prg.printHelp(res); // or:
prg.printHelp(res, console.error); // if you want to print help in STDERR.
process.exit();
}
This prints context sensitive help also. For example, cmd help mycmd
, will print detailed help about mycmd
. The order of printing help:
- Short description.
- Usage (if available).
- Long description (if available).
- Options (if available).