123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- /*
- Copyright 2014 The Kubernetes Authors.
- 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 main
- import (
- "bytes"
- "fmt"
- "io/ioutil"
- "os"
- "strings"
- mangen "github.com/cpuguy83/go-md2man/md2man"
- "github.com/spf13/cobra"
- "github.com/spf13/pflag"
- "k8s.io/kubernetes/cmd/genutils"
- "k8s.io/kubernetes/pkg/kubectl/cmd"
- cmdutil "k8s.io/kubernetes/pkg/kubectl/cmd/util"
- )
- func main() {
- // use os.Args instead of "flags" because "flags" will mess up the man pages!
- path := "docs/man/man1"
- if len(os.Args) == 2 {
- path = os.Args[1]
- } else if len(os.Args) > 2 {
- fmt.Fprintf(os.Stderr, "usage: %s [output directory]\n", os.Args[0])
- os.Exit(1)
- }
- outDir, err := genutils.OutDir(path)
- if err != nil {
- fmt.Fprintf(os.Stderr, "failed to get output directory: %v\n", err)
- os.Exit(1)
- }
- // Set environment variables used by kubectl so the output is consistent,
- // regardless of where we run.
- os.Setenv("HOME", "/home/username")
- // TODO os.Stdin should really be something like ioutil.Discard, but a Reader
- kubectl := cmd.NewKubectlCommand(cmdutil.NewFactory(nil), os.Stdin, ioutil.Discard, ioutil.Discard)
- genMarkdown(kubectl, "", outDir)
- for _, c := range kubectl.Commands() {
- genMarkdown(c, "kubectl", outDir)
- }
- }
- func preamble(out *bytes.Buffer, name, short, long string) {
- out.WriteString(`% KUBERNETES(1) kubernetes User Manuals
- % Eric Paris
- % Jan 2015
- # NAME
- `)
- fmt.Fprintf(out, "%s \\- %s\n\n", name, short)
- fmt.Fprintf(out, "# SYNOPSIS\n")
- fmt.Fprintf(out, "**%s** [OPTIONS]\n\n", name)
- fmt.Fprintf(out, "# DESCRIPTION\n")
- fmt.Fprintf(out, "%s\n\n", long)
- }
- func printFlags(out *bytes.Buffer, flags *pflag.FlagSet) {
- flags.VisitAll(func(flag *pflag.Flag) {
- format := "**--%s**=%s\n\t%s\n\n"
- if flag.Value.Type() == "string" {
- // put quotes on the value
- format = "**--%s**=%q\n\t%s\n\n"
- }
- // Todo, when we mark a shorthand is deprecated, but specify an empty message.
- // The flag.ShorthandDeprecated is empty as the shorthand is deprecated.
- // Using len(flag.ShorthandDeprecated) > 0 can't handle this, others are ok.
- if !(len(flag.ShorthandDeprecated) > 0) && len(flag.Shorthand) > 0 {
- format = "**-%s**, " + format
- fmt.Fprintf(out, format, flag.Shorthand, flag.Name, flag.DefValue, flag.Usage)
- } else {
- fmt.Fprintf(out, format, flag.Name, flag.DefValue, flag.Usage)
- }
- })
- }
- func printOptions(out *bytes.Buffer, command *cobra.Command) {
- flags := command.NonInheritedFlags()
- if flags.HasFlags() {
- fmt.Fprintf(out, "# OPTIONS\n")
- printFlags(out, flags)
- fmt.Fprintf(out, "\n")
- }
- flags = command.InheritedFlags()
- if flags.HasFlags() {
- fmt.Fprintf(out, "# OPTIONS INHERITED FROM PARENT COMMANDS\n")
- printFlags(out, flags)
- fmt.Fprintf(out, "\n")
- }
- }
- func genMarkdown(command *cobra.Command, parent, docsDir string) {
- dparent := strings.Replace(parent, " ", "-", -1)
- name := command.Name()
- dname := name
- if len(parent) > 0 {
- dname = dparent + "-" + name
- name = parent + " " + name
- }
- out := new(bytes.Buffer)
- short := command.Short
- long := command.Long
- if len(long) == 0 {
- long = short
- }
- preamble(out, name, short, long)
- printOptions(out, command)
- if len(command.Example) > 0 {
- fmt.Fprintf(out, "# EXAMPLE\n")
- fmt.Fprintf(out, "```\n%s\n```\n", command.Example)
- }
- if len(command.Commands()) > 0 || len(parent) > 0 {
- fmt.Fprintf(out, "# SEE ALSO\n")
- if len(parent) > 0 {
- fmt.Fprintf(out, "**%s(1)**, ", dparent)
- }
- for _, c := range command.Commands() {
- fmt.Fprintf(out, "**%s-%s(1)**, ", dname, c.Name())
- genMarkdown(c, name, docsDir)
- }
- fmt.Fprintf(out, "\n")
- }
- out.WriteString(`
- # HISTORY
- January 2015, Originally compiled by Eric Paris (eparis at redhat dot com) based on the kubernetes source material, but hopefully they have been automatically generated since!
- `)
- final := mangen.Render(out.Bytes())
- filename := docsDir + dname + ".1"
- outFile, err := os.Create(filename)
- if err != nil {
- fmt.Println(err)
- os.Exit(1)
- }
- defer outFile.Close()
- _, err = outFile.Write(final)
- if err != nil {
- fmt.Println(err)
- os.Exit(1)
- }
- }
|