Releases: golang/tools
Releases · golang/tools
gopls/v0.4.1
This release contains mostly stability improvements and smaller bug fixes. A list of all of the issues fixed in this release can be found in the gopls/v0.4.1 milestone. A notable change is that type error analyzers (fillreturns, undeclaredname, unusedparams, nonewvars) are now on by default.
gopls/v0.4.0
- Improved support for working with modules (@ridersofrohan). A detailed walk-through of the new features can be found here. A quick summary:
- Use the
-modfile
flag to suggest which modules should be added/removed from thego.mod
file, rather than editing it automatically. - Suggest dependency upgrades in-editor and provide additional language features, such as formatting, for the
go.mod
file.
- Use the
- Inverse implementations (@muirdm). "Go to implementations" on a concrete type will show the interfaces it implements.
- Completion improvements (@muirdm). Specifically, improved completion for keywords. Also, offer
if err != nil { return err }
as a completion item. - Jumping to definition on an import statement returns all files as definition locations (@danishprakash).
- Support for running
go generate
through the editor, via a code lens (@marwan-at-work). - Command-line support for workspace symbols (@daisuzu).
Opt-in:
- Code actions suggesting
gofmt -s
-style simplifications (@ridersofrohan). To get these on-save, add the following setting:
"[go]": {
"editor.codeActionsOnSave": {
"source.fixAll": true,
}
}
- Code actions suggesting fixes for type errors, such as missing return values (goreturns-style), undeclared names, unused parameters, and assignment statements that should be converted from
:=
to=
(@ridersofrohan). Add the following to your gopls settings to opt-in to these analyzers. In the future, they will be on by default and high-confidence suggested fixes may be applied on save. See additional documentation on analyzers here.
"gopls": {
"analyses": {
"fillreturns": true,
"undeclaredname": true,
"unusedparams": true,
"nonewvars": true,
}
}
- Further improvements in the support for multiple concurrent clients (@findleyr). See #34111 for all details.
For a complete list of the issues resolved, see the gopls/v0.4.0 milestone.
gopls/v0.3.4
- golang.org/cl/222979: fix for a nil pointer exception in completion (@muirdm).
- golang.org/cl/222980: fix a concurrent map write and iteration (@ridersofrohan).
gopls/v0.3.3
- Support for workspace symbols. (@daisuzu)
- Various completion improvements, including fixes for completion in code that doesn't parse. (@muirdm)
- Limit diagnostic concurrency, preventing huge spikes in memory usage that some users encountered. (@heschik)
- Improved handling for URIs containing escaped characters. (@heschik)
- Module versions from "go list" in pkg.go.dev links. (@ridersofrohan)
- Upgrade module dependencies via a code lens on
go.mod
files. (@ridersofrohan)
Opt-in:
- Support for multiple concurrent clients. See golang/go#34111 for more details. (@findleyr)
- tempModFile: Additional diagnostics and quick fixes for missing dependencies. (@ridersofrohan)
gopls/v0.3.2
- fatih/vim-go#2701: Fix a crash in references on builtin symbols.
- golang/go#37104: Fix crash in completion of recursive pointer types (for example,
type foo *foo
). - golang/go#37108: Fix handling of build flags in imports code.
- golang/go#34955: Import organization was corrupting file contents for untracked files. This is now fixed.
- CL 219203: Disable nilness analyzer. This is the only analyzer that requires
go/ssa
, which is expensive to compute. If you are still seeing excessive memory usage withgopls/v0.3.2
, please read golang/go#36943 and open a new issue.
gopls/v0.3.1
- golang/go#36975: Handle nil pointer in builtin packages if workspace load fails.
- golang/go#36999: Fix panic on files that contain
%
in their paths. - Fix memory leak caused by autocompletion (CL 217677). Users were seeing huge memory usage over long sessions. Please comment on #36943 if you're still seeing this issue with
gopls/v0.3.1
.
gopls/v0.3.0
Note: gopls
now loads your entire workspace, where “workspace” is directory you opened in your editor.
In module mode, you must open your module root (directory containing the go.mod
file) or a subdirectory.
In GOPATH
mode, you must open your GOPATH/src
or a directory within it. If you have a large GOPATH
and you open your GOPATH
as your workspace root, gopls
may be very slow to load. Please see #36899 for further information.
- Autocompletion from unimported packages is on by default. You will get completions for something like
fmt.Printf
even if“fmt”
isn’t imported yet. (@heschik) - Workspace-scoped references, rename, and go to implementation. These features use your workspace root as the search scope, so behavior will vary based on the directory you open in your editor. This may result in unexpected behavior. (@muirdm, @matloob)
- Workspace-wide diagnostics. You will now see errors in your entire workspace, rather than just in your currently open files. Analysis errors will only be shown for packages with currently open files.
- Watch file changes on disk. This allows users to switch branches without reloading their editors. Also, changing configurations no longer requires an editor reload.
- GOPATH vendoring is fully supported. Previously, some features would ignore vendor directories, causing errors if packages weren't in GOPATH. (@heschik)
- New autocompletion suggestions for type conversions. Improved completions for literal candidates and variadic functions. Better rankings, including rankings for builtin functions and keywords. (@muirdm)
- Highlighting improvements: Highlighting now applies not only to variables, but also to fields, methods, types, and imports. Additional highlighting helps visualize control flow in loops and functions. Highlighting of single character variables has better support. (@ridersofrohan)
- Documentation on hover includes links to pkg.go.dev for exported symbols. (@Southclaws)
- Improved support for cgo dependencies. All features now work for packages that have cgo dependencies. Authoring cgo packages is still not supported, but improvements are scheduled for Go 1.15 (see #35721). (@heschik)
- Deep completions are now on by default. This feature of completion will search the fields and methods of all available candidates to see if there are any more candidates with the expected type. As an example, say you have imported the
context
package and are calling a function that takes acontext.Context
as a parameter. In the case that you don’t have a variable of that type in scope, deep completions will suggestcontext.Background()
andcontext.TODO()
. (@muirdm)
Opt-in:
- staticcheck analyses remain opt-in and can be enabled by setting
"staticcheck": true
in yourgopls
settings. - Go 1.14 will support running the go command without modifying the user’s
go.mod
file. This new feature is used ingopls
to show diagnostics and suggest edits in a user’sgo.mod
file rather than change the file without the user noticing. Currently,gopls
will suggest removing unused dependencies and warn the user if there is a parse error in thego.mod
file. Enable this behavior by using the go1.14 beta and setting"tempModfile": true
in yourgopls
settings. (@ridersofrohan)
gopls/v0.2.2
gopls/v0.2.1
- Fix for parse errors showing up as errors on the whole package (CL 206597).
gopls/v0.2.0
- Many improvements to autocompletion. In particular, support for completions of array, slice, map, and function literals (@muirdm).
- A new diff algorithm (github.com/sergi/go-diff) that improves handling of line endings on different operating systems (@ianthehat).
- Improved caching and memory usage (@stamblerre).
- Command-line support for links, suggested fixes, and imports (@kalmanb).
- Command-line support for references, signature, and symbols (@rentziass).
- Command-line support for rename (@hartzell).
Opt-in:
- Get diagnostics from staticcheck by configuring
"staticcheck": true
in your gopls settings (@ianthehat). - Get autocompletion of unimported packages and symbols by configuring
"completeUnimported": true
in your gopls settings (@heschik).