From 172eca1cd3c17d92e4bee63b1d0ab66f3021df25 Mon Sep 17 00:00:00 2001 From: John Olheiser Date: Fri, 6 Nov 2020 18:32:57 -0600 Subject: [PATCH] Add docs command (#13429) Signed-off-by: jolheiser --- cmd/docs.go | 61 +++++++++++++++++++++++++++++++++++++++++++++++++++++ main.go | 1 + 2 files changed, 62 insertions(+) create mode 100644 cmd/docs.go diff --git a/cmd/docs.go b/cmd/docs.go new file mode 100644 index 000000000..52233c7ac --- /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 +} diff --git a/main.go b/main.go index 429314acc..e4fe220e8 100644 --- a/main.go +++ b/main.go @@ -69,6 +69,7 @@ arguments - which can alternatively be run by running the subcommand web.` cmd.CmdManager, cmd.Cmdembedded, cmd.CmdMigrateStorage, + cmd.CmdDocs, } // Now adjust these commands to add our global configuration options