-
Couldn't load subscription status.
- Fork 123
Description
Related: yargs/yargs#1599
Boolean options have this special property:
If a non-flag option - unless
trueorfalse- followskeyinprocess.argv, that string won’t get set as the value ofkey.
This means that if a CLI defines an option as a boolean, it isn't currently possible to later change that option to support more choices than true or false without creating a breaking change for the CLI's interface.
In other words, this happens currently:
require('yargs-parser')('--foo bar')
> { _: [], foo: 'bar' }
require('yargs-parser')('--foo bar', { boolean: ['foo'] })
> { _: [ 'bar' ], foo: true }If the choices option were handled already in the parser, it'd be possible to (optionally?) allow similar behaviour for it:
require('yargs-parser')('--foo bar', {
choices: ['true', 'false', 'maybe'], // not a current parser option
default: { foo: 'maybe' }
})
> { _: [ 'bar' ], foo: 'maybe' }A similar result could also be achieved if the coerce function could indicate that the given value should not be consumed for the current key, but parsed independently:
require('yargs-parser')('--foo bar', {
coerce: {
foo(value) {
if (['true', 'false', 'maybe'].includes(value) return value
this.doNotEat() // not currently defined; could also be an argument
return 'maybe'
}
}
})
> { _: [ 'bar' ], foo: 'maybe' }