mirror of
https://github.com/zeromicro/go-zero.git
synced 2026-05-13 09:50:00 +08:00
(goctl): support nested struct (#4211)
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
package dartgen
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"os"
|
||||
"strings"
|
||||
"text/template"
|
||||
@@ -8,8 +9,8 @@ import (
|
||||
"github.com/zeromicro/go-zero/tools/goctl/api/spec"
|
||||
)
|
||||
|
||||
const dataTemplate = `// --{{with .Info}}{{.Title}}{{end}}--
|
||||
{{ range .Types}}
|
||||
const dataTemplate = `// --{{with .APISpec.Info}}{{.Title}}{{end}}--
|
||||
{{ range .APISpec.Types}}
|
||||
class {{.Name}}{
|
||||
{{range .Members}}
|
||||
/// {{.Comment}}
|
||||
@@ -28,12 +29,16 @@ class {{.Name}}{
|
||||
'{{getPropertyFromMember .}}': {{if isDirectType .Type.Name}}{{lowCamelCase .Name}}{{else if isClassListType .Type.Name}}{{lowCamelCase .Name}}.map((i) => i.toJson()){{else}}{{lowCamelCase .Name}}.toJson(){{end}},{{end}}
|
||||
};
|
||||
}
|
||||
|
||||
{{ range $.InnerClassList}}
|
||||
{{.}}
|
||||
{{end}}
|
||||
}
|
||||
{{end}}
|
||||
`
|
||||
|
||||
const dataTemplateV2 = `// --{{with .Info}}{{.Title}}{{end}}--
|
||||
{{ range .Types}}
|
||||
const dataTemplateV2 = `// --{{with .APISpec.Info}}{{.Title}}{{end}}--
|
||||
{{ range .APISpec.Types}}
|
||||
class {{.Name}} {
|
||||
{{range .Members}}
|
||||
{{if .Comment}}{{.Comment}}{{end}}
|
||||
@@ -73,9 +78,18 @@ class {{.Name}} {
|
||||
,{{end}}
|
||||
};
|
||||
}
|
||||
|
||||
{{ range $.InnerClassList}}
|
||||
{{.}}
|
||||
{{end}}
|
||||
}
|
||||
{{end}}`
|
||||
|
||||
type DartSpec struct {
|
||||
APISpec *spec.ApiSpec
|
||||
InnerClassList []string
|
||||
}
|
||||
|
||||
func genData(dir string, api *spec.ApiSpec, isLegacy bool) error {
|
||||
err := os.MkdirAll(dir, 0o755)
|
||||
if err != nil {
|
||||
@@ -104,12 +118,12 @@ func genData(dir string, api *spec.ApiSpec, isLegacy bool) error {
|
||||
return err
|
||||
}
|
||||
|
||||
err = convertDataType(api)
|
||||
err, dartSpec := convertDataType(api, isLegacy)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return t.Execute(file, api)
|
||||
return t.Execute(file, dartSpec)
|
||||
}
|
||||
|
||||
func genTokens(dir string, isLeagcy bool) error {
|
||||
@@ -132,24 +146,61 @@ func genTokens(dir string, isLeagcy bool) error {
|
||||
return err
|
||||
}
|
||||
|
||||
func convertDataType(api *spec.ApiSpec) error {
|
||||
func convertDataType(api *spec.ApiSpec, isLegacy bool) (error, *DartSpec) {
|
||||
var result DartSpec
|
||||
types := api.Types
|
||||
if len(types) == 0 {
|
||||
return nil
|
||||
return nil, &result
|
||||
}
|
||||
|
||||
for _, ty := range types {
|
||||
defineStruct, ok := ty.(spec.DefineStruct)
|
||||
if ok {
|
||||
for index, member := range defineStruct.Members {
|
||||
tp, err := specTypeToDart(member.Type)
|
||||
if err != nil {
|
||||
return err
|
||||
structMember, ok := member.Type.(spec.DefineStruct)
|
||||
if ok && structMember.IsNestedStruct() {
|
||||
defineStruct.Members[index].Type = spec.PrimitiveType{RawName: member.Name}
|
||||
t := template.New("dataTemplate")
|
||||
t = t.Funcs(funcMap)
|
||||
tpl := dataTemplateV2
|
||||
if isLegacy {
|
||||
tpl = dataTemplate
|
||||
}
|
||||
t, err := t.Parse(tpl)
|
||||
if err != nil {
|
||||
return err, nil
|
||||
}
|
||||
|
||||
var innerClassSpec = &spec.ApiSpec{
|
||||
Types: []spec.Type{
|
||||
spec.DefineStruct{
|
||||
RawName: member.Name,
|
||||
Members: structMember.Members,
|
||||
},
|
||||
},
|
||||
}
|
||||
err, dartSpec := convertDataType(innerClassSpec, isLegacy)
|
||||
if err != nil {
|
||||
return err, nil
|
||||
}
|
||||
|
||||
writer := bytes.NewBuffer(nil)
|
||||
err = t.Execute(writer, dartSpec)
|
||||
if err != nil {
|
||||
return err, nil
|
||||
}
|
||||
result.InnerClassList = append(result.InnerClassList, writer.String())
|
||||
} else {
|
||||
tp, err := specTypeToDart(member.Type)
|
||||
if err != nil {
|
||||
return err, nil
|
||||
}
|
||||
defineStruct.Members[index].Type = buildSpecType(member.Type, tp)
|
||||
}
|
||||
defineStruct.Members[index].Type = buildSpecType(member.Type, tp)
|
||||
}
|
||||
}
|
||||
}
|
||||
result.APISpec = api
|
||||
|
||||
return nil
|
||||
return nil, &result
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user