From: Josh Bleecher Snyder Date: Wed, 3 May 2017 23:37:03 +0000 (-0700) Subject: cmd/compile: prevent panic while formatting func(...T) with unknown T X-Git-Tag: go1.9beta1~343 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=f2c5f57a87fe34a1fbe1a4226319619982ce75eb;p=gostls13.git cmd/compile: prevent panic while formatting func(...T) with unknown T Compile: package p var f = func(...A) Before this CL: x.go:3:13: type %!v(PANIC=runtime error: invalid memory address or nil pointer dereference) is not an expression x.go:3:17: undefined: A After this CL: x.go:3:13: type func(...) is not an expression x.go:3:17: undefined: A Found with go-fuzz. Fixes #20233 Change-Id: Ibb232b3954c4091071440eba48b44c4022a8083f Reviewed-on: https://go-review.googlesource.com/42610 Run-TryBot: Josh Bleecher Snyder TryBot-Result: Gobot Gobot Reviewed-by: Matthew Dempsky --- diff --git a/src/cmd/compile/internal/gc/fmt.go b/src/cmd/compile/internal/gc/fmt.go index 41502268a7..c0d82d8c16 100644 --- a/src/cmd/compile/internal/gc/fmt.go +++ b/src/cmd/compile/internal/gc/fmt.go @@ -1754,7 +1754,11 @@ func fldconv(f *types.Field, flag FmtFlag, mode fmtMode, depth int) string { var typ string if f.Isddd() { - typ = "..." + tmodeString(f.Type.Elem(), mode, depth) + var et *types.Type + if f.Type != nil { + et = f.Type.Elem() + } + typ = "..." + tmodeString(et, mode, depth) } else { typ = tmodeString(f.Type, mode, depth) } diff --git a/test/fixedbugs/issue20233.go b/test/fixedbugs/issue20233.go new file mode 100644 index 0000000000..5734cf44ef --- /dev/null +++ b/test/fixedbugs/issue20233.go @@ -0,0 +1,11 @@ +// errorcheck + +// Copyright 2017 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. + +// Issue 20233: panic while formatting an error message + +package p + +var f = func(...A) // ERROR "type func(....*) is not an expression" ERROR "undefined: A"