golang 环境配置建议

jianyingLi · · 6700 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

AUTH:PHILO VERSION:1.2

开发环境的必要特征

  1. 项目管理
  2. 快速文件跳转
  3. 自动语法检查
  4. 自动补全
  5. 查找定义
  6. 启动速度快
  7. 如果自己有需求的话插件可以随便写
  8. 灵活的运行配置

(project,lint,hint,autocomplete)

要实现上面几点我们来一步一步的配置。

我的大环境

  1. OSX
  2. GO 1.4
  3. HomeBrew

go 环境安装

这一部分是最重要的,如果没有它,每次build的时候出现 too many errors 心里真的是非常难过的。

环境配置:(golint,gooracle,mercurial)

安装mercurial: brew install mercurial

这个东西是用来做版本管理的,也是下载代码的工具类似git,貌似google的项目用的挺多的。

安装golint:


$ go get github.com/golang/lint
$ go install github.com/golang/lint

安装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
  1. 安装环境的时候经常会出现下载不下来的问题,大概是我网络不好吧。连接google经常出现问题。

    解决方案:
    golang中国的下载频道中有一个第三方包的下载工具,只要输入地址之后人家会给你提供下载tar包的。
    放到gopath中就ok了。
    此步骤只能替代go get的步骤,最后还是需要go install

  2. go install 之后会在 $GOPATH/bin/ 中出现各种工具文件

    1. gocode 提供代码补全
    2. godef 代码跳转
    3. gofmt 自动代码整理
    4. golint 代码语法检查
    5. goimports 自动整理imports
    6. oracle 代码callgraph查询(plugin中还在todolist中,但是不配置一直报错。实在烦。)

    最后不要忘记复制上面的命令到 $GOROOT/bin/下面

  3. 最后的配置结果(安装完之后 Package->Go Plus->Display Go Information)


Cover Tool: /usr/local/go/pkg/tool/darwin_amd64/cover
Vet Tool: /usr/local/go/pkg/tool/darwin_amd64/vet
Format Tool: /Users/Li-jianying/git/bin/goimports
Lint Tool: /usr/local/go/bin/golint
Gocode Tool: /Users/Li-jianying/git/bin/gocode
Gocode Status: Enabled
Oracle Tool: /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

没有红色的行就没有问题了。

项目管理,自动文件跳转

  1. 插件:project-manager

    这个插件是非常hot的,在atom.io的首页上排名还是非常靠前的。

  2. 使用细节:
    1. 配合tree view ( cmd - \) 打开关闭project file
    2. 搜索项目文件 ( cmd -t )

      输入的时候按照顺序输入关键字
      比如说 user模块的controll中的go源代码
      搜索的时候可以使用多个快捷键 =》 user controll go
      就可以准确的找到源代码了

    3. 打开项目列表 ( ctrl-cmd-p )

      然后就会显示出来一个项目列表回车就可以打开项目。

  3. 总结:

    感觉这个插件的treeview用途的确不是很大,因为正常项目的项目文件会很多。
    不过是快速打开项目(文件夹)是非常方便的,配合快速打开文件还是相当爽的。

  4. 按快捷键之后的效果展示:

    自动语法检,自动补全

  5. 插件go-plus,autocomplete-plus(dependance),gocode
    使用 apm install 安装就可以了。速度还可以。

  6. 使用细节 在保存的时候

    1. 会自动补上imports
    2. 会自动整理代码

      比如说 a:=5 会变成 a := 5
      两个空行自动变成一个空格

    3. lint自动检查语法错误(go build 的错误都会显示出来)
    4. vet会自动检查语法拼写建议

      函数,结构体 会提示补上注释。
      比如说会提示你函数前面需要加入godoc类型的注释: // functionname
      注释的第一行需要使用双斜杠注释+空格+函数名+空格+简短的函数功能说明。

  7. 使用细节: 在编辑的时候

    1. go-plus会配合autocomplete-plus会自动补全包名字(tab补全,回车不行,这个真心舒服)
    2. 包名.之后输入方法名开头几个字母会给出补全建议。
  8. 安装之后的演示(类似go-plus官方演示)

  9. gocode 插件自动补全演示

    1. 这个插件继承自autocomplete,因为年久失修。api用的是老版本,所以一直都会出现api警告。(我是实用主义,视而不见)
    2. gocode如果找不到就进入代码找到文件autocomplete-view.coffee 中105行写成绝对路径就肯定没有问题了。
    3. 绑定快捷键,因为这个插件没有绑定快捷键的文件(keymap)所以需要在keymap.cson下自己手动绑定配置如下:

'.active.pane':
'ctrl-;': 'gocode:toggle'
  1. 效果演示

    查找定义

  1. 插件 godef
  2. 使用细节:
    光标在目标代码上的时候,使用快捷键ctrl-k跳转到目标代码的定义代码上。

灵活的运行

  1. 安装插件atom-runner
  2. 修改源代码中的go run运行为go: 'sh [绝对路径到你的全局run脚上] '+atom.project.rootDirectories[0].path
  3. 脚本的 $1 会是你项目运行的路径。然后你的所有项目都可以添加一个run.sh 来指定一个构建运行的方案。
  4. 做完之后不管当前在查看什么文件都可以运行整个项目。
  5. 其他语言也可以这样做。毕竟单个文件的项目不是很常见(开发的时候)

总结

  1. 我这里只是总结了我用的所有的golang相关的atom插件。
  2. 要相信golang使用编辑器就够用的事实了。因为 go tool 实在是太好用了。

我的key map

  1. cmd-d duplicate line
  2. cmd-w 关闭标签
  3. cmd-r 文件内的标签列表
  4. cmd-e 使用选中的内容做搜索的pattern
  5. shift-cmd-f project内部搜索,这个非常实用。command 配置(keymap.cson)
    >

'.platform-darwin atom-text-editor':
 'shift-cmd-D': 'find-and-replace:select-next'

感谢golang

  1. golang能有如此的开发体验,以及在如此低的版本中表现的这么好。实在是大牛赐予我们最好的礼物了。
  2. golang的有如此好的开发工具加上各种扩展性比较强的编辑器(vim,emacs,sublime,atom等)开发体验的确是非常好的。

有疑问加站长微信联系(非本文作者)

本文来自:PHILO

感谢作者:jianyingLi

查看原文:golang 环境配置建议

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

6700 次点击  
加入收藏 微博
2 回复  |  直到 2000-01-01 00:00:00
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传