Initial CLI docs (#565)
As title, then we could potentially start ingesting these in the docs repo as they are expanded. Reviewed-on: https://gitea.com/gitea/tea/pulls/565 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: jolheiser <john.olheiser@gmail.com> Co-committed-by: jolheiser <john.olheiser@gmail.com>
This commit is contained in:
parent
e4e8eb07d2
commit
0869c15a6c
|
@ -20,6 +20,7 @@ jobs:
|
||||||
make lint
|
make lint
|
||||||
make fmt-check
|
make fmt-check
|
||||||
make misspell-check
|
make misspell-check
|
||||||
|
make docs-check
|
||||||
make build
|
make build
|
||||||
env:
|
env:
|
||||||
GOPROXY: https://goproxy.io,direct
|
GOPROXY: https://goproxy.io,direct
|
||||||
|
|
13
Makefile
13
Makefile
|
@ -87,6 +87,19 @@ fmt-check:
|
||||||
exit 1; \
|
exit 1; \
|
||||||
fi;
|
fi;
|
||||||
|
|
||||||
|
.PHONY: docs
|
||||||
|
docs:
|
||||||
|
$(GO) run . docs --out docs/CLI.md
|
||||||
|
|
||||||
|
.PHONY: docs-check
|
||||||
|
docs-check:
|
||||||
|
@DIFF=$$($(GO) run . docs | diff docs/CLI.md -); \
|
||||||
|
if [ -n "$$DIFF" ]; then \
|
||||||
|
echo "Please run 'make docs' and commit the result:"; \
|
||||||
|
echo "$$DIFF"; \
|
||||||
|
exit 1; \
|
||||||
|
fi;
|
||||||
|
|
||||||
.PHONY: test
|
.PHONY: test
|
||||||
test:
|
test:
|
||||||
$(GO) test -tags='sqlite sqlite_unlock_notify' $(PACKAGES)
|
$(GO) test -tags='sqlite sqlite_unlock_notify' $(PACKAGES)
|
||||||
|
|
|
@ -0,0 +1,56 @@
|
||||||
|
// Copyright 2023 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"
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
|
"github.com/urfave/cli/v2"
|
||||||
|
)
|
||||||
|
|
||||||
|
// CmdDocs generates markdown for tea
|
||||||
|
var CmdDocs = cli.Command{
|
||||||
|
Name: "docs",
|
||||||
|
Hidden: true,
|
||||||
|
Description: "Generate CLI docs",
|
||||||
|
Action: runDocs,
|
||||||
|
Flags: []cli.Flag{
|
||||||
|
&cli.StringFlag{
|
||||||
|
Name: "out",
|
||||||
|
Usage: "Path to output docs to, otherwise prints to stdout",
|
||||||
|
Aliases: []string{"o"},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
func runDocs(ctx *cli.Context) error {
|
||||||
|
md, err := ctx.App.ToMarkdown()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
outPath := ctx.String("out")
|
||||||
|
if outPath == "" {
|
||||||
|
fmt.Print(md)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := os.MkdirAll(filepath.Dir(outPath), os.ModePerm); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
fi, err := os.Create(outPath)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer fi.Close()
|
||||||
|
if _, err := fi.WriteString(md); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue