- 项目管理
- 快速文件跳转
- 自动语法检查
- 自动补全
- 查找定义
- 启动速度快
- 如果自己有需求的话插件可以随便写
(project,lint,hint,autocomplete)
要实现上面几点我们来一步一步的配置。
我的大环境
- OSX
- GO 1.4
- HomeBrew
go 环境安装
这一部分是最重要的,如果没有它,每次build的时候出现 too many errors 心里真的是非常难过的。
-
环境配置:(golint,go,mercurial)
-
安装mercurial: brew install mercurial
这个东西是用来做版本管理的,也是下载代码的工具类似git,貌似google的项目用的挺多的。
-
安装golint:
- $ go get github.com/golang/lint
- $ go install github.com/golang/lint
-
安装mercurial: brew install mercurial
-
安装gooracle
- go get code.google.com/p/go.tools/cmd/oracle
-
安装goimport
- go get golang.org/x/tools/cmd/goimports
-
安装gocode
- go get-u github.com/nsf/gocode
-
安装 godef
- go get-v code.google.com/p/rog-go/exp/cmd/godef
- go install -v code.google.com/p/rog-go/exp/cmd/godef
-
安装环境的时候经常会出现下载不下来的问题,大概是我网络不好吧。连接google经常出现问题。
解决方案:
golang中国的下载频道中有一个第三方包的下载工具,只要输入地址之后人家会给你提供下载tar包的。
放到gopath中就ok了。此步骤只能替代go get的步骤,最后还是需要go install
-
go install 之后会在 $GOPATH/bin/ 中出现各种工具文件
- gocode 提供代码补全
- godef 代码跳转
- gofmt 自动代码整理
- golint 代码语法检查
- goimports 自动整理imports
- oracle 代码callgraph查询(plugin中还在todolist中,但是不配置一直报错。实在烦。)
最后不要忘记复制上面的命令到 $GOROOT/bin/下面
-
最后的配置结果(安装完之后 Package->Go Plus->Display Go Information)
- CoverTool:/usr/local/go/pkg/tool/darwin_amd64/cover
- VetTool:/usr/local/go/pkg/tool/darwin_amd64/vet
- FormatTool:/Users/Li-jianying/git/bin/goimports
- LintTool:/usr/local/go/bin/golint
- GocodeTool:/Users/Li-jianying/git/bin/gocode
- GocodeStatus:Enabled
- OracleTool:/Users/Li-jianying/git/bin/oracle
- Git:/usr/bin/git
- Mercurial:/usr/local/Cellar/mercurial/3.2.1/bin/hg
- PATH:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/go/bin
没有红色的行就没有问题了。
项目管理,自动文件跳转
-
插件:project-manager
这个插件是非常hot的,在atom.io的首页上排名还是非常靠前的。
-
使用细节:
- 配合tree view ( cmd - \) 打开关闭project file
-
搜索项目文件 ( cmd -t )
输入的时候按照顺序输入关键字,比如说 user模块的controll中的go源代码。搜索的时候可以使用多个快捷键 =》 user controll go,就可以准确的找到源代码了
-
打开项目列表 ( ctrl-cmd-p )
然后就会显示出来一个项目列表回车就可以打开项目。
-
总结:
感觉这个插件的treeview用途的确不是很大,因为正常项目的项目文件会很多。
不过是快速打开项目(文件夹)是非常方便的,配合快速打开文件还是相当爽的。 -
按快捷键之后的效果展示:
自动语法检查,自动补全
-
插件go-plus,autocomplete-plus(dependance),gocode
使用 apm install 安装就可以了。速度还可以。 -
使用细节 在保存的时候
- 会自动补上imports
-
会自动整理代码
比如说 a:=5 会变成 a := 5
两个空行自动变成一个空格
- lint自动检查语法错误(go build 的错误都会显示出来)
-
vet会自动检查语法拼写建议
函数,结构体 会提示补上注释。
比如说会提示你函数前面需要加入godoc类型的注释: // functionname
注释的第一行???要使用双斜杠注释+空格+函数名+空格+简短的函数功能说明。
-
使用细节: 在编辑的时候
- go-plus会配合autocomplete-plus会自动补全包名字(tab补全,回车不行,这个真心舒服)
- 包名.之后输入方法名开头几个字母会给出补全建议。
-
安装之后的演示(类似go-plus官方演示)
-
gocode 插件自动补全演示
- 这个插件继承自autocomplete,因为年久失修。api用的是老版本,所以一直都会出现api警告。(我是实用主义,视而不见)
- gocode如果找不到就进入代码找到文件autocomplete-view.coffee 中105行写成绝对路径就肯定没有问题了。
-
绑定快捷键,因为这个插件没有绑定快捷键的文件(keymap)所以需要在keymap.cson下自己手动绑定配置如下:
- '.active.pane':
- 'ctrl-;':'gocode:toggle'
-
效果演示
查找定义
- 插件 godef
- 使用细节:光标在目标代码上的时候,使用快捷键ctrl-k跳转到目标代码的定义代码上。
总结
- 我这里只是总结了我用的所有的golang相关的atom插件。
- 要相信golang使用编辑器就够用的事实了。因为 go tool 实在是太好用了。
我的key map
- cmd-d duplicate line
- cmd-w 关闭标签
- cmd-r 文件内的标签列表
- cmd-e 使用选中的内容做搜索的pattern
-
shift-cmd-f project内部搜索,这个非常实用。command 配置(keymap.cson)
- '.platform-darwin atom-text-editor':
- 'shift-cmd-D':'find-and-replace:select-next'
感谢golang
- golang能有如此的开发体验,以及在如此低的版本中表现的这么好。实在是大牛赐予我们最好的礼物了。
- golang的有如此好的开发工具加上各种扩展性比较强的编辑器(vim,emacs,sublime,atom等)开发体验的确是非常好的。
本文永久更新链接地址: