a lightweight cli and launcher
The pattern is to create your flags, run Parse, then use your flags.
// create flag
name, err := lighter.NewStringFlag("name", "enter the user's name", true)
// parse flags
err = lighter.Parse()
// use flag
fmt.Println("Hi, my name is", name.Value())
The supported flag types are string, bool, and int64. To create a flag use NewStringFlag(), NewBoolFlag(), and NewInt64Flag() functions.
These functions require the name and description of the flag as well as declaring whether the flag is required or not. Flags that are set as required and are not entered as a command line argument will return an error when parsed.
// create a required string flag
name, err := lighter.NewStringFlag("name", "enter the user's name", true)
if err != nil {
// display help message
lighter.HelpWithError(err)
os.Exit(1)
}
// create a required int flag
age, err := lighter.NewInt64Flag("age", "enter user's age", true)
if err != nil {
// display help message
lighter.HelpWithError(err)
os.Exit(1)
}
// create an optional bool flag
admin, err := lighter.NewBoolFlag("admin", "set admin privileges", false )
if err != nil {
// display help message
lighter.HelpWithError(err)
os.Exit(1)
}
if err := lighter.Parse; err != nil {
// display help message
lighter.HelpWithError(err)
os.Exit(1)
}
fmt.Println("name:", name.Value())
fmt.Println("age:", age.Value())
fmt.Println("is admin:", admin.Value())
The following:
./MyApp --name john --age 32
Will result in:
name: john
age: 32
is admin: false
If you want to check if an optional flag was entered, you can use the IsSet()
method.
age, err := lighter.NewInt64Flag("age", "enter user's age", false)
checkErr(err)
err = lighter.Parse
checkErr(err)
if age.IsSet() {
fmt.Println("The age was set to", age.Value())
}