受到《Go 终极指南:编写一个 Go 工具》的启发,萌生了把 gomodifytags 封装成emacs-plugin的想法, 而后通过两周的努力,诞生了emacs-go-tag。 emacs-go-tag
实现了两个命令: go-tag-add
添加结构体字段tag, go-tag-remove
删除结构体字段tag。git
emacs-go-tag
有两个依赖项, gomodifytags
和 go-mode.el,若使用emacs作Go开发 go-mode.el
应该已经在使用了。 gomodifytags安装以下:github
go get -u github.com/fatih/gomodifytags
目前emacs-go-tag已发布到了MELPA上,可以使用以下命令安装: M-x package-install [RET] go-tag [RET]
如果没发现go-tag,你须要使用以下命令来刷新,而后在使用上面的命令进行安装: M-x package-refresh-contents [RET]
json
目前 gomodifytags
支持三种转换以下:vim
默认使用 snakecase
, 若你准备使用 camelcase
, 可配置以下:dom
(setq go-tag-args (list "-transform" "camelcase"))
快捷键配置示例:工具
(with-eval-after-load 'go-mode (define-key go-mode-map (kbd "C-c t") #'go-tag-add) (define-key go-mode-map (kbd "C-c T") #'go-tag-remove))
如果你有使用 vim-go 的 GoAddTags
和 GoRemoveTags
命令的经验, 那么你会很快上手 emacs-go-tag
, 由于二者的行为彻底一致(如有不一样,请反馈)。spa
:[range] go-tag-add [key],[option] [key1],[option] …
为结构体字段添加tag。若是在一个结构中调用,会自动添加json字段tag。 若在结构体以外调用,或者文件格式不正确,则会给出错误消息。code
若是给出 [range]
,则只有选定的字段将被改变。orm
默认的json能够经过提供一个或多个 [key]
参数来改变。 添加xml和db的例子是::go-tag-add xml db
xml
若提供了 [option]
也提供了,会在添加tag时,一同添加 option
, 或者修改已存在的tag。 以下: :go-tag-add json,omitempty
也能够定义一个常数值而不是默认的基于字段的值。 例如,如下命令将添加 `valid:"1"`到全部字段。 :go-tag-add valid=1
:[range] go-tag-add [key],[option] [key1],[option] …
移除结构字段的字段标记。 若是在一个结构中调用,它会自动删除全部的字段tag。 若是在结构体定义以外调用,或者文件格式不正确,则会给出错误消息。
若是给出 [range]
,则只有选定的字段将被改变。
若是给出 [key]
,则只会删除这些key相关的tag。 以下只删除json相关的tag: :go-tag-remove json
若是 [option]
和 [key]
一同传递,则只会删除 option
。 例如,下面命令只会从包含json的字段中删除omitempty选项: :go-tag-remove json,omitempty
感谢 GoCN每日新闻
的每日推送,让我得以读到 《Go 终极指南:编写一个 Go 工具》, 而后得以完成这个emacs-plugin
。 项目地址:https://github.com/brantou/em..., 欢迎你们来使用和来提问题,如果你以为对你有帮助, 就给颗星
吧。