mirror of
				https://kkgithub.com/actions/setup-python.git
				synced 2025-11-04 12:44:05 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			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.
 |