634 lines
30 KiB
Markdown
634 lines
30 KiB
Markdown
> :warning: This document is no longer being actively maintained. Please see the
|
|
> [releases page](https://github.com/urfave/cli/releases) for all release notes
|
|
> and related hypermedia for releases `>= 1.22.5`, `>= 2.3.0`.
|
|
|
|
---
|
|
|
|
# Change Log
|
|
|
|
**ATTN**: This project uses [semantic versioning](http://semver.org/).
|
|
|
|
## Unreleased - 2.X series
|
|
|
|
View [unreleased 2.X] series changes.
|
|
|
|
## [2.2.0] - 2020-03-08
|
|
|
|
These release notes were written for the git hash [d648edd48d89ef3a841b1ec75c2ebbd4de5f748f](https://github.com/urfave/cli/tree/d648edd48d89ef3a841b1ec75c2ebbd4de5f748f)
|
|
|
|
### Fixed
|
|
|
|
* Fixed zsh completion scripts in [urfave/cli/pull/1062](https://github.com/urfave/cli/pull/1062) via [@zhsj](https://github.com/zhsj)
|
|
* Fixed description of subcommand to be more consistent in [urfave/cli/pull/1054](https://github.com/urfave/cli/pull/1054) via [@itchyny](https://github.com/itchyny)
|
|
* Fixed possible runtime panic in slice parsing in [urfave/cli/pull/1049](https://github.com/urfave/cli/pull/1049) via [@saschagrunert](https://github.com/saschagrunert)
|
|
* Fixed invalid man page header generation in [urfave/cli/pull/1041](https://github.com/urfave/cli/pull/1041) via [@saschagrunert](https://github.com/saschagrunert)
|
|
|
|
### Changed
|
|
|
|
* Improved auto-completion instructions and added example gifs in [urfave/cli/pull/1059](https://github.com/urfave/cli/pull/1059) via [@masonj188](https://github.com/masonj188)
|
|
* Removed the author from generated man pages in [urfave/cli/pull/1041](https://github.com/urfave/cli/pull/1041) via [@saschagrunert](https://github.com/saschagrunert)
|
|
|
|
### Added
|
|
|
|
* Added destination field to `StringSliceFlag` in [urfave/cli/pull/1078](https://github.com/urfave/cli/pull/1078) via [@davidsbond](https://github.com/davidsbond)
|
|
* Added `HideHelpCommand`. While `HideHelp` hides both `help` command and `--help` flag, `HideHelpCommand` only hides `help` command and leave `--help` flag as-is in [urfave/cli/pull/1083](https://github.com/urfave/cli/pull/1083) via [@AkihiroSuda](https://github.com/AkihiroSuda)
|
|
* Added timestampFlag docs in [urfave/cli/pull/997](https://github.com/urfave/cli/pull/997) via [@drov0](https://github.com/drov0)
|
|
* Added required flags documentation in [urfave/cli/pull/1008](https://github.com/urfave/cli/pull/1008) via [@lynncyrin](https://github.com/lynncyrin), [@anberns](https://github.com/anberns)
|
|
|
|
## [2.1.1] - 2019-12-24
|
|
|
|
### Fixed
|
|
|
|
* Fixed a `Context` regression introduced in `v2.1.0` in [urfave/cli/pull/1014](https://github.com/urfave/cli/pull/1014) via [@lynncyrin](https://github.com/lynncyrin)
|
|
|
|
## [2.1.0] - 2019-12-24
|
|
|
|
These release notes were written for the git hash [ae84df4cef4a2a6f1a0cb1d41ea0f3af8755e5a8](https://github.com/urfave/cli/tree/ae84df4cef4a2a6f1a0cb1d41ea0f3af8755e5a8)
|
|
|
|
### Fixed
|
|
|
|
* Fixed some golint errors in [urfave/cli/pull/988](https://github.com/urfave/cli/pull/988) via [@liamchampton](https://github.com/liamchampton)
|
|
* Fixed a panic with flag completion [urfave/cli/pull/946](https://github.com/urfave/cli/pull/946) via [@unRob](https://github.com/unRob)
|
|
|
|
### Changed
|
|
|
|
* Changed docs generation to use visible flags in [urfave/cli/pull/999](https://github.com/urfave/cli/pull/999) via [@subpop](https://github.com/subpop)
|
|
* Changed `App.Run` to use an optional context for timeouts and cancellation in [urfave/cli/pull/975](https://github.com/urfave/cli/pull/975) via [@marwan-at-work](https://github.com/marwan-at-work)
|
|
* Changed version info to be hidden if the user has not defined a version in [urfave/cli/pull/955](https://github.com/urfave/cli/pull/955) via [@asahasrabuddhe](https://github.com/asahasrabuddhe)
|
|
* Changed docs generation to take into account multiple authors in [urfave/cli/pull/900](https://github.com/urfave/cli/pull/900) via [@saschagrunert](https://github.com/saschagrunert)
|
|
* Changed context to expose a `Value` accessor in [urfave/cli/pull/741](https://github.com/urfave/cli/pull/741) via [@corruptmemory](https://github.com/corruptmemory)
|
|
|
|
### Added
|
|
|
|
* Added timestamp flag in [urfave/cli/pull/987](https://github.com/urfave/cli/pull/987) via [@drov0](https://github.com/drov0)
|
|
|
|
## [2.0.0] - 2019-11-17
|
|
|
|
The V2 changes were all shipped in [urfave/cli/pull/892](https://github.com/urfave/cli/pull/892), which was created with the effort of over a dozen participants! They are:
|
|
|
|
[@asahasrabuddhe](https://github.com/asahasrabuddhe), [@meatballhat](https://github.com/meatballhat), [@jszwedko](https://github.com/jszwedko), [@lynncyrin](https://github.com/lynncyrin), [@AudriusButkevicius](https://github.com/AudriusButkevicius), [@saschagrunert](https://github.com/saschagrunert), [@rliebz](https://github.com/rliebz), [@johnweldon](https://github.com/johnweldon), [@nlewo](https://github.com/nlewo), [@grubernaut](https://github.com/grubernaut), [@OneOfOne](https://github.com/OneOfOne), [@VMitov](https://github.com/VMitov), [@cbranch](https://github.com/cbranch), [@marwan-at-work](https://github.com/marwan-at-work), [@uudashr](https://github.com/uudashr), [@bfreis](https://github.com/bfreis)
|
|
|
|
### Added
|
|
|
|
- Added `NewStringSlice` and `NewIntSlice` for creating their related types
|
|
- Added `Float64SliceFlag` for unmarshaling a list of floats from the user
|
|
- Added `Context.Lineage` to get all contexts from current up to global
|
|
- Added `Context.LocalFlagNames` to get the flag names from *only* the current context
|
|
- Added `BoolFlag.Value` to handle both default-false and default-true
|
|
- Added `IsSet` method to the `Flag` interface which allows us to detect whether or not a flag has been set
|
|
|
|
### Changed
|
|
|
|
- `Context.FlagNames` now returns all flags in the context lineage
|
|
- `Context.IsSet` now considers the full context lineage
|
|
|
|
### Removed
|
|
|
|
- Removed the ability to specify `&StringSlice{...string}` or `&IntSlice{...int}`.
|
|
- Removed adapter code for deprecated `Action` func signature
|
|
- Deprecated `App.Author`, `App.Email`, and `Command.ShortName` fields
|
|
- Removed all `Context.Global*` methods, as the non-global versions now traverse up
|
|
the context lineage automatically.
|
|
- Removed `Context.Parent` method, as this is now available via `Context.Lineage`
|
|
- Removed `BoolTFlag` and related code, as this is now available via `BoolFlag.Value`
|
|
|
|
## Unreleased - 1.22.X series
|
|
|
|
View [unreleased 1.22.X] series changes.
|
|
|
|
## [1.22.4] - 2020-03-31
|
|
|
|
### Fixed
|
|
|
|
- Fixed a panic with flag completion in [urfave/cli/pull/1101](https://github.com/urfave/cli/pull/1101) via [@unRob](https://github.com/unRob), [@VirrageS](https://github.com/VirrageS)
|
|
|
|
## [1.22.3] - 2020-02-25
|
|
|
|
### Fixed
|
|
|
|
- String flag no longer persists the default value if the flag is explicitly initialized in [urfave/cli/pull/981](https://github.com/urfave/cli/pull/981) via [@asahasrabuddhe](https://github.com/asahasrabuddhe)
|
|
- `context.IsSet()` returns `true` or `false` correctly regardless of whether the short name or the full name of the flag is passed to it in [urfave/cli/pull/978](https://github.com/urfave/cli/pull/978) via [@asahasrabuddhe](https://github.com/asahasrabuddhe)
|
|
- Hide version if the version is not set by the user in [urfave/cli/pull/954](https://github.com/urfave/cli/pull/954) via [@asahasrabuddhe](https://github.com/asahasrabuddhe)
|
|
|
|
## [1.22.2] - 2019-11-17
|
|
|
|
### Fixed
|
|
|
|
- Fix v1.21.0 pass through regression in [urfave/cli/pull/872](https://github.com/urfave/cli/pull/872) via [@lynncyrin](https://github.com/lynncyrin)
|
|
- Fix infinite loop when parsing invalid flags for apps with short option handling in [urfave/cli/pull/911](https://github.com/urfave/cli/pull/911) via [@rliebz](https://github.com/rliebz)
|
|
- Fix zsh autocomplete in [urfave/cli/pull/906](https://github.com/urfave/cli/pull/906) via [@gnowxilef](https://github.com/gnowxilef)
|
|
- Fix typo in `DocGenerationFlag.TakesValue()` docstring in [urfave/cli/pull/902](https://github.com/urfave/cli/pull/902) via [@benmoose](https://github.com/benmoose)
|
|
- Avoid panic for missing flag value in [urfave/cli/pull/893](https://github.com/urfave/cli/pull/893) via [@rliebz](https://github.com/rliebz)
|
|
|
|
### Changed
|
|
|
|
- Simplify `HelpPrinter` and `CustomHelpPrinter` behaviors in [urfave/cli/pull/912](https://github.com/urfave/cli/pull/912) via [@rliebz](https://github.com/rliebz)
|
|
|
|
## [1.22.1] - 2019-09-11
|
|
|
|
### Fixed
|
|
|
|
* Hide output of hidden commands on man pages in [urfave/cli/pull/889](https://github.com/urfave/cli/pull/889) via [@crosbymichael](https://github.com/crosbymichael)
|
|
* Don't generate fish completion for hidden commands [urfave/cli/pull/891](https://github.com/urfave/891) via [@saschagrunert](https://github.com/saschagrunert)
|
|
* Using short flag names for required flags throws an error in [urfave/cli/pull/890](https://github.com/urfave/cli/pull/890) via [@asahasrabuddhe](https://github.com/asahasrabuddhe)
|
|
|
|
### Changed
|
|
|
|
* Remove flag code generation logic, legacy python test runner in [urfave/cli/pull/883](https://github.com/urfave/cli/pull/883) via [@asahasrabuddhe](https://github.com/asahasrabuddhe)
|
|
* Enable Go Modules support, drop support for `Go 1.10` add support for `Go 1.13` in [urfave/cli/pull/885](https://github.com/urfave/cli/pull/885) via [@asahasrabuddhe](https://github.com/asahasrabuddhe)
|
|
|
|
## [1.22.0] - 2019-09-07
|
|
|
|
### Fixed
|
|
|
|
* Fix Subcommands not falling back to `app.ExitEventHandler` in [urfave/cli/pull/856](https://github.com/urfave/cli/pull/856) via [@FaranIdo](https://github.com/FaranIdo)
|
|
|
|
### Changed
|
|
|
|
* Clarify that altsrc supports both TOML and JSON in [urfave/cli/pull/774](https://github.com/urfave/cli/pull/774) via [@whereswaldon](https://github.com/whereswaldon)
|
|
* Made the exit code example more clear in [urfave/cli/pull/823](https://github.com/urfave/cli/pull/823) via [@xordspar0](https://github.com/xordspar0)
|
|
* Removed the use of python for internal flag generation in [urfave/cli/pull/836](https://github.com/urfave/cli/pull/836) via [@asahasrabuddhe](https://github.com/asahasrabuddhe)
|
|
* Changed the supported go versions to `1.10`, `1.11`, `1.12` in [urfave/cli/pull/843](https://github.com/urfave/cli/pull/843) via [@lafriks](https://github.com/lafriks)
|
|
* Changed the v1 releases section in the readme in [urfave/cli/pull/862](https://github.com/urfave/cli/pull/862) via [@russoj88](https://github.com/russoj88)
|
|
* Cleaned up go modules in [urfave/cli/pull/874](https://github.com/urfave/cli/pull/874) via [@saschagrunert](https://github.com/saschagrunert)
|
|
|
|
### Added
|
|
|
|
* Added `UseShortOptionHandling` for combining short flags in [urfave/cli/pull/735](https://github.com/urfave/cli/pull/735) via [@rliebz](https://github.com/rliebz)
|
|
* Added support for flags bash completion in [urfave/cli/pull/808](https://github.com/urfave/cli/pull/808) via [@yogeshlonkar](https://github.com/yogeshlonkar)
|
|
* Added the `TakesFile` indicator to flag in [urfave/cli/pull/851](https://github.com/urfave/cli/pull/851) via [@saschagrunert](https://github.com/saschagrunert)
|
|
* Added fish shell completion support in [urfave/cli/pull/848](https://github.com/urfave/cli/pull/848) via [@saschagrunert](https://github.com/saschagrunert)
|
|
|
|
## [1.21.0] - 2019-08-02
|
|
|
|
### Fixed
|
|
|
|
* Fix using "slice" flag types with `EnvVar` in [urfave/cli/pull/687](https://github.com/urfave/cli/pull/687) via [@joshuarubin](https://github.com/joshuarubin)
|
|
* Fix regression of `SkipFlagParsing` behavior in [urfave/cli/pull/697](https://github.com/urfave/cli/pull/697) via [@jszwedko](https://github.com/jszwedko)
|
|
* Fix handling `ShortOptions` and `SkipArgReorder` in [urfave/cli/pull/686](https://github.com/urfave/cli/pull/686) via [@baude](https://github.com/baude)
|
|
* Fix args reordering when bool flags are present in [urfave/cli/pull/712](https://github.com/urfave/cli/pull/712) via [@windler](https://github.com/windler)
|
|
* Fix parsing of short options in [urfave/cli/pull/758](https://github.com/urfave/cli/pull/758) via [@vrothberg](https://github.com/vrothberg)
|
|
* Fix unaligned indents for the command help messages in [urfave/cli/pull/806](https://github.com/urfave/cli/pull/806) via [@mingrammer](https://github.com/mingrammer)
|
|
|
|
### Changed
|
|
|
|
* Cleaned up help output in [urfave/cli/pull/664](https://github.com/urfave/cli/pull/664) via [@maguro](https://github.com/maguro)
|
|
* Remove redundant nil checks in [urfave/cli/pull/773](https://github.com/urfave/cli/pull/773) via [@teresy](https://github.com/teresy)
|
|
* Case is now considered when sorting strings in [urfave/cli/pull/676](https://github.com/urfave/cli/pull/676) via [@rliebz](https://github.com/rliebz)
|
|
|
|
### Added
|
|
|
|
* Added _"required flags"_ support in [urfave/cli/pull/819](https://github.com/urfave/cli/pull/819) via [@lynncyrin](https://github.com/lynncyrin/)
|
|
* Backport JSON `InputSource` to v1 in [urfave/cli/pull/598](https://github.com/urfave/cli/pull/598) via [@jszwedko](https://github.com/jszwedko)
|
|
* Allow more customization of flag help strings in [urfave/cli/pull/661](https://github.com/urfave/cli/pull/661) via [@rliebz](https://github.com/rliebz)
|
|
* Allow custom `ExitError` handler function in [urfave/cli/pull/628](https://github.com/urfave/cli/pull/628) via [@phinnaeus](https://github.com/phinnaeus)
|
|
* Allow loading a variable from a file in [urfave/cli/pull/675](https://github.com/urfave/cli/pull/675) via [@jmccann](https://github.com/jmccann)
|
|
* Allow combining short bool names in [urfave/cli/pull/684](https://github.com/urfave/cli/pull/684) via [@baude](https://github.com/baude)
|
|
* Added test coverage to context in [urfave/cli/pull/788](https://github.com/urfave/cli/pull/788) via [@benzvan](https://github.com/benzvan)
|
|
* Added go module support in [urfave/cli/pull/831](https://github.com/urfave/cli/pull/831) via [@saschagrunert](https://github.com/saschagrunert)
|
|
|
|
## [1.20.0] - 2017-08-10
|
|
|
|
### Fixed
|
|
|
|
* `HandleExitCoder` is now correctly iterates over all errors in
|
|
a `MultiError`. The exit code is the exit code of the last error or `1` if
|
|
there are no `ExitCoder`s in the `MultiError`.
|
|
* Fixed YAML file loading on Windows (previously would fail validate the file path)
|
|
* Subcommand `Usage`, `Description`, `ArgsUsage`, `OnUsageError` correctly
|
|
propogated
|
|
* `ErrWriter` is now passed downwards through command structure to avoid the
|
|
need to redefine it
|
|
* Pass `Command` context into `OnUsageError` rather than parent context so that
|
|
all fields are avaiable
|
|
* Errors occuring in `Before` funcs are no longer double printed
|
|
* Use `UsageText` in the help templates for commands and subcommands if
|
|
defined; otherwise build the usage as before (was previously ignoring this
|
|
field)
|
|
* `IsSet` and `GlobalIsSet` now correctly return whether a flag is set if
|
|
a program calls `Set` or `GlobalSet` directly after flag parsing (would
|
|
previously only return `true` if the flag was set during parsing)
|
|
|
|
### Changed
|
|
|
|
* No longer exit the program on command/subcommand error if the error raised is
|
|
not an `OsExiter`. This exiting behavior was introduced in 1.19.0, but was
|
|
determined to be a regression in functionality. See [the
|
|
PR](https://github.com/urfave/cli/pull/595) for discussion.
|
|
|
|
### Added
|
|
|
|
* `CommandsByName` type was added to make it easy to sort `Command`s by name,
|
|
alphabetically
|
|
* `altsrc` now handles loading of string and int arrays from TOML
|
|
* Support for definition of custom help templates for `App` via
|
|
`CustomAppHelpTemplate`
|
|
* Support for arbitrary key/value fields on `App` to be used with
|
|
`CustomAppHelpTemplate` via `ExtraInfo`
|
|
* `HelpFlag`, `VersionFlag`, and `BashCompletionFlag` changed to explictly be
|
|
`cli.Flag`s allowing for the use of custom flags satisfying the `cli.Flag`
|
|
interface to be used.
|
|
|
|
|
|
## [1.19.1] - 2016-11-21
|
|
|
|
### Fixed
|
|
|
|
- Fixes regression introduced in 1.19.0 where using an `ActionFunc` as
|
|
the `Action` for a command would cause it to error rather than calling the
|
|
function. Should not have a affected declarative cases using `func(c
|
|
*cli.Context) err)`.
|
|
- Shell completion now handles the case where the user specifies
|
|
`--generate-bash-completion` immediately after a flag that takes an argument.
|
|
Previously it call the application with `--generate-bash-completion` as the
|
|
flag value.
|
|
|
|
## [1.19.0] - 2016-11-19
|
|
### Added
|
|
- `FlagsByName` was added to make it easy to sort flags (e.g. `sort.Sort(cli.FlagsByName(app.Flags))`)
|
|
- A `Description` field was added to `App` for a more detailed description of
|
|
the application (similar to the existing `Description` field on `Command`)
|
|
- Flag type code generation via `go generate`
|
|
- Write to stderr and exit 1 if action returns non-nil error
|
|
- Added support for TOML to the `altsrc` loader
|
|
- `SkipArgReorder` was added to allow users to skip the argument reordering.
|
|
This is useful if you want to consider all "flags" after an argument as
|
|
arguments rather than flags (the default behavior of the stdlib `flag`
|
|
library). This is backported functionality from the [removal of the flag
|
|
reordering](https://github.com/urfave/cli/pull/398) in the unreleased version
|
|
2
|
|
- For formatted errors (those implementing `ErrorFormatter`), the errors will
|
|
be formatted during output. Compatible with `pkg/errors`.
|
|
|
|
### Changed
|
|
- Raise minimum tested/supported Go version to 1.2+
|
|
|
|
### Fixed
|
|
- Consider empty environment variables as set (previously environment variables
|
|
with the equivalent of `""` would be skipped rather than their value used).
|
|
- Return an error if the value in a given environment variable cannot be parsed
|
|
as the flag type. Previously these errors were silently swallowed.
|
|
- Print full error when an invalid flag is specified (which includes the invalid flag)
|
|
- `App.Writer` defaults to `stdout` when `nil`
|
|
- If no action is specified on a command or app, the help is now printed instead of `panic`ing
|
|
- `App.Metadata` is initialized automatically now (previously was `nil` unless initialized)
|
|
- Correctly show help message if `-h` is provided to a subcommand
|
|
- `context.(Global)IsSet` now respects environment variables. Previously it
|
|
would return `false` if a flag was specified in the environment rather than
|
|
as an argument
|
|
- Removed deprecation warnings to STDERR to avoid them leaking to the end-user
|
|
- `altsrc`s import paths were updated to use `gopkg.in/urfave/cli.v1`. This
|
|
fixes issues that occurred when `gopkg.in/urfave/cli.v1` was imported as well
|
|
as `altsrc` where Go would complain that the types didn't match
|
|
|
|
## [1.18.1] - 2016-08-28
|
|
### Fixed
|
|
- Removed deprecation warnings to STDERR to avoid them leaking to the end-user (backported)
|
|
|
|
## [1.18.0] - 2016-06-27
|
|
### Added
|
|
- `./runtests` test runner with coverage tracking by default
|
|
- testing on OS X
|
|
- testing on Windows
|
|
- `UintFlag`, `Uint64Flag`, and `Int64Flag` types and supporting code
|
|
|
|
### Changed
|
|
- Use spaces for alignment in help/usage output instead of tabs, making the
|
|
output alignment consistent regardless of tab width
|
|
|
|
### Fixed
|
|
- Printing of command aliases in help text
|
|
- Printing of visible flags for both struct and struct pointer flags
|
|
- Display the `help` subcommand when using `CommandCategories`
|
|
- No longer swallows `panic`s that occur within the `Action`s themselves when
|
|
detecting the signature of the `Action` field
|
|
|
|
## [1.17.1] - 2016-08-28
|
|
### Fixed
|
|
- Removed deprecation warnings to STDERR to avoid them leaking to the end-user
|
|
|
|
## [1.17.0] - 2016-05-09
|
|
### Added
|
|
- Pluggable flag-level help text rendering via `cli.DefaultFlagStringFunc`
|
|
- `context.GlobalBoolT` was added as an analogue to `context.GlobalBool`
|
|
- Support for hiding commands by setting `Hidden: true` -- this will hide the
|
|
commands in help output
|
|
|
|
### Changed
|
|
- `Float64Flag`, `IntFlag`, and `DurationFlag` default values are no longer
|
|
quoted in help text output.
|
|
- All flag types now include `(default: {value})` strings following usage when a
|
|
default value can be (reasonably) detected.
|
|
- `IntSliceFlag` and `StringSliceFlag` usage strings are now more consistent
|
|
with non-slice flag types
|
|
- Apps now exit with a code of 3 if an unknown subcommand is specified
|
|
(previously they printed "No help topic for...", but still exited 0. This
|
|
makes it easier to script around apps built using `cli` since they can trust
|
|
that a 0 exit code indicated a successful execution.
|
|
- cleanups based on [Go Report Card
|
|
feedback](https://goreportcard.com/report/github.com/urfave/cli)
|
|
|
|
## [1.16.1] - 2016-08-28
|
|
### Fixed
|
|
- Removed deprecation warnings to STDERR to avoid them leaking to the end-user
|
|
|
|
## [1.16.0] - 2016-05-02
|
|
### Added
|
|
- `Hidden` field on all flag struct types to omit from generated help text
|
|
|
|
### Changed
|
|
- `BashCompletionFlag` (`--enable-bash-completion`) is now omitted from
|
|
generated help text via the `Hidden` field
|
|
|
|
### Fixed
|
|
- handling of error values in `HandleAction` and `HandleExitCoder`
|
|
|
|
## [1.15.0] - 2016-04-30
|
|
### Added
|
|
- This file!
|
|
- Support for placeholders in flag usage strings
|
|
- `App.Metadata` map for arbitrary data/state management
|
|
- `Set` and `GlobalSet` methods on `*cli.Context` for altering values after
|
|
parsing.
|
|
- Support for nested lookup of dot-delimited keys in structures loaded from
|
|
YAML.
|
|
|
|
### Changed
|
|
- The `App.Action` and `Command.Action` now prefer a return signature of
|
|
`func(*cli.Context) error`, as defined by `cli.ActionFunc`. If a non-nil
|
|
`error` is returned, there may be two outcomes:
|
|
- If the error fulfills `cli.ExitCoder`, then `os.Exit` will be called
|
|
automatically
|
|
- Else the error is bubbled up and returned from `App.Run`
|
|
- Specifying an `Action` with the legacy return signature of
|
|
`func(*cli.Context)` will produce a deprecation message to stderr
|
|
- Specifying an `Action` that is not a `func` type will produce a non-zero exit
|
|
from `App.Run`
|
|
- Specifying an `Action` func that has an invalid (input) signature will
|
|
produce a non-zero exit from `App.Run`
|
|
|
|
### Deprecated
|
|
- <a name="deprecated-cli-app-runandexitonerror"></a>
|
|
`cli.App.RunAndExitOnError`, which should now be done by returning an error
|
|
that fulfills `cli.ExitCoder` to `cli.App.Run`.
|
|
- <a name="deprecated-cli-app-action-signature"></a> the legacy signature for
|
|
`cli.App.Action` of `func(*cli.Context)`, which should now have a return
|
|
signature of `func(*cli.Context) error`, as defined by `cli.ActionFunc`.
|
|
|
|
### Fixed
|
|
- Added missing `*cli.Context.GlobalFloat64` method
|
|
|
|
## [1.14.0] - 2016-04-03 (backfilled 2016-04-25)
|
|
### Added
|
|
- Codebeat badge
|
|
- Support for categorization via `CategorizedHelp` and `Categories` on app.
|
|
|
|
### Changed
|
|
- Use `filepath.Base` instead of `path.Base` in `Name` and `HelpName`.
|
|
|
|
### Fixed
|
|
- Ensure version is not shown in help text when `HideVersion` set.
|
|
|
|
## [1.13.0] - 2016-03-06 (backfilled 2016-04-25)
|
|
### Added
|
|
- YAML file input support.
|
|
- `NArg` method on context.
|
|
|
|
## [1.12.0] - 2016-02-17 (backfilled 2016-04-25)
|
|
### Added
|
|
- Custom usage error handling.
|
|
- Custom text support in `USAGE` section of help output.
|
|
- Improved help messages for empty strings.
|
|
- AppVeyor CI configuration.
|
|
|
|
### Changed
|
|
- Removed `panic` from default help printer func.
|
|
- De-duping and optimizations.
|
|
|
|
### Fixed
|
|
- Correctly handle `Before`/`After` at command level when no subcommands.
|
|
- Case of literal `-` argument causing flag reordering.
|
|
- Environment variable hints on Windows.
|
|
- Docs updates.
|
|
|
|
## [1.11.1] - 2015-12-21 (backfilled 2016-04-25)
|
|
### Changed
|
|
- Use `path.Base` in `Name` and `HelpName`
|
|
- Export `GetName` on flag types.
|
|
|
|
### Fixed
|
|
- Flag parsing when skipping is enabled.
|
|
- Test output cleanup.
|
|
- Move completion check to account for empty input case.
|
|
|
|
## [1.11.0] - 2015-11-15 (backfilled 2016-04-25)
|
|
### Added
|
|
- Destination scan support for flags.
|
|
- Testing against `tip` in Travis CI config.
|
|
|
|
### Changed
|
|
- Go version in Travis CI config.
|
|
|
|
### Fixed
|
|
- Removed redundant tests.
|
|
- Use correct example naming in tests.
|
|
|
|
## [1.10.2] - 2015-10-29 (backfilled 2016-04-25)
|
|
### Fixed
|
|
- Remove unused var in bash completion.
|
|
|
|
## [1.10.1] - 2015-10-21 (backfilled 2016-04-25)
|
|
### Added
|
|
- Coverage and reference logos in README.
|
|
|
|
### Fixed
|
|
- Use specified values in help and version parsing.
|
|
- Only display app version and help message once.
|
|
|
|
## [1.10.0] - 2015-10-06 (backfilled 2016-04-25)
|
|
### Added
|
|
- More tests for existing functionality.
|
|
- `ArgsUsage` at app and command level for help text flexibility.
|
|
|
|
### Fixed
|
|
- Honor `HideHelp` and `HideVersion` in `App.Run`.
|
|
- Remove juvenile word from README.
|
|
|
|
## [1.9.0] - 2015-09-08 (backfilled 2016-04-25)
|
|
### Added
|
|
- `FullName` on command with accompanying help output update.
|
|
- Set default `$PROG` in bash completion.
|
|
|
|
### Changed
|
|
- Docs formatting.
|
|
|
|
### Fixed
|
|
- Removed self-referential imports in tests.
|
|
|
|
## [1.8.0] - 2015-06-30 (backfilled 2016-04-25)
|
|
### Added
|
|
- Support for `Copyright` at app level.
|
|
- `Parent` func at context level to walk up context lineage.
|
|
|
|
### Fixed
|
|
- Global flag processing at top level.
|
|
|
|
## [1.7.1] - 2015-06-11 (backfilled 2016-04-25)
|
|
### Added
|
|
- Aggregate errors from `Before`/`After` funcs.
|
|
- Doc comments on flag structs.
|
|
- Include non-global flags when checking version and help.
|
|
- Travis CI config updates.
|
|
|
|
### Fixed
|
|
- Ensure slice type flags have non-nil values.
|
|
- Collect global flags from the full command hierarchy.
|
|
- Docs prose.
|
|
|
|
## [1.7.0] - 2015-05-03 (backfilled 2016-04-25)
|
|
### Changed
|
|
- `HelpPrinter` signature includes output writer.
|
|
|
|
### Fixed
|
|
- Specify go 1.1+ in docs.
|
|
- Set `Writer` when running command as app.
|
|
|
|
## [1.6.0] - 2015-03-23 (backfilled 2016-04-25)
|
|
### Added
|
|
- Multiple author support.
|
|
- `NumFlags` at context level.
|
|
- `Aliases` at command level.
|
|
|
|
### Deprecated
|
|
- `ShortName` at command level.
|
|
|
|
### Fixed
|
|
- Subcommand help output.
|
|
- Backward compatible support for deprecated `Author` and `Email` fields.
|
|
- Docs regarding `Names`/`Aliases`.
|
|
|
|
## [1.5.0] - 2015-02-20 (backfilled 2016-04-25)
|
|
### Added
|
|
- `After` hook func support at app and command level.
|
|
|
|
### Fixed
|
|
- Use parsed context when running command as subcommand.
|
|
- Docs prose.
|
|
|
|
## [1.4.1] - 2015-01-09 (backfilled 2016-04-25)
|
|
### Added
|
|
- Support for hiding `-h / --help` flags, but not `help` subcommand.
|
|
- Stop flag parsing after `--`.
|
|
|
|
### Fixed
|
|
- Help text for generic flags to specify single value.
|
|
- Use double quotes in output for defaults.
|
|
- Use `ParseInt` instead of `ParseUint` for int environment var values.
|
|
- Use `0` as base when parsing int environment var values.
|
|
|
|
## [1.4.0] - 2014-12-12 (backfilled 2016-04-25)
|
|
### Added
|
|
- Support for environment variable lookup "cascade".
|
|
- Support for `Stdout` on app for output redirection.
|
|
|
|
### Fixed
|
|
- Print command help instead of app help in `ShowCommandHelp`.
|
|
|
|
## [1.3.1] - 2014-11-13 (backfilled 2016-04-25)
|
|
### Added
|
|
- Docs and example code updates.
|
|
|
|
### Changed
|
|
- Default `-v / --version` flag made optional.
|
|
|
|
## [1.3.0] - 2014-08-10 (backfilled 2016-04-25)
|
|
### Added
|
|
- `FlagNames` at context level.
|
|
- Exposed `VersionPrinter` var for more control over version output.
|
|
- Zsh completion hook.
|
|
- `AUTHOR` section in default app help template.
|
|
- Contribution guidelines.
|
|
- `DurationFlag` type.
|
|
|
|
## [1.2.0] - 2014-08-02
|
|
### Added
|
|
- Support for environment variable defaults on flags plus tests.
|
|
|
|
## [1.1.0] - 2014-07-15
|
|
### Added
|
|
- Bash completion.
|
|
- Optional hiding of built-in help command.
|
|
- Optional skipping of flag parsing at command level.
|
|
- `Author`, `Email`, and `Compiled` metadata on app.
|
|
- `Before` hook func support at app and command level.
|
|
- `CommandNotFound` func support at app level.
|
|
- Command reference available on context.
|
|
- `GenericFlag` type.
|
|
- `Float64Flag` type.
|
|
- `BoolTFlag` type.
|
|
- `IsSet` flag helper on context.
|
|
- More flag lookup funcs at context level.
|
|
- More tests & docs.
|
|
|
|
### Changed
|
|
- Help template updates to account for presence/absence of flags.
|
|
- Separated subcommand help template.
|
|
- Exposed `HelpPrinter` var for more control over help output.
|
|
|
|
## [1.0.0] - 2013-11-01
|
|
### Added
|
|
- `help` flag in default app flag set and each command flag set.
|
|
- Custom handling of argument parsing errors.
|
|
- Command lookup by name at app level.
|
|
- `StringSliceFlag` type and supporting `StringSlice` type.
|
|
- `IntSliceFlag` type and supporting `IntSlice` type.
|
|
- Slice type flag lookups by name at context level.
|
|
- Export of app and command help functions.
|
|
- More tests & docs.
|
|
|
|
## 0.1.0 - 2013-07-22
|
|
### Added
|
|
- Initial implementation.
|
|
|
|
[unreleased 2.X]: https://github.com/urfave/cli/compare/v2.2.0...HEAD
|
|
[2.2.0]: https://github.com/urfave/cli/compare/v2.1.1...v2.2.0
|
|
[2.1.1]: https://github.com/urfave/cli/compare/v2.1.0...v2.1.1
|
|
[2.1.0]: https://github.com/urfave/cli/compare/v2.0.0...v2.1.0
|
|
[2.0.0]: https://github.com/urfave/cli/compare/v1.22.2...v2.0.0
|
|
|
|
[unreleased 1.22.X]: https://github.com/urfave/cli/compare/v1.22.4...v1
|
|
[1.22.4]: https://github.com/urfave/cli/compare/v1.22.3...v1.22.4
|
|
[1.22.3]: https://github.com/urfave/cli/compare/v1.22.2...v1.22.3
|
|
[1.22.2]: https://github.com/urfave/cli/compare/v1.22.1...v1.22.2
|
|
[1.22.1]: https://github.com/urfave/cli/compare/v1.22.0...v1.22.1
|
|
[1.22.0]: https://github.com/urfave/cli/compare/v1.21.0...v1.22.0
|
|
[1.21.0]: https://github.com/urfave/cli/compare/v1.20.0...v1.21.0
|
|
[1.20.0]: https://github.com/urfave/cli/compare/v1.19.1...v1.20.0
|
|
[1.19.1]: https://github.com/urfave/cli/compare/v1.19.0...v1.19.1
|
|
[1.19.0]: https://github.com/urfave/cli/compare/v1.18.0...v1.19.0
|
|
[1.18.0]: https://github.com/urfave/cli/compare/v1.17.0...v1.18.0
|
|
[1.17.0]: https://github.com/urfave/cli/compare/v1.16.0...v1.17.0
|
|
[1.16.0]: https://github.com/urfave/cli/compare/v1.15.0...v1.16.0
|
|
[1.15.0]: https://github.com/urfave/cli/compare/v1.14.0...v1.15.0
|
|
[1.14.0]: https://github.com/urfave/cli/compare/v1.13.0...v1.14.0
|
|
[1.13.0]: https://github.com/urfave/cli/compare/v1.12.0...v1.13.0
|
|
[1.12.0]: https://github.com/urfave/cli/compare/v1.11.1...v1.12.0
|
|
[1.11.1]: https://github.com/urfave/cli/compare/v1.11.0...v1.11.1
|
|
[1.11.0]: https://github.com/urfave/cli/compare/v1.10.2...v1.11.0
|
|
[1.10.2]: https://github.com/urfave/cli/compare/v1.10.1...v1.10.2
|
|
[1.10.1]: https://github.com/urfave/cli/compare/v1.10.0...v1.10.1
|
|
[1.10.0]: https://github.com/urfave/cli/compare/v1.9.0...v1.10.0
|
|
[1.9.0]: https://github.com/urfave/cli/compare/v1.8.0...v1.9.0
|
|
[1.8.0]: https://github.com/urfave/cli/compare/v1.7.1...v1.8.0
|
|
[1.7.1]: https://github.com/urfave/cli/compare/v1.7.0...v1.7.1
|
|
[1.7.0]: https://github.com/urfave/cli/compare/v1.6.0...v1.7.0
|
|
[1.6.0]: https://github.com/urfave/cli/compare/v1.5.0...v1.6.0
|
|
[1.5.0]: https://github.com/urfave/cli/compare/v1.4.1...v1.5.0
|
|
[1.4.1]: https://github.com/urfave/cli/compare/v1.4.0...v1.4.1
|
|
[1.4.0]: https://github.com/urfave/cli/compare/v1.3.1...v1.4.0
|
|
[1.3.1]: https://github.com/urfave/cli/compare/v1.3.0...v1.3.1
|
|
[1.3.0]: https://github.com/urfave/cli/compare/v1.2.0...v1.3.0
|
|
[1.2.0]: https://github.com/urfave/cli/compare/v1.1.0...v1.2.0
|
|
[1.1.0]: https://github.com/urfave/cli/compare/v1.0.0...v1.1.0
|
|
[1.0.0]: https://github.com/urfave/cli/compare/v0.1.0...v1.0.0
|