1
0
mirror of https://github.com/golang/go synced 2024-11-19 00:04:40 -07:00
go/internal/lsp/testdata/deep/deep.go
Muir Manders 0abb09c987 internal/lsp: search for deep completions across function calls
We now continue deep completion search across function calls. The
function must take no arguments and return a single argument. For
example, when completing "fo<>" you might get candidates such as
"foo.bar().baz()".

Previously we would stop searching for deep completions when we hit a
function call. For example, we would stop at "foo.bar()", never
finding "foo.bar().baz()". At the time I was worried about the search
scope growing too large, but now that we dynamically limit the search
scope there isn't much left to worry about.

Change-Id: I48772c154400662876682503c1f58ef6e3dca688
Reviewed-on: https://go-review.googlesource.com/c/tools/+/201222
Reviewed-by: Rebecca Stambler <rstambler@golang.org>
Run-TryBot: Rebecca Stambler <rstambler@golang.org>
2019-10-17 03:50:25 +00:00

126 lines
2.9 KiB
Go

// Copyright 2019 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package deep
import "context"
type deepA struct {
b deepB //@item(deepBField, "b", "deepB", "field")
}
type deepB struct {
}
func wantsDeepB(deepB) {}
func _() {
var a deepA //@item(deepAVar, "a", "deepA", "var")
a.b //@item(deepABField, "a.b", "deepB", "field")
wantsDeepB(a) //@deep(")", deepABField, deepAVar)
deepA{a} //@snippet("}", deepABField, "a.b", "a.b")
}
func wantsContext(context.Context) {}
func _() {
context.Background() //@item(ctxBackground, "context.Background", "func() context.Context", "func", "Background returns a non-nil, empty Context.")
context.TODO() //@item(ctxTODO, "context.TODO", "func() context.Context", "func", "TODO returns a non-nil, empty Context.")
wantsContext(c) //@rank(")", ctxBackground, ctxTODO)
}
func _() {
// deepCircle is circular.
type deepCircle struct {
*deepCircle
}
var circle deepCircle //@item(deepCircle, "circle", "deepCircle", "var")
circle.deepCircle //@item(deepCircleField, "circle.deepCircle", "*deepCircle", "field", "deepCircle is circular.")
var _ deepCircle = circ //@deep(" //", deepCircle, deepCircleField)
}
func _() {
type deepEmbedC struct {
}
type deepEmbedB struct {
deepEmbedC
}
type deepEmbedA struct {
deepEmbedB
}
wantsC := func(deepEmbedC) {}
var a deepEmbedA //@item(deepEmbedA, "a", "deepEmbedA", "var")
a.deepEmbedB //@item(deepEmbedB, "a.deepEmbedB", "deepEmbedB", "field")
a.deepEmbedC //@item(deepEmbedC, "a.deepEmbedC", "deepEmbedC", "field")
wantsC(a) //@deep(")", deepEmbedC, deepEmbedA, deepEmbedB)
}
func _() {
type nested struct {
a int
n *nested //@item(deepNestedField, "n", "*nested", "field")
}
nested{
a: 123, //@deep(" //", deepNestedField)
}
}
func _() {
var a struct {
b struct {
c int
}
d int
}
a.d //@item(deepAD, "a.d", "int", "field")
a.b.c //@item(deepABC, "a.b.c", "int", "field")
a.b //@item(deepAB, "a.b", "struct{...}", "field")
a //@item(deepA, "a", "struct{...}", "var")
// "a.d" should be ranked above the deeper "a.b.c"
var i int
i = a //@deep(" //", deepAD, deepABC, deepA, deepAB)
}
type foo struct {
b bar
}
func (f foo) bar() bar {
return f.b
}
func (f foo) barPtr() *bar {
return &f.b
}
type bar struct{}
func (b bar) valueReceiver() int {
return 0
}
func (b *bar) ptrReceiver() int {
return 0
}
func _() {
var (
i int
f foo
)
f.bar().valueReceiver //@item(deepBarValue, "f.bar().valueReceiver", "func() int", "method")
f.barPtr().valueReceiver //@item(deepBarPtrValue, "f.barPtr().valueReceiver", "func() int", "method")
f.barPtr().ptrReceiver //@item(deepBarPtrPtr, "f.barPtr().ptrReceiver", "func() int", "method")
i = fb //@fuzzy(" //", deepBarValue, deepBarPtrPtr, deepBarPtrValue)
}