more complete readme

This commit is contained in:
spf13 2013-09-24 16:45:20 -04:00
parent fb2146e9e5
commit f0d16a4984

View file

@ -79,16 +79,30 @@ execute the commander.
var cmdPrint = &cobra.Command{ var cmdPrint = &cobra.Command{
Use: "print [string to print]", Use: "print [string to print]",
Short: "Print anything to the screen", Short: "Print anything to the screen",
Long: `an utterly useless command for testing.`, Long: `print is for printing anything back to the screen.
For many years people have printed back to the screen.
`,
Run: func(cmd *cobra.Command, args []string) { Run: func(cmd *cobra.Command, args []string) {
fmt.Println("Print: " + strings.Join(args, " ")) fmt.Println("Print: " + strings.Join(args, " "))
}, },
} }
var cmdEcho = &cobra.Command{ var cmdEcho = &Command{
Use: "echo [string to echo]", Use: "echo [string to echo]",
Short: "Echo anything to the screen", Short: "Echo anything to the screen",
Long: `an utterly useless command for testing.`, Long: `echo is for echoing anything back.
Echo works a lot like print, except it has a child command.
`,
Run: func(cmd *cobra.Command, args []string) {
fmt.Println("Print: " + strings.Join(args, " "))
},
}
var cmdTimes = &Command{
Use: "times [# times] [string to echo]",
Short: "Echo anything to the screen more times",
Long: `echo things multiple times back to the user by providing
a count and a string.`,
Run: func(cmd *cobra.Command, args []string) { Run: func(cmd *cobra.Command, args []string) {
for i:=0; i < echoTimes; i++ { for i:=0; i < echoTimes; i++ {
fmt.Println("Echo: " + strings.Join(args, " ")) fmt.Println("Echo: " + strings.Join(args, " "))
@ -97,22 +111,32 @@ execute the commander.
} }
cmdEcho.Flags().IntVarP(&echoTimes, "times", "t", 1, "times to echo the input") cmdTimes().IntVarP(&echoTimes, "times", "t", 1, "times to echo the input")
var commander = cobra.Commander() var commander = cobra.Commander()
commander.SetName("Cobra") commander.SetName("CobraExample")
commander.AddCommand(cmdPrint, cmdEcho) commander.AddCommand(cmdPrint, cmdEcho)
cmdEcho.AddCommand(cmdTimes)
commander.Execute() commander.Execute()
} }
## Release Notes ## Release Notes
* **0.7.0** Sept 24, 2013
* Needs more eyes
* Test suite
* Support for automatic error messages
* Support for help command
* Support for printing to any io.Writer instead of os.Stderr
* Support for persistent flags which cascade down tree
* Ready for integration into Hugo
* **0.1.0** Sept 3, 2013 * **0.1.0** Sept 3, 2013
* Implement first draft * Implement first draft
## ToDo
* More testing of non-runnable
* More testing
* Launch proper documentation site
## Contributing ## Contributing
1. Fork it 1. Fork it