mirror of
https://github.com/golang/go
synced 2024-11-24 02:10:11 -07:00
1737aef270
This change adds line position tests for several yyerror calls in the typechecker that are currently not tested in any way. Untested yyerror calls were found by replacing them with yerrorl(src.NoXPos, ...) (thus destroying position information in the error), and then running the test suite. No failures means no test coverage for the relevant yyerror call. For #19683 Change-Id: Iedb3d2f02141b332e9bfa76dbf5ae930ad2fddc3 Reviewed-on: https://go-review.googlesource.com/41477 Run-TryBot: Alberto Donizetti <alb.donizetti@gmail.com> Reviewed-by: Josh Bleecher Snyder <josharian@gmail.com> Reviewed-by: Matthew Dempsky <mdempsky@google.com>
66 lines
1.5 KiB
Go
66 lines
1.5 KiB
Go
// errorcheck
|
|
|
|
// Copyright 2011 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.
|
|
|
|
// Verify that illegal composite literals are detected.
|
|
// Does not compile.
|
|
|
|
package main
|
|
|
|
var m map[int][3]int
|
|
|
|
func f() [3]int
|
|
|
|
func fp() *[3]int
|
|
|
|
var mp map[int]*[3]int
|
|
|
|
var (
|
|
_ = [3]int{1, 2, 3}[:] // ERROR "slice of unaddressable value"
|
|
_ = m[0][:] // ERROR "slice of unaddressable value"
|
|
_ = f()[:] // ERROR "slice of unaddressable value"
|
|
|
|
_ = 301[:] // ERROR "cannot slice"
|
|
_ = 3.1[:] // ERROR "cannot slice"
|
|
_ = true[:] // ERROR "cannot slice"
|
|
|
|
// these are okay because they are slicing a pointer to an array
|
|
_ = (&[3]int{1, 2, 3})[:]
|
|
_ = mp[0][:]
|
|
_ = fp()[:]
|
|
)
|
|
|
|
type T struct {
|
|
i int
|
|
f float64
|
|
s string
|
|
next *T
|
|
}
|
|
|
|
type TP *T
|
|
type Ti int
|
|
|
|
var (
|
|
_ = &T{0, 0, "", nil} // ok
|
|
_ = &T{i: 0, f: 0, s: "", next: {}} // ERROR "missing type in composite literal|omit types within composite literal"
|
|
_ = &T{0, 0, "", {}} // ERROR "missing type in composite literal|omit types within composite literal"
|
|
_ = TP{i: 0, f: 0, s: "", next: {}} // ERROR "invalid pointer type"
|
|
_ = &Ti{} // ERROR "invalid pointer type"
|
|
)
|
|
|
|
type M map[T]T
|
|
|
|
var (
|
|
_ = M{{i:1}: {i:2}}
|
|
_ = M{T{i:1}: {i:2}}
|
|
_ = M{{i:1}: T{i:2}}
|
|
_ = M{T{i:1}: T{i:2}}
|
|
)
|
|
|
|
type S struct { s [1]*M1 }
|
|
type M1 map[S]int
|
|
var _ = M1{{s:[1]*M1{&M1{{}:1}}}:2}
|
|
|