diff options
author | LinuxWizard42 <computerwizard@linuxmail.org> | 2022-10-12 22:54:37 +0300 |
---|---|---|
committer | LinuxWizard42 <computerwizard@linuxmail.org> | 2022-10-12 22:54:37 +0300 |
commit | 703e03aba33f234712206769f57717ba7d92d23d (patch) | |
tree | 0041f04ccb75bd5379c764e9fe42249fffe75fc3 /node_modules/dashdash/CHANGES.md | |
parent | ab6e257e6e9d9a483d7e86f220d8b209a2cd7753 (diff) | |
download | FlashRunner-703e03aba33f234712206769f57717ba7d92d23d.tar.gz FlashRunner-703e03aba33f234712206769f57717ba7d92d23d.tar.zst |
Added export_allowed file to make repository visible in cgit
Diffstat (limited to 'node_modules/dashdash/CHANGES.md')
-rw-r--r-- | node_modules/dashdash/CHANGES.md | 364 |
1 files changed, 364 insertions, 0 deletions
diff --git a/node_modules/dashdash/CHANGES.md b/node_modules/dashdash/CHANGES.md new file mode 100644 index 0000000..d7c8f4e --- /dev/null +++ b/node_modules/dashdash/CHANGES.md @@ -0,0 +1,364 @@ +# node-dashdash changelog + +## not yet released + +(nothing yet) + +## 1.14.1 + +- [issue #30] Change the output used by dashdash's Bash completion support to + indicate "there are no completions for this argument" to cope with different + sorting rules on different Bash/platforms. For example: + + $ triton -v -p test2 package get <TAB> # before + ##-no -tritonpackage- completions-## + + $ triton -v -p test2 package get <TAB> # after + ##-no-completion- -results-## + +## 1.14.0 + +- New `synopsisFromOpt(<option spec>)` function. This will be used by + [node-cmdln](https://github.com/trentm/node-cmdln) to put together a synopsis + of options for a command. Some examples: + + > synopsisFromOpt({names: ['help', 'h'], type: 'bool'}); + '[ --help | -h ]' + > synopsisFromOpt({name: 'file', type: 'string', helpArg: 'FILE'}); + '[ --file=FILE ]' + + +## 1.13.1 + +- [issue #20] `bashCompletionSpecFromOptions` breaks on an options array with + an empty-string group. + + +## 1.13.0 + +- Update assert-plus dep to 1.x to get recent fixes (particularly for + `assert.optional*`). + +- Drop testing (and official support in packages.json#engines) for node 0.8.x. + Add testing against node 5.x and 4.x with `make testall`. + +- [pull #16] Change the `positiveInteger` type to NOT accept zero (0). + For those who might need the old behaviour, see + "examples/custom-option-intGteZero.js". (By Dave Pacheco.) + + +## 1.12.2 + +- Bash completion: Add `argtypes` to specify the types of positional args. + E.g. this would allow you to have an `ssh` command with `argtypes = ['host', + 'cmd']` for bash completion. You then have to provide Bash functions to + handle completing those types via the `specExtra` arg. See + "[examples/ddcompletion.js](examples/ddcompletion.js)" for an example. + +- Bash completion: Tweak so that options or only offered as completions when + there is a leading '-'. E.g. `mytool <TAB>` does NOT offer options, `mytool + -<TAB>` *does*. Without this, a tool with options would never be able to + fallback to Bash's "default" completion. For example `ls <TAB>` wouldn't + result in filename completion. Now it will. + +- Bash completion: A workaround for not being able to explicitly have *no* + completion results. Because dashdash's completion uses `complete -o default`, + we fallback to Bash's "default" completion (typically for filename + completion). Before this change, an attempt to explicitly say "there are + no completions that match" would unintentionally trigger filename completion. + Instead as a workaround we return: + + $ ddcompletion --none <TAB> # the 'none' argtype + ##-no completions-## + + $ ddcompletion # a custom 'fruit' argtype + apple banana orange + $ ddcompletion z + ##-no -fruit- completions-## + + This is a bit of a hack, but IMO a better experience than the surprise + of matching a local filename beginning with 'z', which isn't, in this + case, a "fruit". + +## 1.12.1 + +- Bash completion: Document `<option spec>.completionType`. Add `includeHidden` + option to `bashCompletionSpecFromOptions()`. Add support for dealing with + hidden subcmds. + + +## 1.12.0 + +- Support for generating Bash completion files. See the "Bash completion" + section of the README.md and "examples/ddcompletion.js" for an example. + + +## 1.11.0 + +- Add the `arrayFlatten` boolean option to `dashdash.addOptionType` used for + custom option types. This allows one to create an `arrayOf...` option type + where each usage of the option can return multiple results. For example: + + node mytool.js --foo a,b --foo c + + We could define an option type for `--foo` such that + `opts.foo = ['a', 'b', 'c']`. See + "[examples/custom-option-arrayOfCommaSepString.js](examples/custom-option-arrayOfCommaSepString.js)" + for an example. + + +## 1.10.1 + +- Trim the published package to the minimal bits. Before: 24K tarball, 144K unpacked. + After: 12K tarball, 48K unpacked. `npm` won't let me drop the README.md. :) + + +## 1.10.0 + +- [issue #9] Support `includeDefault` in help config (similar to `includeEnv`) to have a + note of an option's default value, if any, in help output. +- [issue #11] Fix option group breakage introduced in v1.9.0. + + +## 1.9.0 + +- [issue #10] Custom option types added with `addOptionType` can specify a + "default" value. See "examples/custom-option-fruit.js". + + +## 1.8.0 + +- Support `hidden: true` in an option spec to have help output exclude this + option. + + +## 1.7.3 + +- [issue #8] Fix parsing of a short option group when one of the + option takes an argument. For example, consider `tail` with + a `-f` boolean option and a `-n` option that takes a number + argument. This should parse: + + tail -fn5 + + Before this change, that would not parse correctly. + It is suspected that this was introduced in version 1.4.0 + (with commit 656fa8bc71c372ebddad0a7026bd71611e2ec99a). + + +## 1.7.2 + +- Known issues: #8 + +- Exclude 'tools/' dir in packages published to npm. + + +## 1.7.1 + +- Known issues: #8 + +- Support an option group *empty string* value: + + ... + { group: '' }, + ... + + to render as a blank line in option help. This can help separate loosely + related sets of options without resorting to a title for option groups. + + +## 1.7.0 + +- Known issues: #8 + +- [pull #7] Support for `<parser>.help({helpWrap: false, ...})` option to be able + to fully control the formatting for option help (by Patrick Mooney) `helpWrap: + false` can also be set on individual options in the option objects, e.g.: + + var options = [ + { + names: ['foo'], + type: 'string', + helpWrap: false, + help: 'long help with\n newlines' + + '\n spaces\n and such\nwill render correctly' + }, + ... + ]; + + +## 1.6.0 + +- Known issues: #8 + +- [pull #6] Support headings between groups of options (by Joshua M. Clulow) + so that this code: + + var options = [ + { group: 'Armament Options' }, + { names: [ 'weapon', 'w' ], type: 'string' }, + { group: 'General Options' }, + { names: [ 'help', 'h' ], type: 'bool' } + ]; + ... + + will give you this help output: + + ... + Armament Options: + -w, --weapon + + General Options: + -h, --help + ... + + +## 1.5.0 + +- Known issues: #8 + +- Add support for adding custom option types. "examples/custom-option-duration.js" + shows an example adding a "duration" option type. + + $ node custom-option-duration.js -t 1h + duration: 3600000 ms + $ node custom-option-duration.js -t 1s + duration: 1000 ms + $ node custom-option-duration.js -t 5d + duration: 432000000 ms + $ node custom-option-duration.js -t bogus + custom-option-duration.js: error: arg for "-t" is not a valid duration: "bogus" + + A custom option type is added via: + + var dashdash = require('dashdash'); + dashdash.addOptionType({ + name: '...', + takesArg: true, + helpArg: '...', + parseArg: function (option, optstr, arg) { + ... + } + }); + +- [issue #4] Add `date` and `arrayOfDate` option types. They accept these date + formats: epoch second times (e.g. 1396031701) and ISO 8601 format: + `YYYY-MM-DD[THH:MM:SS[.sss][Z]]` (e.g. "2014-03-28", + "2014-03-28T18:35:01.489Z"). See "examples/date.js" for an example usage. + + $ node examples/date.js -s 2014-01-01 -e $(date +%s) + start at 2014-01-01T00:00:00.000Z + end at 2014-03-29T04:26:18.000Z + + +## 1.4.0 + +- Known issues: #8 + +- [pull #2, pull #3] Add a `allowUnknown: true` option on `createParser` to + allow unknown options to be passed through as `opts._args` instead of parsing + throwing an exception (by https://github.com/isaacs). + + See 'allowUnknown' in the README for a subtle caveat. + + +## 1.3.2 + +- Fix a subtlety where a *bool* option using both `env` and `default` didn't + work exactly correctly. If `default: false` then all was fine (by luck). + However, if you had an option like this: + + options: [ { + names: ['verbose', 'v'], + env: 'FOO_VERBOSE', + 'default': true, // <--- this + type: 'bool' + } ], + + wanted `FOO_VERBOSE=0` to make the option false, then you need the fix + in this version of dashdash. + + +## 1.3.1 + +- [issue #1] Fix an envvar not winning over an option 'default'. Previously + an option with both `default` and `env` would never take a value from the + environment variable. E.g. `FOO_FILE` would never work here: + + options: [ { + names: ['file', 'f'], + env: 'FOO_FILE', + 'default': 'default.file', + type: 'string' + } ], + + +## 1.3.0 + +- [Backward incompatible change for boolean envvars] Change the + interpretation of environment variables for boolean options to consider '0' + to be false. Previous to this *any* value to the envvar was considered + true -- which was quite misleading. Example: + + $ FOO_VERBOSE=0 node examples/foo.js + # opts: { verbose: [ false ], + _order: [ { key: 'verbose', value: false, from: 'env' } ], + _args: [] } + # args: [] + + +## 1.2.1 + +- Fix for `parse.help({includeEnv: true, ...})` handling to ensure that an + option with an `env` **but no `help`** still has the "Environment: ..." + output. E.g.: + + { names: ['foo'], type: 'string', env: 'FOO' } + + ... + + --foo=ARG Environment: FOO=ARG + + +## 1.2.0 + +- Transform the option key on the `opts` object returned from + `<parser>.parse()` for convenience. Currently this is just + `s/-/_/g`, e.g. '--dry-run' -> `opts.dry_run`. This allow one to use hyphen + in option names (common) but not have to do silly things like + `opt["dry-run"]` to access the parsed results. + + +## 1.1.0 + +- Environment variable integration. Envvars can be associated with an option, + then option processing will fallback to using that envvar if defined and + if the option isn't specified in argv. See the "Environment variable + integration" section in the README. + +- Change the `<parser>.parse()` signature to take a single object with keys + for arguments. The old signature is still supported. + +- `dashdash.createParser(CONFIG)` alternative to `new dashdash.Parser(CONFIG)` + a la many node-land APIs. + + +## 1.0.2 + +- Add "positiveInteger" and "arrayOfPositiveInteger" option types that only + accept positive integers. + +- Add "integer" and "arrayOfInteger" option types that accepts only integers. + Note that, for better or worse, these do NOT accept: "0x42" (hex), "1e2" + (with exponent) or "1.", "3.0" (floats). + + +## 1.0.1 + +- Fix not modifying the given option spec objects (which breaks creating + a Parser with them more than once). + + +## 1.0.0 + +First release. |