Commit cb6e0639 authored by Emmanuel Odeke's avatar Emmanuel Odeke Committed by Matthew Dempsky

cmd/compile: improve error message if init is directly invoked

Fixes #8481.

Inform the user that init functions cannot be directly invoked
in user code, as mandated by the spec at:
http://golang.org/ref/spec#Program_initialization_and_execution.

Change-Id: Ib12c0c08718ffd48b76b6f9b13c76bb6612d2e7b
Reviewed-on: https://go-review.googlesource.com/34790Reviewed-by: default avatarKeith Randall <khr@golang.org>
Reviewed-by: default avatarMatthew Dempsky <mdempsky@google.com>
Run-TryBot: Matthew Dempsky <mdempsky@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent dbd51ce9
...@@ -3648,11 +3648,19 @@ func typecheckdef(n *Node) *Node { ...@@ -3648,11 +3648,19 @@ func typecheckdef(n *Node) *Node {
lineno = n.Pos lineno = n.Pos
} }
// Note: adderrorname looks for this string and switch n.Sym.Name {
// adds context about the outer expression case "init":
yyerror("undefined: %v", n.Sym) // As per the spec at:
// https://golang.org/ref/spec#Program_initialization_and_execution
// init cannot be referred to in usercode.
// See https://golang.org/issues/8481.
yyerror("cannot refer to init functions")
default:
// Note: adderrorname looks for this string and
// adds context about the outer expression
yyerror("undefined: %v", n.Sym)
}
} }
return n return n
} }
......
// 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 main
func init() {
}
func main() {
init() // ERROR "cannot refer to init functions"
}
...@@ -15,7 +15,7 @@ func init() { ...@@ -15,7 +15,7 @@ func init() {
} }
func main() { func main() {
init() // ERROR "undefined.*init" init() // ERROR "cannot refer to init functions"
runtime.init() // ERROR "unexported.*runtime\.init" runtime.init() // ERROR "unexported.*runtime\.init"
var _ = init // ERROR "undefined.*init" var _ = init // ERROR "cannot refer to init functions"
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment