terraform-provider-gitea/vendor/github.com/mitchellh/cli
dependabot[bot] b4859cda6b
Bump github.com/hashicorp/terraform-plugin-docs from 0.7.0 to 0.13.0
Bumps [github.com/hashicorp/terraform-plugin-docs](https://github.com/hashicorp/terraform-plugin-docs) from 0.7.0 to 0.13.0.
- [Release notes](https://github.com/hashicorp/terraform-plugin-docs/releases)
- [Changelog](https://github.com/hashicorp/terraform-plugin-docs/blob/main/CHANGELOG.md)
- [Commits](https://github.com/hashicorp/terraform-plugin-docs/compare/v0.7.0...v0.13.0)

---
updated-dependencies:
- dependency-name: github.com/hashicorp/terraform-plugin-docs
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
2022-12-18 17:14:23 +00:00
..
autocomplete.go add vendor 2022-04-03 09:37:16 +05:30
cli.go Bump github.com/hashicorp/terraform-plugin-docs from 0.7.0 to 0.13.0 2022-12-18 17:14:23 +00:00
command_mock.go add vendor 2022-04-03 09:37:16 +05:30
command.go add vendor 2022-04-03 09:37:16 +05:30
help.go add vendor 2022-04-03 09:37:16 +05:30
LICENSE add vendor 2022-04-03 09:37:16 +05:30
Makefile add vendor 2022-04-03 09:37:16 +05:30
README.md Bump github.com/hashicorp/terraform-plugin-docs from 0.7.0 to 0.13.0 2022-12-18 17:14:23 +00:00
ui_colored.go add vendor 2022-04-03 09:37:16 +05:30
ui_concurrent.go add vendor 2022-04-03 09:37:16 +05:30
ui_mock.go add vendor 2022-04-03 09:37:16 +05:30
ui_writer.go add vendor 2022-04-03 09:37:16 +05:30
ui.go add vendor 2022-04-03 09:37:16 +05:30

Go CLI Library GoDoc

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

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)
}