Implement field generation

This commit is contained in:
2024-09-12 08:49:35 +02:00
parent 4fbc86e4b6
commit 98deea62d4
4 changed files with 30 additions and 11 deletions

View File

@@ -1,8 +1,8 @@
---@diagnostic disable: missing-return, lowercase-global ---@diagnostic disable: missing-return, lowercase-global
---@class {{.ClassName}}
{{range .Fields -}} {{range .Fields -}}
---@field {{.Name}} {{.Type}} {{.Comment}} ---@field {{.Name}} {{.Type}} {{.Comment}}
{{end -}} {{end -}}
---@class {{.ClassName}}
{{.ClassName}} = { {{.ClassName}} = {
{{$n := len .Methods -}} {{$n := len .Methods -}}
{{$methods := len .Methods -}} {{$methods := len .Methods -}}

5
go.mod
View File

@@ -2,7 +2,10 @@ module avorion-docparser
go 1.23.0 go 1.23.0
require github.com/PuerkitoBio/goquery v1.10.0 require (
github.com/PuerkitoBio/goquery v1.10.0
github.com/davecgh/go-spew v1.1.1
)
require ( require (
github.com/andybalholm/cascadia v1.3.2 // indirect github.com/andybalholm/cascadia v1.3.2 // indirect

2
go.sum
View File

@@ -2,6 +2,8 @@ github.com/PuerkitoBio/goquery v1.10.0 h1:6fiXdLuUvYs2OJSvNRqlNPoBm6YABE226xrbav
github.com/PuerkitoBio/goquery v1.10.0/go.mod h1:TjZZl68Q3eGHNBA8CWaxAN7rOU1EbDz3CWuolcO5Yu4= github.com/PuerkitoBio/goquery v1.10.0/go.mod h1:TjZZl68Q3eGHNBA8CWaxAN7rOU1EbDz3CWuolcO5Yu4=
github.com/andybalholm/cascadia v1.3.2 h1:3Xi6Dw5lHF15JtdcmAHD3i1+T8plmv7BQ/nsViSLyss= github.com/andybalholm/cascadia v1.3.2 h1:3Xi6Dw5lHF15JtdcmAHD3i1+T8plmv7BQ/nsViSLyss=
github.com/andybalholm/cascadia v1.3.2/go.mod h1:7gtRlve5FxPPgIgX36uWBX58OdBsSS6lUvCFb+h7KvU= github.com/andybalholm/cascadia v1.3.2/go.mod h1:7gtRlve5FxPPgIgX36uWBX58OdBsSS6lUvCFb+h7KvU=
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY= github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=

32
main.go
View File

@@ -6,9 +6,11 @@ import (
"io" "io"
"log" "log"
"os" "os"
"strings"
"text/template" "text/template"
"github.com/PuerkitoBio/goquery" "github.com/PuerkitoBio/goquery"
"github.com/davecgh/go-spew/spew"
_ "embed" _ "embed"
) )
@@ -30,6 +32,9 @@ func init() {
Warning = log.New(io.MultiWriter(os.Stdout), Warning = log.New(io.MultiWriter(os.Stdout),
fmt.Sprintf("%sWarning:%s ", "\033[0;93m", "\033[0m"), fmt.Sprintf("%sWarning:%s ", "\033[0;93m", "\033[0m"),
log.Lmicroseconds|log.Lshortfile) log.Lmicroseconds|log.Lshortfile)
spew.Config.Indent = " "
spew.Config.SortKeys = true
} }
var fns = template.FuncMap{ var fns = template.FuncMap{
@@ -108,8 +113,8 @@ func ParseFile(filename string) (*Class, error) {
resConstructor := Constructor{} resConstructor := Constructor{}
paramTypes.Each(func(i int, s *goquery.Selection) { paramTypes.Each(func(i int, s *goquery.Selection) {
pname := paramNames.Eq(i).Text() pname := strings.TrimSpace(paramNames.Eq(i).Text())
ptype := paramTypes.Eq(i).Text() ptype := strings.TrimSpace(paramTypes.Eq(i).Text())
ptype = MapType(ptype) ptype = MapType(ptype)
resConstructor.Params = append(resConstructor.Params, Param{ resConstructor.Params = append(resConstructor.Params, Param{
@@ -120,9 +125,20 @@ func ParseFile(filename string) (*Class, error) {
}) })
res.Constructors = append(res.Constructors, resConstructor) res.Constructors = append(res.Constructors, resConstructor)
// constructorDetails := codeblocks.Eq(1) properties := doc.Find("div.floatright > div.codecontainer#Properties")
properties.ChildrenFiltered("div").Each(func(i int, s *goquery.Selection) {
property := Field{}
property.Name = strings.TrimSpace(s.Find("span.property").Text())
property.Type = strings.TrimSpace(s.Find("span.type").Text())
property.Type = MapType(property.Type)
comment := s.Find("td[align='right']").Text()
if comment != "" {
property.Comment = strings.TrimSpace(comment)
}
res.Fields = append(res.Fields, property)
})
log.Printf("%#v", res) spew.Dump(res)
return &res, nil return &res, nil
} }
@@ -135,12 +151,10 @@ func MapType(t string) string {
return "number" return "number"
case "float": case "float":
return "number" return "number"
case "string": case "bool":
return "string"
case "boolean":
return "boolean" return "boolean"
case "void": case "table_t":
return "nil" return "table"
default: default:
return t return t
} }