generate.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. package main
  2. import (
  3. "fmt"
  4. "io/ioutil"
  5. "log"
  6. "os"
  7. "path/filepath"
  8. "github.com/docker/docker/cli/command"
  9. "github.com/docker/docker/cli/command/commands"
  10. "github.com/docker/docker/pkg/term"
  11. "github.com/spf13/cobra"
  12. "github.com/spf13/cobra/doc"
  13. "github.com/spf13/pflag"
  14. )
  15. const descriptionSourcePath = "man/src/"
  16. func generateManPages(opts *options) error {
  17. header := &doc.GenManHeader{
  18. Title: "DOCKER",
  19. Section: "1",
  20. Source: "Docker Community",
  21. }
  22. stdin, stdout, stderr := term.StdStreams()
  23. dockerCli := command.NewDockerCli(stdin, stdout, stderr)
  24. cmd := &cobra.Command{Use: "docker"}
  25. commands.AddCommands(cmd, dockerCli)
  26. source := filepath.Join(opts.source, descriptionSourcePath)
  27. if err := loadLongDescription(cmd, source); err != nil {
  28. return err
  29. }
  30. cmd.DisableAutoGenTag = true
  31. return doc.GenManTreeFromOpts(cmd, doc.GenManTreeOptions{
  32. Header: header,
  33. Path: opts.target,
  34. CommandSeparator: "-",
  35. })
  36. }
  37. func loadLongDescription(cmd *cobra.Command, path string) error {
  38. for _, cmd := range cmd.Commands() {
  39. if cmd.Name() == "" {
  40. continue
  41. }
  42. fullpath := filepath.Join(path, cmd.Name()+".md")
  43. if cmd.HasSubCommands() {
  44. loadLongDescription(cmd, filepath.Join(path, cmd.Name()))
  45. }
  46. if _, err := os.Stat(fullpath); err != nil {
  47. log.Printf("WARN: %s does not exist, skipping\n", fullpath)
  48. continue
  49. }
  50. content, err := ioutil.ReadFile(fullpath)
  51. if err != nil {
  52. return err
  53. }
  54. cmd.Long = string(content)
  55. fullpath = filepath.Join(path, cmd.Name()+"-example.md")
  56. if _, err := os.Stat(fullpath); err != nil {
  57. continue
  58. }
  59. content, err = ioutil.ReadFile(fullpath)
  60. if err != nil {
  61. return err
  62. }
  63. cmd.Example = string(content)
  64. }
  65. return nil
  66. }
  67. type options struct {
  68. source string
  69. target string
  70. }
  71. func parseArgs() (*options, error) {
  72. opts := &options{}
  73. cwd, _ := os.Getwd()
  74. flags := pflag.NewFlagSet(os.Args[0], pflag.ContinueOnError)
  75. flags.StringVar(&opts.source, "root", cwd, "Path to project root")
  76. flags.StringVar(&opts.target, "target", "/tmp", "Target path for generated man pages")
  77. err := flags.Parse(os.Args[1:])
  78. return opts, err
  79. }
  80. func main() {
  81. opts, err := parseArgs()
  82. if err != nil {
  83. fmt.Fprintln(os.Stderr, err.Error())
  84. }
  85. fmt.Printf("Project root: %s\n", opts.source)
  86. fmt.Printf("Generating man pages into %s\n", opts.target)
  87. if err := generateManPages(opts); err != nil {
  88. fmt.Fprintf(os.Stderr, "Failed to generate man pages: %s\n", err.Error())
  89. }
  90. }