]> Cypherpunks repositories - gostls13.git/commitdiff
go/parser: require label after goto
authorMateusz Poliwczak <mpoliwczak34@gmail.com>
Tue, 7 Jan 2025 18:28:10 +0000 (18:28 +0000)
committerRobert Griesemer <gri@google.com>
Tue, 25 Feb 2025 17:14:35 +0000 (09:14 -0800)
Fixes #70957

Change-Id: Ied7cf29ea3e02bb71ddce8a19ddd381ce5991ed1
GitHub-Last-Rev: 310bd1537b7a36758f3fbf8db476fa68e1a11599
GitHub-Pull-Request: golang/go#70958
Reviewed-on: https://go-review.googlesource.com/c/go/+/638395
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Reviewed-by: Robert Griesemer <gri@google.com>
Reviewed-by: Alan Donovan <adonovan@google.com>
src/cmd/compile/internal/syntax/testdata/issue70957.go [new file with mode: 0644]
src/go/parser/parser.go
src/go/parser/short_test.go

diff --git a/src/cmd/compile/internal/syntax/testdata/issue70957.go b/src/cmd/compile/internal/syntax/testdata/issue70957.go
new file mode 100644 (file)
index 0000000..921478f
--- /dev/null
@@ -0,0 +1,9 @@
+// Copyright 2024 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
+
+func f() { goto /* ERROR syntax error: unexpected semicolon, expected name */ ;}
+
+func f() { goto } // ERROR syntax error: unexpected }, expected name
index c2906c5bda8a38486bda6119074122eea40f353c..c31b65bb53081e184701165425e980deea4b2d7d 100644 (file)
@@ -2066,7 +2066,7 @@ func (p *parser) parseBranchStmt(tok token.Token) *ast.BranchStmt {
 
        pos := p.expect(tok)
        var label *ast.Ident
-       if tok != token.FALLTHROUGH && p.tok == token.IDENT {
+       if tok == token.GOTO || ((tok == token.CONTINUE || tok == token.BREAK) && p.tok == token.IDENT) {
                label = p.parseIdent()
        }
        p.expectSemi()
index 9465fe0e478c556ee272c060d7d9da5a4245df43..422d1b38c3bc604eb71e280ddfa5ff58dd9b237c 100644 (file)
@@ -212,6 +212,10 @@ var invalids = []string{
        `package p; func (T) _[ /* ERROR "must have no type parameters" */ A, B C[A, B]](a A) B`,
 
        `package p; func(*T[e, e /* ERROR "e redeclared" */ ]) _()`,
+
+       // go.dev/issue/70957
+       `package p; func f() {goto; /* ERROR "expected 'IDENT', found ';'" */ }`,
+       `package p; func f() {goto} /* ERROR "expected 'IDENT', found '}'" */ }`,
 }
 
 func TestInvalid(t *testing.T) {