Hilbish/cmd/docgen/docgen.go

79 lines
1.7 KiB
Go
Raw Normal View History

2021-10-16 03:58:56 +00:00
package main
import (
"fmt"
"path/filepath"
"go/ast"
2021-10-16 03:58:56 +00:00
"go/doc"
"go/parser"
"go/token"
"strings"
"os"
2021-10-16 03:58:56 +00:00
)
// feel free to clean this up
// it works, dont really care about the code
2021-10-16 03:58:56 +00:00
func main() {
fset := token.NewFileSet()
dirs := []string{"./"}
filepath.Walk("golibs/", func (path string, info os.FileInfo, err error) error {
if !info.IsDir() {
return nil
}
dirs = append(dirs, "./" + path)
return nil
})
pkgs := make(map[string]*ast.Package)
for _, path := range dirs {
d, err := parser.ParseDir(fset, path, nil, parser.ParseComments)
if err != nil {
fmt.Println(err)
return
}
for k, v := range d {
pkgs[k] = v
}
2021-10-16 03:58:56 +00:00
}
prefix := map[string]string{
"hilbish": "hl",
"fs": "f",
"commander": "c",
"bait": "b",
"terminal": "term",
}
docs := make(map[string][]string)
2021-10-16 03:58:56 +00:00
for l, f := range pkgs {
p := doc.New(f, "./", doc.AllDecls)
2021-10-16 03:58:56 +00:00
for _, t := range p.Funcs {
mod := l
if strings.HasPrefix(t.Name, "hl") { mod = "hilbish" }
if !strings.HasPrefix(t.Name, prefix[mod]) || t.Name == "Loader" { continue }
parts := strings.Split(strings.TrimSpace(t.Doc), "\n")
funcsig := parts[0]
doc := parts[1:]
docs[mod] = append(docs[mod], funcsig + " > " + strings.Join(doc, "\n"))
}
for _, t := range p.Types {
for _, m := range t.Methods {
if !strings.HasPrefix(m.Name, prefix[l]) || m.Name == "Loader" { continue }
parts := strings.Split(strings.TrimSpace(m.Doc), "\n")
funcsig := parts[0]
doc := parts[1:]
docs[l] = append(docs[l], funcsig + " > " + strings.Join(doc, "\n"))
}
2021-10-16 03:58:56 +00:00
}
}
for mod, v := range docs {
os.Mkdir("docs", 0777)
f, _ := os.Create("docs/" + mod + ".txt")
f.WriteString(strings.Join(v, "\n\n") + "\n")
}
2021-10-16 03:58:56 +00:00
}