go-zero/tools/goctl/api/docgen/gen.go

71 lines
1.4 KiB
Go
Raw Normal View History

2020-07-29 17:11:41 +08:00
package docgen
import (
"errors"
"fmt"
"os"
"path/filepath"
"strings"
"github.com/urfave/cli"
"github.com/zeromicro/go-zero/tools/goctl/api/parser"
"github.com/zeromicro/go-zero/tools/goctl/util/pathx"
2020-07-29 17:11:41 +08:00
)
// DocCommand generate Markdown doc file
2020-07-29 17:11:41 +08:00
func DocCommand(c *cli.Context) error {
dir := c.String("dir")
if len(dir) == 0 {
return errors.New("missing -dir")
}
outputDir := c.String("o")
if len(outputDir) == 0 {
var err error
outputDir, err = os.Getwd()
if err != nil {
return err
}
}
if !pathx.FileExists(dir) {
return fmt.Errorf("dir %s not exsit", dir)
}
dir, err := filepath.Abs(dir)
2020-07-29 17:11:41 +08:00
if err != nil {
return err
2020-07-29 17:11:41 +08:00
}
files, err := filePathWalkDir(dir)
2020-07-29 17:11:41 +08:00
if err != nil {
return err
}
for _, p := range files {
api, err := parser.Parse(p)
2020-07-29 17:11:41 +08:00
if err != nil {
return fmt.Errorf("parse file: %s, err: %w", p, err)
2020-07-29 17:11:41 +08:00
}
api.Service = api.Service.JoinPrefix()
err = genDoc(api, filepath.Dir(filepath.Join(outputDir, p[len(dir):])),
strings.Replace(p[len(filepath.Dir(p)):], ".api", ".md", 1))
if err != nil {
return err
2020-07-29 17:11:41 +08:00
}
}
return nil
}
func filePathWalkDir(root string) ([]string, error) {
var files []string
err := filepath.Walk(root, func(path string, info os.FileInfo, err error) error {
if !info.IsDir() && strings.HasSuffix(path, ".api") {
files = append(files, path)
}
return nil
})
return files, err
}