gotools/gopls/internal/test/marker/testdata/completion/keywords.txt

This test checks completion of Go keywords.

-- flags --
-ignore_extra_diags
-filter_keywords=false

-- settings.json --
{
	"completeUnimported": false,
	"matcher": "caseInsensitive",
	"experimentalPostfixCompletions": false
}

-- keywords.go --
package keywords

//@rank("", type),rank("", func),rank("", var),rank("", const),rank("", import)

func _() {
	var test int //@rank(" //", int, interface)
	var tChan chan int
	var _ m //@complete(" //", map)
	var _ f //@complete(" //", func)
	var _ c //@complete(" //", chan)

	var _ str //@rank(" //", string, struct)

	type _ int //@rank(" //", interface, int)

	type _ str //@rank(" //", struct, string)

	switch test {
	case 1: // TODO: trying to complete case here will break because the parser won't return *ast.Ident
		b //@complete(" //", break)
	case 2:
		f //@complete(" //", fallthrough, for)
		r //@complete(" //", return)
		d //@complete(" //", default, defer)
		c //@complete(" //", case, const)
	}

	switch test.(type) {
	case fo: //@complete(":")
	case int:
		b //@complete(" //", break)
	case int32:
		f //@complete(" //", for)
		d //@complete(" //", default, defer)
		r //@complete(" //", return)
		c //@complete(" //", case, const)
	}

	select {
	case <-tChan:
		b //@complete(" //", break)
		c //@complete(" //", case, const)
	}

	for index := 0; index < test; index++ {
		c //@complete(" //", const, continue)
		b //@complete(" //", break)
	}

	for range []int{} {
		c //@complete(" //", const, continue)
		b //@complete(" //", break)
	}

	// Test function level keywords

	//Using 2 characters to test because map output order is random
	sw //@complete(" //", switch)
	se //@complete(" //", select)

	f //@complete(" //", for)
	d //@complete(" //", defer)
	g //@rank(" //", go),rank(" //", goto)
	r //@complete(" //", return)
	i //@complete(" //", if)
	e //@complete(" //", else)
	v //@complete(" //", var)
	c //@complete(" //", const)

	for i := r //@complete(" //", range)
}

/* package */ //@item(package, "package", "", "keyword")
/* import */ //@item(import, "import", "", "keyword")
/* func */ //@item(func, "func", "", "keyword")
/* type */ //@item(type, "type", "", "keyword")
/* var */ //@item(var, "var", "", "keyword")
/* const */ //@item(const, "const", "", "keyword")
/* break */ //@item(break, "break", "", "keyword")
/* default */ //@item(default, "default", "", "keyword")
/* case */ //@item(case, "case", "", "keyword")
/* defer */ //@item(defer, "defer", "", "keyword")
/* go */ //@item(go, "go", "", "keyword")
/* for */ //@item(for, "for", "", "keyword")
/* if */ //@item(if, "if", "", "keyword")
/* else */ //@item(else, "else", "", "keyword")
/* switch */ //@item(switch, "switch", "", "keyword")
/* select */ //@item(select, "select", "", "keyword")
/* fallthrough */ //@item(fallthrough, "fallthrough", "", "keyword")
/* continue */ //@item(continue, "continue", "", "keyword")
/* return */ //@item(return, "return", "", "keyword")
/* goto */ //@item(goto, "goto", "", "keyword")
/* struct */ //@item(struct, "struct", "", "keyword")
/* interface */ //@item(interface, "interface", "", "keyword")
/* map */ //@item(map, "map", "", "keyword")
/* chan */ //@item(chan, "chan", "", "keyword")
/* range */ //@item(range, "range", "", "keyword")
/* string */ //@item(string, "string", "", "type")
/* int */ //@item(int, "int", "", "type")

-- accidental_keywords.go --
package keywords

// non-matching candidate - shouldn't show up as completion
var apple = "apple"

func _() {
	foo.bar() // insert some extra statements to exercise our AST surgery
	variance := 123 //@item(kwVariance, "variance", "int", "var")
	foo.bar()
	println(var) //@complete(")", kwVariance)
}

func _() {
	foo.bar()
	var s struct { variance int } //@item(kwVarianceField, "variance", "int", "field")
	foo.bar()
	s.var //@complete(" //", kwVarianceField)
}

func _() {
	channel := 123 //@item(kwChannel, "channel", "int", "var")
	chan //@complete(" //", kwChannel)
	foo.bar()
}

func _() {
	foo.bar()
	var typeName string //@item(kwTypeName, "typeName", "string", "var")
	foo.bar()
	type //@complete(" //", kwTypeName)
}
-- empty_select.go --
package keywords

func _() {
	select {
		c //@complete(" //", case)
	}
}
-- empty_switch.go --
package keywords

func _() {
	switch {
		//@complete("", case, default)
	}

	switch test.(type) {
		d //@complete(" //", default)
	}
}