git-project-manager/cmd/docs.go

63 lines
1.5 KiB
Go
Raw Normal View History

2024-12-19 19:51:26 +00:00
package cmd
import (
"os"
"github.com/spf13/cobra"
"github.com/spf13/cobra/doc"
2024-12-30 20:50:31 +00:00
"gitea.libretechconsulting.com/rmcguire/git-project-manager/cmd/util"
2024-12-19 19:51:26 +00:00
)
var docsCmd = &cobra.Command{
Use: "docs",
Aliases: []string{"documentation"},
Short: "Generate documentation for git-project-manager",
Args: cobra.RangeArgs(1, 1),
ValidArgs: []string{"md", "man", "yaml"},
Run: runDocsCmd,
}
func runDocsCmd(cmd *cobra.Command, args []string) {
2024-12-30 20:50:31 +00:00
outDir, err := cmd.Flags().GetString(util.FlagDocsPath)
2024-12-19 19:51:26 +00:00
if err != nil {
2024-12-30 20:50:31 +00:00
utils.Logger().Error("missing docs path")
2024-12-19 19:51:26 +00:00
}
prepareDocsDir(cmd, outDir)
switch args[0] {
case "md":
err = doc.GenMarkdownTree(cmd.Root(), outDir)
case "man":
err = doc.GenManTree(cmd.Root(), &doc.GenManHeader{
Title: "EIA Client",
Section: "1",
}, outDir)
case "yaml":
err = doc.GenYamlTree(cmd.Root(), outDir)
default:
2024-12-30 20:50:31 +00:00
utils.Logger().Error("invalid docs type", utils.Logger().Args("type", args[0]))
2024-12-19 19:51:26 +00:00
}
2024-12-30 20:50:31 +00:00
utils.Logger().Info("docs generation complete", utils.Logger().Args(
2024-12-27 22:42:44 +00:00
"type", args[0], "docsDir", outDir, "err", err))
2024-12-19 19:51:26 +00:00
}
2024-12-27 22:42:44 +00:00
func prepareDocsDir(_ *cobra.Command, outDir string) {
2024-12-19 19:51:26 +00:00
_, err := os.Stat(outDir)
if err != nil {
err = os.Mkdir(outDir, 0o755)
if err != nil {
2024-12-30 20:50:31 +00:00
utils.Logger().Error("failed to create docs path", utils.Logger().Args(
2024-12-19 19:51:26 +00:00
"error", err.Error(), "docsDir", outDir))
}
}
}
func init() {
2024-12-30 20:50:31 +00:00
docsCmd.PersistentFlags().StringP(util.FlagDocsPath, "d", "./docs", "specify output directory for documentation")
2024-12-19 19:51:26 +00:00
rootCmd.AddCommand(docsCmd)
}