spf13--cobra/cobra/tpl/main.go

164 lines
4.6 KiB
Go
Raw Normal View History

// Copyright © 2021 Steve Francia <spf@spf13.com>.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package tpl
func MainTemplate() []byte {
2019-01-30 08:46:53 +00:00
return []byte(`/*
{{ .Copyright }}
2019-01-29 09:07:11 +00:00
{{ if .Legal.Header }}{{ .Legal.Header }}{{ end }}
*/
package main
import "{{ .PkgName }}/cmd"
func main() {
2019-12-23 20:51:40 +00:00
cmd.Execute()
}
`)
}
2019-01-29 09:07:11 +00:00
func RootTemplate() []byte {
2019-01-30 08:46:53 +00:00
return []byte(`/*
2019-01-29 09:07:11 +00:00
{{ .Copyright }}
{{ if .Legal.Header }}{{ .Legal.Header }}{{ end }}
*/
package cmd
import (
{{- if .Viper }}
"fmt"{{ end }}
2019-12-23 20:51:40 +00:00
"os"
"github.com/spf13/cobra"
{{- if .Viper }}
"github.com/spf13/viper"{{ end }}
2019-01-29 09:07:11 +00:00
)
2019-12-23 20:51:40 +00:00
{{ if .Viper -}}
2019-01-29 09:07:11 +00:00
var cfgFile string
2019-12-23 20:51:40 +00:00
{{- end }}
2019-01-29 09:07:11 +00:00
// rootCmd represents the base command when called without any subcommands
var rootCmd = &cobra.Command{
2019-12-23 20:51:40 +00:00
Use: "{{ .AppName }}",
Short: "A brief description of your application",
Long: ` + "`" + `A longer description that spans multiple lines and likely contains
2019-01-29 09:07:11 +00:00
examples and usage of using your application. For example:
Cobra is a CLI library for Go that empowers applications.
This application is a tool to generate the needed files
to quickly create a Cobra application.` + "`" + `,
2019-12-23 20:51:40 +00:00
// Uncomment the following line if your bare application
// has an action associated with it:
// Run: func(cmd *cobra.Command, args []string) { },
2019-01-29 09:07:11 +00:00
}
// Execute adds all child commands to the root command and sets flags appropriately.
// This is called by main.main(). It only needs to happen once to the rootCmd.
func Execute() {
err := rootCmd.Execute()
if err != nil {
os.Exit(1)
}
2019-01-29 09:07:11 +00:00
}
func init() {
{{- if .Viper }}
2019-12-23 20:51:40 +00:00
cobra.OnInitialize(initConfig)
2019-01-29 09:07:11 +00:00
{{ end }}
2019-12-23 20:51:40 +00:00
// Here you will define your flags and configuration settings.
// Cobra supports persistent flags, which, if defined here,
// will be global for your application.
2019-01-29 09:07:11 +00:00
{{ if .Viper }}
2019-12-23 20:51:40 +00:00
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.{{ .AppName }}.yaml)")
2019-01-29 09:07:11 +00:00
{{ else }}
2019-12-23 20:51:40 +00:00
// rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.{{ .AppName }}.yaml)")
2019-01-29 09:07:11 +00:00
{{ end }}
2019-12-23 20:51:40 +00:00
// Cobra also supports local flags, which will only run
// when this action is called directly.
rootCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
2019-01-29 09:07:11 +00:00
}
2019-12-23 20:51:40 +00:00
{{ if .Viper -}}
2019-01-29 09:07:11 +00:00
// initConfig reads in config file and ENV variables if set.
func initConfig() {
2019-12-23 20:51:40 +00:00
if cfgFile != "" {
// Use config file from the flag.
viper.SetConfigFile(cfgFile)
} else {
// Find home directory.
2019-06-07 19:48:51 +00:00
home, err := os.UserHomeDir()
cobra.CheckErr(err)
2019-12-23 20:51:40 +00:00
// Search config in home directory with name ".{{ .AppName }}" (without extension).
viper.AddConfigPath(home)
viper.SetConfigType("yaml")
2019-12-23 20:51:40 +00:00
viper.SetConfigName(".{{ .AppName }}")
}
viper.AutomaticEnv() // read in environment variables that match
// If a config file is found, read it in.
if err := viper.ReadInConfig(); err == nil {
fmt.Fprintln(os.Stderr, "Using config file:", viper.ConfigFileUsed())
2019-12-23 20:51:40 +00:00
}
2019-01-29 09:07:11 +00:00
}
2019-12-23 20:51:40 +00:00
{{- end }}
2019-01-29 09:07:11 +00:00
`)
}
2019-01-30 08:58:29 +00:00
func AddCommandTemplate() []byte {
return []byte(`/*
2019-01-30 09:44:39 +00:00
{{ .Project.Copyright }}
2019-01-31 03:47:38 +00:00
{{ if .Legal.Header }}{{ .Legal.Header }}{{ end }}
2019-01-30 08:58:29 +00:00
*/
package cmd
import (
"fmt"
"github.com/spf13/cobra"
)
// {{ .CmdName }}Cmd represents the {{ .CmdName }} command
var {{ .CmdName }}Cmd = &cobra.Command{
Use: "{{ .CmdName }}",
Short: "A brief description of your command",
Long: ` + "`" + `A longer description that spans multiple lines and likely contains examples
and usage of using your command. For example:
Cobra is a CLI library for Go that empowers applications.
This application is a tool to generate the needed files
to quickly create a Cobra application.` + "`" + `,
Run: func(cmd *cobra.Command, args []string) {
fmt.Println("{{ .CmdName }} called")
},
}
func init() {
{{ .CmdParent }}.AddCommand({{ .CmdName }}Cmd)
// Here you will define your flags and configuration settings.
// Cobra supports Persistent Flags which will work for this command
// and all subcommands, e.g.:
// {{ .CmdName }}Cmd.PersistentFlags().String("foo", "", "A help for foo")
// Cobra supports local flags which will only run when this command
// is called directly, e.g.:
// {{ .CmdName }}Cmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
}
`)
}