2020-07-29 17:11:41 +08:00
|
|
|
package docgen
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"strings"
|
|
|
|
|
2022-02-09 17:22:52 +08:00
|
|
|
"github.com/urfave/cli"
|
2022-01-25 23:15:07 +08:00
|
|
|
"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
|
|
|
)
|
|
|
|
|
2022-02-16 19:31:43 +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")
|
|
|
|
}
|
|
|
|
|
2021-02-18 15:08:20 +08:00
|
|
|
outputDir := c.String("o")
|
|
|
|
if len(outputDir) == 0 {
|
|
|
|
var err error
|
|
|
|
outputDir, err = os.Getwd()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-03 21:32:40 +08:00
|
|
|
if !pathx.FileExists(dir) {
|
2021-02-26 16:11:47 +08:00
|
|
|
return fmt.Errorf("dir %s not exsit", dir)
|
2021-02-18 15:08:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
dir, err := filepath.Abs(dir)
|
2020-07-29 17:11:41 +08:00
|
|
|
if err != nil {
|
2021-02-18 15:08:20 +08:00
|
|
|
return err
|
2020-07-29 17:11:41 +08:00
|
|
|
}
|
|
|
|
|
2021-02-18 15:08:20 +08:00
|
|
|
files, err := filePathWalkDir(dir)
|
2020-07-29 17:11:41 +08:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-02-18 15:08:20 +08:00
|
|
|
|
2021-11-03 20:57:03 +08:00
|
|
|
for _, p := range files {
|
|
|
|
api, err := parser.Parse(p)
|
2020-07-29 17:11:41 +08:00
|
|
|
if err != nil {
|
2022-02-16 19:31:43 +08:00
|
|
|
return fmt.Errorf("parse file: %s, err: %w", p, err)
|
2020-07-29 17:11:41 +08:00
|
|
|
}
|
2021-01-11 15:10:51 +08:00
|
|
|
|
2021-11-03 20:57:03 +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))
|
2021-02-18 15:08:20 +08:00
|
|
|
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
|
|
|
|
}
|