fj/cmd/manpages.go
sid c3e8ad67ed
Some checks are pending
CI / lint (push) Waiting to run
CI / build (push) Waiting to run
CI / test (push) Waiting to run
CI / functional (push) Blocked by required conditions
complete fgj → fj rename: env vars, config migration, docs
- Rename env vars: FGJ_HOST → FJ_HOST, FGJ_TOKEN → FJ_TOKEN,
  FGJ_FORCE_TTY → FJ_FORCE_TTY, FGJ_PAGER → FJ_PAGER,
  FGJ_BINARY_PATH → FJ_BINARY_PATH (all with legacy fallback)
- Auto-migrate ~/.config/fgj/ → ~/.config/fj/ on first run
- Update man page title, README, CHANGELOG
- Update test fixture labels from [FGJ E2E Test] to [FJ E2E Test]
2026-04-26 08:23:48 -06:00

49 lines
1 KiB
Go

package cmd
import (
"fmt"
"os"
"path/filepath"
"github.com/spf13/cobra"
"github.com/spf13/cobra/doc"
)
var manpagesCmd = &cobra.Command{
Use: "manpages",
Short: "Generate manpages",
Long: "Generate manpages for fj commands.",
RunE: func(cmd *cobra.Command, args []string) error {
dir, _ := cmd.Flags().GetString("dir")
if dir == "" {
return fmt.Errorf("directory is required")
}
if err := os.MkdirAll(dir, 0755); err != nil {
return fmt.Errorf("failed to create %s: %w", dir, err)
}
absDir, err := filepath.Abs(dir)
if err != nil {
return fmt.Errorf("failed to resolve %s: %w", dir, err)
}
header := &doc.GenManHeader{
Title: "FJ",
Section: "1",
}
if err := doc.GenManTree(rootCmd, header, absDir); err != nil {
return fmt.Errorf("failed to generate manpages: %w", err)
}
fmt.Printf("Manpages generated in %s\n", absDir)
return nil
},
}
func init() {
rootCmd.AddCommand(manpagesCmd)
manpagesCmd.Flags().String("dir", "", "Output directory for manpages")
_ = manpagesCmd.MarkFlagRequired("dir")
}