Skip to content

Commit

Permalink
refine rpc generator
Browse files Browse the repository at this point in the history
  • Loading branch information
kevwan committed Aug 28, 2020
1 parent 72132ce commit f411178
Show file tree
Hide file tree
Showing 8 changed files with 46 additions and 33 deletions.
9 changes: 3 additions & 6 deletions tools/goctl/api/parser/util.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,17 +9,14 @@ import (
"github.com/tal-tech/go-zero/tools/goctl/api/spec"
)

const (
// struct匹配
typeRegex = `(?m)(?m)(^ *type\s+[a-zA-Z][a-zA-Z0-9_-]+\s+(((struct)\s*?\{[\w\W]*?[^\{]\})|([a-zA-Z][a-zA-Z0-9_-]+)))|(^ *type\s*?\([\w\W]+\}\s*\))`
)
// struct匹配
const typeRegex = `(?m)(?m)(^ *type\s+[a-zA-Z][a-zA-Z0-9_-]+\s+(((struct)\s*?\{[\w\W]*?[^\{]\})|([a-zA-Z][a-zA-Z0-9_-]+)))|(^ *type\s*?\([\w\W]+\}\s*\))`

var (
emptyStrcut = errors.New("struct body not found")
emptyType spec.Type
)

var emptyType spec.Type

func GetType(api *spec.ApiSpec, t string) spec.Type {
for _, tp := range api.Types {
if tp.Name == t {
Expand Down
2 changes: 1 addition & 1 deletion tools/goctl/model/sql/gen/gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,7 @@ func (g *defaultGenerator) genModel(in parser.Table, withCache bool) (string, er
"types": typesCode,
"new": newCode,
"insert": insertCode,
"find": strings.Join(findCode, "\r\n"),
"find": strings.Join(findCode, "\n"),
"update": updateCode,
"delete": deleteCode,
})
Expand Down
2 changes: 1 addition & 1 deletion tools/goctl/model/sql/gen/vars.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ func genVars(table Table, withCache bool) (string, error) {
Execute(map[string]interface{}{
"lowerStartCamelObject": stringx.From(camel).UnTitle(),
"upperStartCamelObject": camel,
"cacheKeys": strings.Join(keys, "\r\n"),
"cacheKeys": strings.Join(keys, "\n"),
"autoIncrement": table.PrimaryKey.AutoIncrement,
"originalPrimaryKey": table.PrimaryKey.Name.Source(),
"withCache": withCache,
Expand Down
3 changes: 0 additions & 3 deletions tools/goctl/rpc/ctx/project.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package ctx

import (
"errors"
"fmt"
"io/ioutil"
"os"
Expand All @@ -16,8 +15,6 @@ import (
"github.com/tal-tech/go-zero/tools/goctl/util/console"
)

var errProtobufNotFound = errors.New("github.com/golang/protobuf is not found,please ensure you has already [go get github.com/golang/protobuf]")

const (
constGo = "go"
constProtoC = "protoc"
Expand Down
2 changes: 1 addition & 1 deletion tools/goctl/rpc/gen/gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ func (g *defaultRpcGenerator) Generate() (err error) {
return
}

err = g.genRemoteHandler()
err = g.genHandler()
if err != nil {
return
}
Expand Down
55 changes: 37 additions & 18 deletions tools/goctl/rpc/gen/genhandler.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,15 +9,29 @@ import (
)

const (
remoteTemplate = `{{.head}}
handlerTemplate = `{{.head}}
package handler
import {{.imports}}
import (
"context"
{{.imports}}
)
type {{.types}}
{{.newFuncs}}
func New{{.server}}Server(svcCtx *svc.ServiceContext) *{{.server}}Server {
return &{{.server}}Server{
svcCtx: svcCtx,
}
}
{{if .hasComment}}{{.comment}}{{end}}
func (s *{{.server}}Server) {{.method}} (ctx context.Context, in *{{.package}}.{{.request}}) (*{{.package}}.{{.response}}, error) {
l := logic.New{{.logicName}}(ctx,s.svcCtx)
return l.{{.method}}(in)
}
`
functionTemplate = `{{.head}}
Expand All @@ -29,8 +43,6 @@ import (
{{.imports}}
)
type {{.server}}Server struct{}
{{if .hasComment}}{{.comment}}{{end}}
func (s *{{.server}}Server) {{.method}} (ctx context.Context, in *{{.package}}.{{.request}}) (*{{.package}}.{{.response}}, error) {
l := logic.New{{.logicName}}(ctx,s.svcCtx)
Expand All @@ -47,29 +59,35 @@ func (s *{{.server}}Server) {{.method}} (ctx context.Context, in *{{.package}}.{
}`
)

func (g *defaultRpcGenerator) genRemoteHandler() error {
func (g *defaultRpcGenerator) genHandler() error {
handlerPath := g.dirM[dirHandler]
serverGo := fmt.Sprintf("%vhandler.go", g.Ctx.ServiceName.Lower())
fileName := filepath.Join(handlerPath, serverGo)
filename := fmt.Sprintf("%vhandler.go", g.Ctx.ServiceName.Lower())
handlerFile := filepath.Join(handlerPath, filename)
file := g.ast
pkg := file.Package
pbImport := fmt.Sprintf(`%v "%v"`, pkg, g.mustGetPackage(dirPb))
logicImport := fmt.Sprintf(`"%v"`, g.mustGetPackage(dirLogic))
svcImport := fmt.Sprintf(`"%v"`, g.mustGetPackage(dirSvc))
imports := []string{
pbImport,
logicImport,
svcImport,
}
types := make([]string, 0)
newFuncs := make([]string, 0)
head := util.GetHead(g.Ctx.ProtoSource)
for _, service := range file.Service {
types = append(types, fmt.Sprintf(typeFmt, service.Name.Title()))
newFuncs = append(newFuncs, fmt.Sprintf(newFuncFmt, service.Name.Title(), service.Name.Title(), service.Name.Title()))
newFuncs = append(newFuncs, fmt.Sprintf(newFuncFmt, service.Name.Title(),
service.Name.Title(), service.Name.Title()))
}
err := util.With("server").GoFmt(true).Parse(remoteTemplate).SaveTo(map[string]interface{}{

return util.With("server").GoFmt(true).Parse(handlerTemplate).SaveTo(map[string]interface{}{
"head": head,
"types": strings.Join(types, "\n"),
"newFuncs": strings.Join(newFuncs, "\n"),
"imports": svcImport,
}, fileName, true)
if err != nil {
return err
}
return g.genFunctions()
"imports": strings.Join(imports, "\n\t"),
}, handlerFile, true)
}

func (g *defaultRpcGenerator) genFunctions() error {
Expand All @@ -89,19 +107,20 @@ func (g *defaultRpcGenerator) genFunctions() error {
err := util.With("func").GoFmt(true).Parse(functionTemplate).SaveTo(map[string]interface{}{
"head": head,
"server": service.Name.Title(),
"imports": strings.Join(handlerImports, "\r\n"),
"imports": strings.Join(handlerImports, "\n"),
"logicName": fmt.Sprintf("%sLogic", method.Name.Title()),
"method": method.Name.Title(),
"package": pkg,
"request": method.InType,
"response": method.OutType,
"hasComment": len(method.Document),
"comment": strings.Join(method.Document, "\r\n"),
"comment": strings.Join(method.Document, "\n"),
}, filename, true)
if err != nil {
return err
}
}
}

return nil
}
4 changes: 2 additions & 2 deletions tools/goctl/rpc/gen/genlogic.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ func (g *defaultRpcGenerator) genLogic() error {
err = util.With("logic").GoFmt(true).Parse(logicTemplate).SaveTo(map[string]interface{}{
"logicName": fmt.Sprintf("%sLogic", method.Name.Title()),
"functions": functions,
"imports": strings.Join(imports.KeysStr(), "\r\n"),
"imports": strings.Join(imports.KeysStr(), "\n"),
}, filename, false)
if err != nil {
return err
Expand All @@ -83,7 +83,7 @@ func genLogicFunction(packageName string, method *parser.Func) (string, error) {
"request": method.InType,
"response": method.OutType,
"hasComment": len(method.Document) > 0,
"comment": strings.Join(method.Document, "\r\n"),
"comment": strings.Join(method.Document, "\n"),
})
if err != nil {
return "", err
Expand Down
2 changes: 1 addition & 1 deletion tools/goctl/rpc/gen/genmain.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ func (g *defaultRpcGenerator) genMain() error {
"serviceName": g.Ctx.ServiceName.Lower(),
"srv": srv,
"registers": registers,
"imports": strings.Join(imports, "\r\n"),
"imports": strings.Join(imports, "\n"),
}, fileName, true)
}

Expand Down

0 comments on commit f411178

Please sign in to comment.