mirror of
https://github.com/golang/go
synced 2024-11-05 22:46:12 -07:00
0b739fd4df
Part of the general trend of moving yyerror calls out of walk and into typecheck. Notably, this requires splitting test/typeswitch2.go into two files, because now some of the errors are reported during typecheck and others are still reported during walk; and if there were any errors during typecheck, then cmd/compile exits without invoking walk. Passes toolstash-check. Change-Id: I05ee0c00b99af659ee1eef098d342d0d736cf31e Reviewed-on: https://go-review.googlesource.com/c/go/+/194659 Reviewed-by: Robert Griesemer <gri@golang.org>
21 lines
598 B
Go
21 lines
598 B
Go
// errorcheck
|
|
|
|
// 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.
|
|
|
|
// Verify that various erroneous type switches are caught by the compiler.
|
|
// Does not compile.
|
|
|
|
package main
|
|
|
|
func notused(x interface{}) {
|
|
// The first t is in a different scope than the 2nd t; it cannot
|
|
// be accessed (=> declared and not used error); but it is legal
|
|
// to declare it.
|
|
switch t := 0; t := x.(type) { // ERROR "declared and not used"
|
|
case int:
|
|
_ = t // this is using the t of "t := x.(type)"
|
|
}
|
|
}
|