aboutsummaryrefslogtreecommitdiffstats
path: root/cmd/docs.go
diff options
context:
space:
mode:
authorJohn Olheiser <john.olheiser@gmail.com>2020-11-06 18:32:57 -0600
committerGitHub <noreply@github.com>2020-11-07 08:32:57 +0800
commit172eca1cd3c17d92e4bee63b1d0ab66f3021df25 (patch)
tree06cc0eff44dfa2b8d3721ea82935df40aa4c2480 /cmd/docs.go
parent30ce3731a17913155436cee323b1e7016ad8eb49 (diff)
downloadgitea-172eca1cd3c17d92e4bee63b1d0ab66f3021df25.tar.gz
gitea-172eca1cd3c17d92e4bee63b1d0ab66f3021df25.zip
Add docs command (#13429)
Signed-off-by: jolheiser <john.olheiser@gmail.com>
Diffstat (limited to 'cmd/docs.go')
-rw-r--r--cmd/docs.go61
1 files changed, 61 insertions, 0 deletions
diff --git a/cmd/docs.go b/cmd/docs.go
new file mode 100644
index 0000000000..52233c7ac8
--- /dev/null
+++ b/cmd/docs.go
@@ -0,0 +1,61 @@
+// Copyright 2020 The Gitea Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package cmd
+
+import (
+ "fmt"
+ "os"
+ "strings"
+
+ "github.com/urfave/cli"
+)
+
+// CmdDocs represents the available docs sub-command.
+var CmdDocs = cli.Command{
+ Name: "docs",
+ Usage: "Output CLI documentation",
+ Description: "A command to output Gitea's CLI documentation, optionally to a file.",
+ Action: runDocs,
+ Flags: []cli.Flag{
+ &cli.BoolFlag{
+ Name: "man",
+ Usage: "Output man pages instead",
+ },
+ &cli.StringFlag{
+ Name: "output, o",
+ Usage: "Path to output to instead of stdout (will overwrite if exists)",
+ },
+ },
+}
+
+func runDocs(ctx *cli.Context) error {
+ docs, err := ctx.App.ToMarkdown()
+ if ctx.Bool("man") {
+ docs, err = ctx.App.ToMan()
+ }
+ if err != nil {
+ return err
+ }
+
+ if !ctx.Bool("man") {
+ // Clean up markdown. The following bug was fixed in v2, but is present in v1.
+ // It affects markdown output (even though the issue is referring to man pages)
+ // https://github.com/urfave/cli/issues/1040
+ docs = docs[strings.Index(docs, "#"):]
+ }
+
+ out := os.Stdout
+ if ctx.String("output") != "" {
+ fi, err := os.Create(ctx.String("output"))
+ if err != nil {
+ return err
+ }
+ defer fi.Close()
+ out = fi
+ }
+
+ _, err = fmt.Fprintln(out, docs)
+ return err
+}