Package Exports
- argv-split
- argv-split/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (argv-split) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
argv-split
Split argv(argument vector) and handle special cases, such as quoted or escaped values.
Why?
const split = require('split')
const mkdir = 'mkdir "foo bar"'
mkdir.split(' ') // ['mkdir', '"foo', 'bar"'] -> Oops!
split(mkdir) // ['mkdir', 'foo bar'] -> Oh yeah!
const mkdir2 = 'mkdir foo\\ bar'.split(' ')
mkdir2.split(' ') // ['mkdir', 'foo\\', 'bar'] -> Oops!
split(mkdir2) // ['mkdir', 'foo bar'] -> Oh yeah!
argv-split
handles all special cases with complete unit tests.
# shell command: javascript array:
foo a\ b # ['foo', 'a b']
foo \' # ['foo', '\\\'']
foo \" # ['foo', '\\"']
foo "a b" # ['foo', 'a b']
foo "a\ b" # ['foo', 'a\\ b']
foo '\' # ['foo', '\\']
foo --abc="a b" # ['foo', '--abc=a b']
foo --abc=a\ b # ['foo', '--abc=a b']
# argv-split also handles line feeds
foo \
--abc=a\ b # ['foo', '--abc=a b']
# etc
split('foo \\\n --abc=a\\ b') // ['foo', '--abc=a b']
Error Codes
UNMATCHED_SINGLE
If a command missed the closing single quote, the error will throw:
Shell command:
foo --abc 'abc
try {
split('foo --abc \'abc')
} catch (e) {
console.log(e.code) // 'UNMATCHED_SINGLE'
}
UNMATCHED_DOUBLE
If a command missed the closing double quote, the error will throw:
foo --abc "abc
ESCAPED_EOF
If a command unexpectedly ends with a \
, the error will throw:
foo --abc a\# if there is nothing after \, the error will throw
foo --abc a\ # if there is a whitespace after, then -> ['foo', '--abc', 'a ']
NON_STRING
If the argument passed to split
is not a string, the error will throw
split(undefined)
Install
$ npm i argv-split
Methods
split(string) -> Array
Splits a string, and balance quoted parts. The usage is quite simple, see examples above.
Returns Array<string>
split.join(args, options?) -> string
Join the given array of argument vectors into a valid argument string
New in 3.1.0
- args
Array<string>
arguments to be joined - options?
Object=
- quote
string="
should we use single quote or double quote when a certain argument needs to be quoted. Defaults to"
- quote
'command ' + join(['foo "bar', "'baz"])
// command "foo \"bar" "'baz"
Handle Line Feeds
There is a special value of split.LF
which could help us to create valid commands with line feeds:
'kubectl' + join(['apply', '--prune', '-f', 'manifest.yaml', split.LF, '-l', 'app=nginx'])
// kubectl apply --prune -f manifest.yaml \
// -l app=nginx
License
MIT