Files
cunicu/cmd/wice/docs.go
Steffen Vogel 8576b24331 fix markdown codestyle issues
Signed-off-by: Steffen Vogel <post@steffenvogel.de>
2022-02-04 12:20:10 +01:00

84 lines
1.7 KiB
Go

package main
import (
"fmt"
"os"
"path/filepath"
"time"
"github.com/spf13/cobra"
"github.com/spf13/cobra/doc"
)
var (
outputDir string
docsCmd = &cobra.Command{
Use: "docs",
Short: "Generate documentation for the wice commands",
Hidden: true,
Args: cobra.NoArgs,
RunE: func(cmd *cobra.Command, args []string) error {
if err := docsMarkdown(cmd, args); err != nil {
return err
}
return docsManpage(cmd, args)
},
}
docsMarkdownCmd = &cobra.Command{
Use: "markdown",
Short: "Generate markdown docs",
RunE: docsMarkdown,
Args: cobra.NoArgs,
}
docsManpageCmd = &cobra.Command{
Use: "man",
Short: "Generate manpages",
RunE: docsManpage,
Args: cobra.NoArgs,
}
)
func init() {
rootCmd.AddCommand(docsCmd)
docsCmd.AddCommand(docsManpageCmd)
docsCmd.AddCommand(docsMarkdownCmd)
pf := docsCmd.PersistentFlags()
pf.StringVar(&outputDir, "output-dir", "./docs/usage", "Output directory of generated documenation")
}
func docsMarkdown(cmd *cobra.Command, args []string) error {
dir := filepath.Join(outputDir, "md")
if err := os.MkdirAll(dir, 0755); err != nil {
return fmt.Errorf("failed to create directory: %w", err)
}
return doc.GenMarkdownTree(rootCmd, dir)
}
func docsManpage(cmd *cobra.Command, args []string) error {
dir := filepath.Join(outputDir, "man")
if err := os.MkdirAll(dir, 0755); err != nil {
return fmt.Errorf("failed to create directory: %w", err)
}
d, err := time.Parse(time.RFC3339, date)
if err != nil {
return fmt.Errorf("failed to parse build date")
}
header := &doc.GenManHeader{
Title: "WICE",
Section: "3",
Source: "https://github.com/stv0g/wice",
Date: &d,
}
return doc.GenManTree(rootCmd, header, dir)
}