]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/compile: stop leaking 'any' type into user package
authorMatthew Dempsky <mdempsky@google.com>
Sat, 5 Mar 2016 00:39:07 +0000 (16:39 -0800)
committerMatthew Dempsky <mdempsky@google.com>
Sat, 5 Mar 2016 02:13:04 +0000 (02:13 +0000)
The new check corresponds to the (etype != TANY || Debug['A'] != 0)
that was lost in golang.org/cl/19936.

Fixes #14652.

Change-Id: Iec3788ff02529b3b0f0d4dd92ec9f3ef20aec849
Reviewed-on: https://go-review.googlesource.com/20271
Reviewed-by: Ian Lance Taylor <iant@golang.org>
src/cmd/compile/internal/gc/lex.go
test/fixedbugs/issue14652.go [new file with mode: 0644]

index 3fa876ad40f6574004f9e16549915239f4f8df4f..81bd9461ca2554decc1cfe1c6a928b35123bbcfc 100644 (file)
@@ -2264,7 +2264,7 @@ func lexinit1() {
 
 func lexfini() {
        for _, s := range builtinpkg.Syms {
-               if s.Def == nil {
+               if s.Def == nil || (s.Name == "any" && Debug['A'] == 0) {
                        continue
                }
                s1 := Lookup(s.Name)
diff --git a/test/fixedbugs/issue14652.go b/test/fixedbugs/issue14652.go
new file mode 100644 (file)
index 0000000..b030aee
--- /dev/null
@@ -0,0 +1,9 @@
+// errorcheck
+
+// Copyright 2016 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 p
+
+var x any // ERROR "undefined: any"