new-* constructor generator
Doc: English | 中文
一个为 Golang 结构体生成构造器函数(NewXXX
)代码的自动工具。
go install github.com/Bin-Huang/newc@latest
在需要生成构造器的结构体上添加一行 go:generate
注释。
//go:generate newc
type UserService struct {
baseService
userRepository *repositories.UserRepository
proRepository *repositories.ProRepository
}
然后只需要执行 go generate ./...
就能生成下面这样的构造器代码:
// constructor_gen.go
// NewUserService Create a new UserService
func NewUserService(baseService baseService, userRepository *repositories.UserRepository, proRepository *repositories.ProRepository) *UserService {
return &UserService{
baseService: baseService,
userRepository: userRepository,
proRepository: proRepository,
}
}
这里可以查看更多例子
推荐在团队合作中采用
无需手动安装,只需要给结构体添加下面这行注释就行。Go 会在缺失时自动下载这个工具。
//go:generate go run github.com/Bin-Huang/newc@v0.8.3
比如这样:
//go:generate go run github.com/Bin-Huang/newc@v0.8.3
type UserService struct {
baseService
userRepository *repositories.UserRepository
proRepository *repositories.ProRepository
}
这个方式非常有用,尤其在团队开发中。就算其他同事没有安装这个工具,这么做也能正常运行,不会影响到其他人的工作。
使用 --value
参数
//go:generate newc --value
type Config struct {
debug bool
}
生成代码:
// constructor_gen.go
// NewConfig Create a new Config
func NewConfig(debug bool) Config {
return Config{
debug: debug,
}
}
- 加上
--init
参数 - 为结构体实现一个
init
方法
//go:generate newc --init
type Controller struct {
logger *zap.Logger
debug bool
}
func (c *Controller) init() {
c.logger = c.logger.With(zap.String("tag", "controller-debugger"))
c.debug = true
}
生成代码:
// constructor_gen.go
// NewController Create a new Controller
func NewController(logger *zap.Logger, debug bool) *Controller {
s := &Controller{
logger: logger,
debug: debug,
}
s.init()
return s
}
给需要忽略的字段添加 newc:"-"
标签
type Forbidden struct {
Msg string
Status int `newc:"-"`
}
生成代码:
// NewForbidden Create a new Forbidden
func NewForbidden(msg string) *Forbidden {
return &Forbidden{
Msg: msg,
}
}
一些建议:
- (推荐)把它加进你的编辑器/IDE的快捷代码片段(code snippest)里
- ......
1. 它能让你的代码更容易编写和维护.
不管是编写还是更新构造器代码,都是一个费力且容易出错的事情,尤其当代码量很大的时候。这些繁琐易错的工作应该交给自动程序来完成,比如这个工具。
同时,这个工具还能完美兼容像wire这种依赖注入工具。如果你的项目中也使用了 wire,那你可能非常需要这个工具。wire 在 newc 的“加持”下会变得更加好用。
2. 你不需要担心自动生成的代码.
这个工具在生成代码时会非常小心,会帮你考虑所有代码细节,包括引用依赖、变量命名,甚至还有代码风格。
3. 它非常适合团队协同工作.
就算其他同事没有安装这个工具,这么做也不会影响到他们的工作。因为 Go 会在必要时自动安装这个工具。
//go:generate go run github.com/Bin-Huang/newc@v0.8.3
MIT