Skip to content

A Golang code completion plugin for SublimeText 2

License

Notifications You must be signed in to change notification settings

dersebi/GoSublime

 
 

Repository files navigation

GoSublime

Intro

GoSublime is a Golang plugin collection for the text editor SublimeText 2 providing code completion and other IDE-like features.

Features

  • code completion from Gocode
  • context aware snippets via the code-completion popup to complement the existing SublimeText Go package.
  • a sublime build system(ctrl+b) for gomake including support for cycling errors with F4/Shift+F4
  • gotype and govet support as linters with errors highlighted in the editor view
  • gofmt support for quickly reformatting your source to conform with the Go standards
  • automatic code completion popup when you press dot(.)

Demo

Installation

  1. First (if you haven't done so already) install Gocode.

  2. Download GoSublime into your packages directory. You can access your package directory from within SublimeText by going to the menu Preferences > Browse Packages.... You can download a zipped archive or tarball on github via the Downloads button. Alternatively (recommended), you can simply clone this repo into your packages directory . (on Linux)

    $ cd ~/.config/sublime-text-2/Packages $ git clone git://github.com/DisposaBoy/GoSublime

Usage

Please see USAGE.md for general usage and other tips for effective usage of GoSublime

Settings

You can customize the behaviour of GoSublime by creating a settings file in your User package. This can be accessed from within SublimeText by going to the menu Preferences > Browse Packages.... Create a file named GoSublime.sublime-settings. A sample settings file Packages/GoSublime/examples/GoSublime.sublime-settings.example is provided inside the GoSublime package directory.

Note: Filenames are case-sensitive on some platforms(e.g. Linux) so the filename should be exactly GoSublime.sublime-settings with capitalization preserved.

e.g. If you want to change the path of gocode, you can edit the gocode_cmd setting:

"gocode_cmd": "/go/bin/gocode"

The available settings are:

  • gocode_cmd - the command that shall be called for gocode, this can be the command name e.g. gocode or full path to a binary e.g. /go/bin/gocode - default gocode

  • gofmt_cmd - the command that shall be called for gofmt, this can be the command name e.g. gofmt or full path to a binary e.g. /go/bin/gofmt - default gofmt

  • gslint_cmd - the command that will be used by gslint. Set it to an empty string to disable gslint. Any command can be used in place of gotype as long as the output is compatible and printed to stderr (e.g govet provides compatible output) - default gotype

  • gslint_timeout - how long to wait after the last keystroke before the command is run (in milliseconds) - default 500

Completion Markers

The following letters are used to prefix entries in the completion list.

  • ʂ - Snippets. These snippets are provided by GoSublime and should not be confused with SublimeText's snippets. Furthermore, they are context sensitive, therefore the snippets provided in the global scope will be different to those provided in function scope.

  • ν - Variables

  • ʈ - User-defined types, structs, maps, slices, etc.

  • Ɩ - Constants

  • ƒ - Functions

  • ρ - Packages

About

A Golang code completion plugin for SublimeText 2

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%