]> Cypherpunks repositories - gostls13.git/commitdiff
spec: refine rules about terminating statements
authorRobert Griesemer <gri@golang.org>
Fri, 26 Feb 2016 23:52:13 +0000 (15:52 -0800)
committerRobert Griesemer <gri@golang.org>
Tue, 19 Apr 2016 17:34:12 +0000 (17:34 +0000)
Per a suggestion from mdempsky.

Both gc and gccgo consider a statement list as terminating if the
last _non_empty_ statement is terminating; i.e., trailing semis are
ok. Only gotype followed the current stricter rule in the spec.

This change adjusts the spec to match gc and gccgo behavior. In
support of this change, the spec has a matching rule for fallthrough,
which in valid positions may be followed by trailing semis as well.

For details and examples, see the issue below.

Fixes #14422.

Change-Id: Ie17c282e216fc40ecb54623445c17be111e17ade
Reviewed-on: https://go-review.googlesource.com/19981
Reviewed-by: Ian Lance Taylor <iant@golang.org>
Reviewed-by: Russ Cox <rsc@golang.org>
doc/go_spec.html

index 437fc066bb60d9df6ec87567c0fd1cf75f947bcc..c6187b0787ad69a0216bc2722373d16d910494f9 100644 (file)
@@ -1,6 +1,6 @@
 <!--{
        "Title": "The Go Programming Language Specification",
-       "Subtitle": "Version of February 23, 2016",
+       "Subtitle": "Version of April 19, 2016",
        "Path": "/ref/spec"
 }-->
 
@@ -4257,7 +4257,7 @@ All other statements are not terminating.
 
 <p>
 A <a href="#Blocks">statement list</a> ends in a terminating statement if the list
-is not empty and its final statement is terminating.
+is not empty and its final non-empty statement is terminating.
 </p>