Module Name: src
Committed By: rillig
Date: Sat Jul 10 09:40:12 UTC 2021
Modified Files:
src/usr.bin/xlint/lint1: cgram.y
Log Message:
lint: merge duplicate code in grammar for 'while' statements
No functional change.
To generate a diff of this commit:
cvs rdiff -u -r1.282 -r1.283 src/usr.bin/xlint/lint1/cgram.y
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/usr.bin/xlint/lint1/cgram.y
diff -u src/usr.bin/xlint/lint1/cgram.y:1.282 src/usr.bin/xlint/lint1/cgram.y:1.283
--- src/usr.bin/xlint/lint1/cgram.y:1.282 Sat Jul 10 05:42:29 2021
+++ src/usr.bin/xlint/lint1/cgram.y Sat Jul 10 09:40:12 2021
@@ -1,5 +1,5 @@
%{
-/* $NetBSD: cgram.y,v 1.282 2021/07/10 05:42:29 rillig Exp $ */
+/* $NetBSD: cgram.y,v 1.283 2021/07/10 09:40:12 rillig Exp $ */
/*
* Copyright (c) 1996 Christopher G. Demetriou. All Rights Reserved.
@@ -35,7 +35,7 @@
#include <sys/cdefs.h>
#if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: cgram.y,v 1.282 2021/07/10 05:42:29 rillig Exp $");
+__RCSID("$NetBSD: cgram.y,v 1.283 2021/07/10 09:40:12 rillig Exp $");
#endif
#include <limits.h>
@@ -1517,11 +1517,10 @@ do_statement: /* C99 6.8.5 */
;
iteration_statement: /* C99 6.8.5 */
- while_expr statement {
+ T_WHILE T_LPAREN expr T_RPAREN {
+ while1($3);
clear_warning_flags();
- while2();
- }
- | while_expr error {
+ } while_body {
clear_warning_flags();
while2();
}
@@ -1547,11 +1546,9 @@ iteration_statement: /* C99 6.8.5 */
}
;
-while_expr: /* see C99 6.8.5 */
- T_WHILE T_LPAREN expr T_RPAREN {
- while1($3);
- clear_warning_flags();
- }
+while_body:
+ statement
+ | error
;
do: /* see C99 6.8.5 */