Go to file
Mostyn Bramley-Moore 500d6b04e6 Report the source of a value when we cannot parse it
If you allow a flag to be set from environment variables or files and
a parse error occurs from one of them, it is very useful for the error
message to mention where the value came from.

Without this, it can be difficult to notice an error caused by an
unexpected environment variable being set.

Implements #1167.
2020-11-03 23:57:00 +01:00
.github Add Support for Go 1.15 2020-10-31 00:08:57 +05:30
altsrc Update altsrc/map_input_source.go 2020-10-22 10:00:45 +03:00
autocomplete Added manual and script for PowerShell autocomplete 2020-05-18 11:19:00 +08:00
docs Merge pull request #1139 from kirinnee/master 2020-10-31 11:56:33 -04:00
internal Reduce desiredMinBinarySize 2020-10-31 00:14:08 +05:30
testdata fish.go: support PathFlag.TakesFile [#1156] 2020-06-22 17:24:44 -07:00
.flake8 Allow slightly longer lines in Python scripts 2017-02-14 21:17:05 -08:00
.gitignore add diffing 2020-02-29 14:00:26 -08:00
app_test.go feature: Add a App.Reader that defaults to os.Stdin 2020-10-02 12:39:44 +02:00
app.go Merge pull request #1191 from stellirin/master 2020-10-21 21:49:32 -04:00
args.go add is set method to flag interface - refer #294 2019-09-15 18:46:52 +05:30
category.go amend comments 2019-12-12 21:29:09 +00:00
cli.go Merge master @1.22.1 with v2 2019-09-13 05:17:24 +05:30
CODE_OF_CONDUCT.md Adjust contribution and maintainer prose per current reality 2018-02-20 12:40:43 -05:00
command_test.go added test for successfully used -v flag on command with subcommands 2020-06-18 09:34:54 +03:00
command.go hide version flag for subcommands 2020-06-18 00:24:04 +03:00
context_test.go test(context): Change the StringSliceFlag to a pointer 2020-05-03 11:14:51 +02:00
context.go remove unused code 2019-12-31 16:36:01 +01:00
docs_test.go Merge branch 'master' into github-actions-windows 2020-01-13 11:29:49 +05:30
docs.go Use VisibleFlags during doc generation 2019-12-19 08:38:43 -05:00
errors_test.go Update docs and tests around cli.Exit 2020-03-24 20:32:39 -04:00
errors.go Update docs and tests around cli.Exit 2020-03-24 20:32:39 -04:00
fish_test.go fish.go: support PathFlag.TakesFile [#1156] 2020-06-22 17:24:44 -07:00
fish.go Revert "Refactor fishAddFileFlag for better flexibility [#1156]" 2020-10-22 14:22:01 -07:00
flag_bool.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_duration.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_float64_slice.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_float64.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_generic.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_int64_slice.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_int64.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_int_slice.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_int.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_path.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_string_slice.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_string.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_test.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_timestamp.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_uint64.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag_uint.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
flag.go Report the source of a value when we cannot parse it 2020-11-03 23:57:00 +01:00
funcs.go Fix test cases for context, docs, errors, fish, flags and funcs 2019-09-15 11:01:20 +05:30
go.mod Bump gopkg.in/yaml.v2 to v2.2.3 2020-09-18 09:16:14 -07:00
go.sum Bump gopkg.in/yaml.v2 to v2.2.3 2020-09-18 09:16:14 -07:00
help_test.go Added template functions for multi-line Description formatting. 2020-08-17 16:02:40 -04:00
help.go Merge pull request #1175 from imle/imle/add-better-multi-line-description-formatting 2020-11-01 14:29:08 +05:30
helpers_test.go remove unused code 2019-12-31 16:36:01 +01:00
LICENSE Update license text 2016-06-21 12:52:25 -04:00
parse.go revert testing change 2019-11-27 20:37:23 -08:00
README.md Link to migration guide 2020-04-04 06:09:14 -04:00
sort_test.go Consider case when sorting strings 2017-10-28 03:00:11 -04:00
sort.go Consider case when sorting strings 2017-10-28 03:00:11 -04:00
template.go Added template functions for multi-line Description formatting. 2020-08-17 16:02:40 -04:00

cli

GoDoc codebeat Go Report Card codecov

cli is a simple, fast, and fun package for building command line apps in Go. The goal is to enable developers to write fast and distributable command line applications in an expressive way.

Usage Documentation

Usage documentation exists for each major version. Don't know what version you're on? You're probably using the version from the master branch, which is currently v2.

Guides for migrating to newer versions:

Installation

Using this package requires a working Go environment. See the install instructions for Go.

Go Modules are required when using this package. See the go blog guide on using Go Modules.

Using v2 releases

$ GO111MODULE=on go get github.com/urfave/cli/v2
...
import (
  "github.com/urfave/cli/v2" // imports as package "cli"
)
...

Using v1 releases

$ GO111MODULE=on go get github.com/urfave/cli
...
import (
  "github.com/urfave/cli"
)
...

GOPATH

Make sure your PATH includes the $GOPATH/bin directory so your commands can be easily used:

export PATH=$PATH:$GOPATH/bin

Supported platforms

cli is tested against multiple versions of Go on Linux, and against the latest released version of Go on OS X and Windows. This project uses Github Actions for builds. To see our currently supported go versions and platforms, look at the ./.github/workflows/cli.yml.