Skip to content

go-phings/broccli

Repository files navigation

broccli

Go Reference Go Report Card


The go-phings/broccli package simplifies command line interface management. It allows you to define commands complete with arguments and flags, and attach handlers to them. The package handles all the parsing automatically.


Table of Contents

Sample code

Example dummy application can be found in cmd/example1 directory.

However, the following code snippet from another tiny project shows how the module can be used.

// create new CLI object
cli := broccli.NewCLI("snakey-letters", "Classic snake but with letters and words!", "")

// add a command and attach a function to it
cmd := cli.AddCmd("start", "Starts the game", startHandler)
// add a flag to the command
cmd.AddFlag("words", "f", "", 
    "Text file with wordlist", 
    // should be a path to a file
    broccli.TypePathFile,
    // flag is required (cannot be empty) and path must exist
    broccli.IsExistent|broccli.IsRequired,
)

// add another command to print version number
_ = cli.AddCmd("version", "Shows version", versionHandler)

// run cli
os.Exit(cli.Run())

// handlers for each command
func startHandler(c *broccli.CLI) int {
	fmt.Fprint(os.Stdout, "Starting with file %s...", c.Flag("words"))
	return 0
}

func versionHandler(c *broccli.CLI) int {
    fmt.Fprintf(os.Stdout, VERSION+"\n")
    return 0
}

Structs explained

CLI

The main CLI object has three arguments such as name, description and author. These guys are displayed when syntax is printed out.

Commands

Method AddCmd creates a new command which has the following properties.

  • a name, used to call it
  • short description - few words to display what the command does on the syntax screen
  • handler function that is executed when the command is called and all its flags and argument are valid

Command Options

Optionally, after command flags and arguments are successfully validated, and just before the execution of handler, additional code (func) can be executed. This can be passed as a last argument.

cmd := cli.AddCmd("start", "Starts the game", startHandler, 
    broccli.OnPostValidation(func(c *broccli.Cmd) {
        // do something, even with the command
    }),
)

See cmd_options.go for all available options.

Flags and Arguments

Each command can have arguments and flags, as shown below.

program some-command -f flag1 -g flag2 ARGUMENT1 ARGUMENT2

To setup a flag in a command, method AddFlag is used. It takes the following arguments:

  • name and alias that are used to call the flag (eg. --help and -h, without the hyphens in the func args)
  • valuePlaceholder, a placeholder that is printed out on the syntax screen, eg. in -f PATH_TO_FILE it is the PATH_TO_FILE
  • description - few words telling what the command does (syntax screen again)
  • types, an int64 value that defines the value type, currently one of TypeString, TypeBool, TypeInt, TypeFloat, TypeAlphanumeric or TypePathFile (see flags.go for more information)
  • flags, an int64 value containing validation requirement, eg. IsRequired|IsExistent|IsDirectory could be used with TypePathFile to require the flag to be a non-empty path to an existing directory (again, navigate to flags.go for more detailed information)

Optionally, a function can be attached to a boolean flag that is triggered when a flag is true. The motivation behind that was a use case when setting a certain flag to true would make another string flag required. However, it's not recommended to be used.

To add an argument for a command, method AddArg shall be used. It has almost the same arguments, apart from the fact that alias is not there.

Environment variables to check

Command may require environment variables. AddEnvVar can be called to setup environment variables that should be verified before running the command. For example, a variable might need to contain a path to an existing regular file.

Accessing flag and arg values

See sample code that does that below.

func startHandler(c *broccli.CLI) int {
	fmt.Fprint(os.Stdout, "Starting with level %s...", c.Arg("level"))
    fmt.Fprint(os.Stdout, "Writing moves to file %s...", c.Flag("somefile"))
	return 0
}

level and somefile are names of the argument (sometimes they are uppercase) and flag.

Features

  • Flags and arguments support
  • Validation for basic value types such as integer, float, string, bool
  • Additional value types of alpha-numeric and file path
  • Validation for multiple values, separated with colon or semicolon, eg. -t val1,val2,val3
  • Check for file existence and its type (can be directory, regular file or other)
  • Post validation hook
  • Boolean flag on-true hook before validation

About

Library for creating CLI applications in golang

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages