365 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			365 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
|  | # 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. |