resolve-cli-args
v1.1.1
Published
A simple function to resolve cli arguments.
Downloads
120
Readme
resolve-cli-args
A simple function to resolve cli arguments.
Install
npm i resolve-cli-args
Usage
import { resolveCliArgs } from 'resolve-cli-args'
const { args } = resolveCliArgs(process.argv.slice(2))
if (args['--help'] || args['-h']) {
// print help message
}
The type of the return value is:
export interface ResolvedCliArgs {
/**
* An object containing argument names and their values.
*/
args: Record<string, string[] | undefined>
/**
* A list of values without option names.
*/
unnamedValues: string[]
}
If the option do not have any values, the value of this option will be set to an empty array.
Examples
import { resolveCliArgs } from 'resolve-cli-args'
const print = (value: string) => {
const argv = value.split(' ')
const resolved = resolveCliArgs(argv)
console.log(resolved)
}
print('--config config.json input.txt output.txt')
// {
// args: { '--config': [ 'config.json' ] },
// unnamedValues: [ 'input`.txt', 'output.txt' ]
// }
print('--log-level=2 --type typescript')
// {
// args: { '--log-level': [ '2' ], '--type': [ 'typescript' ] },
// unnamedValues: []
// }
print('--compress -q')
// { args: { '--compress': [], '-q': [] }, unnamedValues: [] }
print('--a 1 a --b 2 b --c=3 c')
// {
// args: { '--a': [ '1' ], '--b': [ '2' ], '--c': [ '3' ] },
// unnamedValues: [ 'a', 'b', 'c' ]
// }
print('--ext=.js --ext=.ts --ext .jsx --ext .tsx')
// {
// args: { '--ext': [ '.js', '.ts', '.jsx', '.tsx' ] },
// unnamedValues: []
// }
print('--var=a=b --var ---c=d')
// { args: { '--var': [ 'a=b', '---c=d' ] }, unnamedValues: [] }
print('--a=1 -- --c=d -e f')
// {
// args: { '--a': [ '1' ], '--': [ '--c=d', '-e', 'f' ] },
// unnamedValues: []
// }
Note: The string that starts with
"--"
or"-"
will be treated as option name (not including the string that starts with"---"
).