open-vault/vendor/github.com/mitchellh/cli
Hridoy Roy 4a96126d5a
Revert "Vault Dependency Upgrades [VAULT-871] (#10903)" (#10939)
This reverts commit eb74ca61fc4dcb7038f39defb127d5d639ba0ca1.
2021-02-18 15:40:18 -05:00
..
.travis.yml Backport leader status telemetry [VAULT-672] (#10147) 2020-10-15 14:15:58 -07:00
LICENSE Migrate to built-in Go vendoring. 2016-02-18 15:06:02 -05:00
Makefile Backport leader status telemetry [VAULT-672] (#10147) 2020-10-15 14:15:58 -07:00
README.md Bump deps 2017-07-18 10:15:54 -04:00
autocomplete.go Bump deps 2017-07-18 10:15:54 -04:00
cli.go Revert "Vault Dependency Upgrades [VAULT-871] (#10903)" (#10939) 2021-02-18 15:40:18 -05:00
command.go Bump deps 2017-07-18 10:15:54 -04:00
command_mock.go Bump deps 2017-07-18 10:15:54 -04:00
go.mod Backport leader status telemetry [VAULT-672] (#10147) 2020-10-15 14:15:58 -07:00
go.sum Update Deps (#5454) 2018-10-03 09:55:26 -07:00
help.go Update deps 2017-02-02 16:19:55 -05:00
ui.go Migrate to built-in Go vendoring. 2016-02-18 15:06:02 -05:00
ui_colored.go Update CLI coloring 2018-04-06 14:38:56 -04:00
ui_concurrent.go Migrate to built-in Go vendoring. 2016-02-18 15:06:02 -05:00
ui_mock.go Backport leader status telemetry [VAULT-672] (#10147) 2020-10-15 14:15:58 -07:00
ui_writer.go Migrate to built-in Go vendoring. 2016-02-18 15:06:02 -05:00

README.md

Go CLI Library GoDoc

cli is a library for implementing powerful command-line interfaces in Go. cli is the library that powers the CLI for Packer, Serf, Consul, Vault, Terraform, and Nomad.

Features

  • Easy sub-command based CLIs: cli foo, cli bar, etc.

  • Support for nested subcommands such as cli foo bar.

  • Optional support for default subcommands so cli does something other than error.

  • Support for shell autocompletion of subcommands, flags, and arguments with callbacks in Go. You don't need to write any shell code.

  • Automatic help generation for listing subcommands

  • Automatic help flag recognition of -h, --help, etc.

  • Automatic version flag recognition of -v, --version.

  • Helpers for interacting with the terminal, such as outputting information, asking for input, etc. These are optional, you can always interact with the terminal however you choose.

  • Use of Go interfaces/types makes augmenting various parts of the library a piece of cake.

Example

Below is a simple example of creating and running a CLI

package main

import (
	"log"
	"os"

	"github.com/mitchellh/cli"
)

func main() {
	c := cli.NewCLI("app", "1.0.0")
	c.Args = os.Args[1:]
	c.Commands = map[string]cli.CommandFactory{
		"foo": fooCommandFactory,
		"bar": barCommandFactory,
	}

	exitStatus, err := c.Run()
	if err != nil {
		log.Println(err)
	}

	os.Exit(exitStatus)
}