This statement:
const argsObj = require('command-line-parser')();
returns this argsObj object:
{
v: true,
debug: true,
host: 'there.com',
port: '8081',
_args: [ 'myfile1', 'myfile2' ]
}
when invoked with:
node ./myscript.js myfile1 -v -debug -host there.com -port 8081 myfile2
This simple lightweight module exports a default function that takes an array of command-line arguments and returns a parsed object (a bit simpler than the venerable minimist or commander).
A key argument (starts with a dash) looks to the next argument for a value, such as -foo bar. If foo does not find a value, a default value of true will be set.
There's a few ways in which foo might not find a value:
- the following argument also starts with a dash, as in
-foo -hey - there are no more arguments
foois set inbooleanKeysof config (an optional argument):
const argsObj = require('command-line-parser')({
booleanKeys: [ 'foo' ]
});
A key with multiple leading dashes such as --debug will be the same as -debug (with the exception of overriding the optional argument allowKeyGrouping described below).
A key with embedded dashes or spaces will be converted to camelCase from camel-case.
Arguments that don't fulfill the role of a key or a value will be added in an array to a key called _args in the parsed object.
To avoid any arguments intended for _args from becoming the unintentional value of a preceding boolean key, either specify that boolean key in booleanKeys of config, or follow that boolean key with a placeholder argument such as a single - or double dash -- on the command line.
node ./myscript.js -d -- foo1 foo2 foo3
Instead of having to separate a numerical argument from its key:
node ./myscript.js -n 8
it may be embedded in the key:
node ./myscript.js -n8
by setting allowEmbeddedValues in the config:
const argsObj = require('command-line-parser')({
allowEmbeddedValues: true
});
to give the result
{
n: 8
}
To parse a leading-dash argument such as -abc as single-letter keys instead of one multi-letter key, then set allowKeyGrouping in config so that
node ./myscript.js -abc
when parsed by
const argsObj = require('command-line-parser')({
allowKeyGrouping: true
});
gives the result
{
a: true,
b: true,
c: true
}
allowKeyGrouping can be overridden on the command-line by prefixing the argument with double-dashes, so that
node ./myscript.js --abc
becomes
{
abc: true
}
An optional configuration object may be passed in that will override these default values:
const argsObj = require('command-line-parser')({
args = process.argv.slice(2), // skip the binary and script file args
booleanKeys = [],
allowKeyGrouping: false,
allowEmbeddedValues: false
});
Install with npm install command-line-parser.
Test via npm test (and see test/index.js for some examples).
This is a common pattern using destructuring assignment (available in ES6 or via Babel) which can be useful here, especially with default values, and perhaps renaming _args:
const {
v,
debug = false,
host = 'default.com',
port = '80',
_args: files = []
} = argsObj ;
will assign the locally scoped constant variables v, debug, host, port, and files.