]> Cypherpunks repositories - gostls13.git/commitdiff
go/parser: match syntax parser error for unnamed type parameters
authorRobert Griesemer <gri@golang.org>
Wed, 31 Aug 2022 21:23:07 +0000 (14:23 -0700)
committerGopher Robot <gobot@golang.org>
Fri, 2 Sep 2022 02:14:54 +0000 (02:14 +0000)
For #54511.

Change-Id: I1ae391b5f157bf688f9f31b1577c90e681b6df26
Reviewed-on: https://go-review.googlesource.com/c/go/+/426655
Reviewed-by: Robert Griesemer <gri@google.com>
Run-TryBot: Robert Griesemer <gri@google.com>
Reviewed-by: Robert Findley <rfindley@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Auto-Submit: Robert Griesemer <gri@google.com>

src/go/parser/parser.go
src/go/parser/short_test.go
src/go/parser/testdata/issue49175.go2
src/go/parser/testdata/tparams.go2

index 6d1ab3481506761609a9646cf3273efd10352fd9..159834172aca688cf5eecc024a1216b0017549ba 100644 (file)
@@ -897,7 +897,7 @@ func (p *parser) parseParameterList(name0 *ast.Ident, typ0 ast.Expr, closing tok
                        }
                }
                if tparams {
-                       p.error(pos, "all type parameters must be named")
+                       p.error(pos, "type parameters must be named")
                }
        } else if named != len(list) {
                // some named => all must be named
@@ -925,7 +925,7 @@ func (p *parser) parseParameterList(name0 *ast.Ident, typ0 ast.Expr, closing tok
                }
                if !ok {
                        if tparams {
-                               p.error(missingName, "all type parameters must be named")
+                               p.error(missingName, "type parameters must be named")
                        } else {
                                p.error(pos, "mixed named and unnamed parameters")
                        }
index 298579ea6c0c20468dc738f5dc8532b50ac21e19..f9575e1d0f2ffaa03bb6c4b41696c7c47b455fdf 100644 (file)
@@ -196,10 +196,9 @@ var invalids = []string{
        `package p; func _[]/* ERROR "empty type parameter list" */()`,
 
        // TODO(rfindley) a better location would be after the ']'
-       `package p; type _[A /* ERROR "all type parameters must be named" */ ,] struct{ A }`,
+       `package p; type _[A /* ERROR "type parameters must be named" */ ,] struct{ A }`,
 
-       // TODO(rfindley) this error is confusing.
-       `package p; func _[type /* ERROR "all type parameters must be named" */ P, *Q interface{}]()`,
+       `package p; func _[type /* ERROR "found 'type'" */ P, *Q interface{}]()`,
 
        `package p; func (T) _[ /* ERROR "must have no type parameters" */ A, B any](a A) B`,
        `package p; func (T) _[ /* ERROR "must have no type parameters" */ A, B C](a A) B`,
index a5ad30f14c8e2f1b52b25a4d91adc21e9e6741be..cf1c83c63398eac7462e12db2bd9543cb21d9811 100644 (file)
@@ -10,4 +10,4 @@ type _[_ [1]t]t
 func _[_ []t]() {}
 func _[_ [1]t]() {}
 
-type t [t /* ERROR "all type parameters must be named" */ [0]]t
+type t [t /* ERROR "type parameters must be named" */ [0]]t
index 28fd1322431a8cf5ef557133ae17292c2a02d268..abde5dc05045b67f61209d23044c161e95f145df 100644 (file)
@@ -4,8 +4,8 @@
 
 package p
 
-type _[a /* ERROR "all type parameters must be named" */, b] struct{}
-type _[a t, b t, c /* ERROR "all type parameters must be named" */ ] struct{}
+type _[a /* ERROR "type parameters must be named" */, b] struct{}
+type _[a t, b t, c /* ERROR "type parameters must be named" */ ] struct{}
 type _ struct {
        t [n]byte
        t[a]
@@ -18,8 +18,8 @@ type _ interface {
 }
 
 func _[] /* ERROR "empty type parameter list" */ ()
-func _[a /* ERROR "all type parameters must be named" */, b ]()
-func _[a t, b t, c /* ERROR "all type parameters must be named" */ ]()
+func _[a /* ERROR "type parameters must be named" */, b ]()
+func _[a t, b t, c /* ERROR "type parameters must be named" */ ]()
 
 // TODO(rfindley) incorrect error message (see existing TODO in parser)
 func f[a b, 0 /* ERROR "expected '\)', found 0" */ ] ()