This is go-mode, the Emacs mode for editing Go code.
It is a complete rewrite of the go-mode that shipped with Go 1.0.3 and before, and was part of Go 1.1 until Go 1.3. Beginning with Go 1.4, editor integration will not be part of the Go distribution anymore, making this repository the canonical place for go-mode.
In addition to normal features, such as fontification and indentation,
and close integration with familiar Emacs functionality (for example
syntax-based navigation like beginning-of-defun), go-mode comes with
the following extra features to provide an improved experience:
- Integration with
gofmtby providing a command of the same name, andgofmt-before-save, which can be used in a hook to format Go buffers before saving them.- Setting the
gofmt-commandvariable also allows usinggoimports.
- Setting the
- Integration with
godocvia the functionsgodocandgodoc-at-point. - Integration with the Playground
go-play-bufferandgo-play-regionto send code to the Playgroundgo-download-playto download a Playground entry into a new buffer
- Managing imports
- A function for jumping to the file's imports (
go-goto-imports) - A function for adding imports, including tab completion
(
go-import-add, bound toC-c C-a) - A function for removing or commenting unused imports
(
go-remove-unused-imports)
- A function for jumping to the file's imports (
- Integration with godef
godef-describe(C-c C-d) to describe expressionsgodef-jump(C-c C-j) andgodef-jump-other-window(C-x 4 C-c C-j) to jump to declarations- This requires you to install godef via
go get code.google.com/p/rog-go/exp/cmd/godef.
- Basic support for imenu (functions and variables)
- Built-in support for displaying code coverage as calculated by
go test(go-coverage)
There are several third party extensions that can enhance the Go experience in Emacs.
There are two ways of using flymake with Go:
- goflymake, which internally
uses
go buildto capture all errors that a regular compilation would also produce - flymake-go for a
more lightweight solution that only uses
gofmtand as such is only able to catch syntax errors. Unlike goflymake, however, it does not require an additional executable.
Additionally, there is
flycheck, a modern replacement
for flymake, which comes with built-in support for Go. In addition to
using go build or gofmt, it also has support for go vet,
golint and errcheck.
For auto completion, take a look at gocode.
https://github.com/syohex/emacs-go-eldoc provides eldoc functionality for go-mode.
I maintain a set of YASnippet snippets for go-mode at https://github.com/dominikh/yasnippet-go
https://github.com/dominikh/go-errcheck.el provides integration with errcheck.
I am accepting donations for go-mode, but it has to be said that even though I am its primary developer, there are several third party contributions with varying complexity. Donations would be towards me, Dominik Honnef, and not go-mode as a whole.
