Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/xlint/lint1 lint: in the grammar, replace %prec with...



details:   https://anonhg.NetBSD.org/src/rev/2c09aecf0ca3
branches:  trunk
changeset: 1022389:2c09aecf0ca3
user:      rillig <rillig%NetBSD.org@localhost>
date:      Thu Jul 15 17:20:57 2021 +0000

description:
lint: in the grammar, replace %prec with explicit rules

This way, in the arguments of __attribute__, where only constant
expressions are expected, a '=' leads to a syntax error.  Previously,
this was not detected.

No noticeable change in practice since these cases are already handled
by the compilers.

diffstat:

 tests/usr.bin/xlint/lint1/expr_precedence.c   |   5 +-
 tests/usr.bin/xlint/lint1/expr_precedence.exp |   2 +-
 usr.bin/xlint/lint1/cgram.y                   |  88 ++++++++++++++------------
 3 files changed, 49 insertions(+), 46 deletions(-)

diffs (201 lines):

diff -r 7e58dc7794e0 -r 2c09aecf0ca3 tests/usr.bin/xlint/lint1/expr_precedence.c
--- a/tests/usr.bin/xlint/lint1/expr_precedence.c       Thu Jul 15 17:20:25 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/expr_precedence.c       Thu Jul 15 17:20:57 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: expr_precedence.c,v 1.1 2021/07/15 17:09:08 rillig Exp $       */
+/*     $NetBSD: expr_precedence.c,v 1.2 2021/07/15 17:20:58 rillig Exp $       */
 # 3 "expr_precedence.c"
 
 /*
@@ -23,9 +23,8 @@
  */
 void __attribute__((format(printf,
     /* expect+2: error: 'var' undefined [99] */ /* XXX: why? */
-    /* XXX: allow only constant-expression, not assignment-expression */
+    /* expect+1: syntax error '=' [249] */
     var = 1,
     /* Syntactically ok, must be a constant expression though. */
-    /* expect+1: error: 'var' undefined [99] */
     var > 0 ? 2 : 1)))
 my_printf(const char *, ...);
diff -r 7e58dc7794e0 -r 2c09aecf0ca3 tests/usr.bin/xlint/lint1/expr_precedence.exp
--- a/tests/usr.bin/xlint/lint1/expr_precedence.exp     Thu Jul 15 17:20:25 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/expr_precedence.exp     Thu Jul 15 17:20:57 2021 +0000
@@ -1,4 +1,4 @@
 expr_precedence.c(15): error: syntax error '4' [249]
 expr_precedence.c(18): error: non-constant initializer [177]
 expr_precedence.c(27): error: 'var' undefined [99]
-expr_precedence.c(30): error: 'var' undefined [99]
+expr_precedence.c(27): error: syntax error '=' [249]
diff -r 7e58dc7794e0 -r 2c09aecf0ca3 usr.bin/xlint/lint1/cgram.y
--- a/usr.bin/xlint/lint1/cgram.y       Thu Jul 15 17:20:25 2021 +0000
+++ b/usr.bin/xlint/lint1/cgram.y       Thu Jul 15 17:20:57 2021 +0000
@@ -1,5 +1,5 @@
 %{
-/* $NetBSD: cgram.y,v 1.324 2021/07/14 17:19:37 rillig Exp $ */
+/* $NetBSD: cgram.y,v 1.325 2021/07/15 17:20:57 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.324 2021/07/14 17:19:37 rillig Exp $");
+__RCSID("$NetBSD: cgram.y,v 1.325 2021/07/15 17:20:57 rillig Exp $");
 #endif
 
 #include <limits.h>
@@ -295,9 +295,10 @@
 %type  <y_tnode>       argument_expression_list
 %type  <y_tnode>       unary_expression
 %type  <y_tnode>       cast_expression
+%type  <y_tnode>       conditional_expression
+%type  <y_tnode>       assignment_expression
 %type  <y_tnode>       expression_opt
 %type  <y_tnode>       expression
-%type  <y_tnode>       assignment_expression
 %type  <y_tnode>       constant_expr
 
 %type  <y_type>        begin_type_typespec
@@ -562,10 +563,10 @@
 
 /* K&R 7.1, C90 ???, C99 6.5.2, C11 6.5.2 */
 argument_expression_list:
-         expression %prec T_COMMA {
+         assignment_expression {
                $$ = new_function_argument_node(NULL, $1);
          }
-       | argument_expression_list T_COMMA expression {
+       | argument_expression_list T_COMMA assignment_expression {
                $$ = new_function_argument_node($1, $3);
          }
        ;
@@ -635,71 +636,74 @@
        | expression
        ;
 
-/* 'expression' also implements 'multiplicative_expression'. */
-/* 'expression' also implements 'additive_expression'. */
-/* 'expression' also implements 'shift_expression'. */
-/* 'expression' also implements 'relational_expression'. */
-/* 'expression' also implements 'equality_expression'. */
-/* 'expression' also implements 'AND_expression'. */
-/* 'expression' also implements 'exclusive_OR_expression'. */
-/* 'expression' also implements 'inclusive_OR_expression'. */
-/* 'expression' also implements 'logical_AND_expression'. */
-/* 'expression' also implements 'logical_OR_expression'. */
-/* 'expression' also implements 'conditional_expression'. */
-/* 'expression' also implements 'assignment_expression'. */
-/* K&R ???, C90 ???, C99 6.5.5 to 6.5.17, C11 ??? */
-expression:
-         expression T_ASTERISK expression {
+/* 'conditional_expression' also implements 'multiplicative_expression'. */
+/* 'conditional_expression' also implements 'additive_expression'. */
+/* 'conditional_expression' also implements 'shift_expression'. */
+/* 'conditional_expression' also implements 'relational_expression'. */
+/* 'conditional_expression' also implements 'equality_expression'. */
+/* 'conditional_expression' also implements 'AND_expression'. */
+/* 'conditional_expression' also implements 'exclusive_OR_expression'. */
+/* 'conditional_expression' also implements 'inclusive_OR_expression'. */
+/* 'conditional_expression' also implements 'logical_AND_expression'. */
+/* 'conditional_expression' also implements 'logical_OR_expression'. */
+/* K&R ???, C90 ???, C99 6.5.5 to 6.5.15, C11 6.5.5 to 6.5.15 */
+conditional_expression:
+         conditional_expression T_ASTERISK conditional_expression {
                $$ = build(MULT, $1, $3);
          }
-       | expression T_MULTIPLICATIVE expression {
+       | conditional_expression T_MULTIPLICATIVE conditional_expression {
                $$ = build($2, $1, $3);
          }
-       | expression T_ADDITIVE expression {
+       | conditional_expression T_ADDITIVE conditional_expression {
                $$ = build($2, $1, $3);
          }
-       | expression T_SHIFT expression {
+       | conditional_expression T_SHIFT conditional_expression {
                $$ = build($2, $1, $3);
          }
-       | expression T_RELATIONAL expression {
+       | conditional_expression T_RELATIONAL conditional_expression {
                $$ = build($2, $1, $3);
          }
-       | expression T_EQUALITY expression {
+       | conditional_expression T_EQUALITY conditional_expression {
                $$ = build($2, $1, $3);
          }
-       | expression T_AMPER expression {
+       | conditional_expression T_AMPER conditional_expression {
                $$ = build(BITAND, $1, $3);
          }
-       | expression T_BITXOR expression {
+       | conditional_expression T_BITXOR conditional_expression {
                $$ = build(BITXOR, $1, $3);
          }
-       | expression T_BITOR expression {
+       | conditional_expression T_BITOR conditional_expression {
                $$ = build(BITOR, $1, $3);
          }
-       | expression T_LOGAND expression {
+       | conditional_expression T_LOGAND conditional_expression {
                $$ = build(LOGAND, $1, $3);
          }
-       | expression T_LOGOR expression {
+       | conditional_expression T_LOGOR conditional_expression {
                $$ = build(LOGOR, $1, $3);
          }
-       | expression T_QUEST expression T_COLON expression {
+       | conditional_expression T_QUEST conditional_expression
+           T_COLON conditional_expression {
                $$ = build(QUEST, $1, build(COLON, $3, $5));
          }
-       | expression T_ASSIGN expression {
+       | cast_expression;
+
+/* K&R ???, C90 ???, C99 6.5.16, C11 6.5.16 */
+assignment_expression:
+         conditional_expression
+       | assignment_expression T_ASSIGN conditional_expression {
                $$ = build(ASSIGN, $1, $3);
          }
-       | expression T_OPASSIGN expression {
+       | assignment_expression T_OPASSIGN conditional_expression {
                $$ = build($2, $1, $3);
          }
-       | expression T_COMMA expression {
+       ;
+
+/* K&R ???, C90 ???, C99 6.5.17, C11 6.5.17 */
+expression:
+         assignment_expression
+       | expression T_COMMA assignment_expression {
                $$ = build(COMMA, $1, $3);
          }
-       | cast_expression
-       ;
-
-/* K&R ???, C90 ???, C99 6.5.16, C11 ??? */
-assignment_expression:
-         expression %prec T_ASSIGN
        ;
 
 constant_expr_list_opt:                /* helper for gcc_attribute */
@@ -713,7 +717,7 @@
        ;
 
 constant_expr:                 /* C99 6.6 */
-         expression %prec T_ASSIGN
+         conditional_expression
        ;
 
 declaration:                   /* C99 6.7 */
@@ -1506,7 +1510,7 @@
        ;
 
 initializer:                   /* C99 6.7.8 "Initialization" */
-         expression %prec T_COMMA {
+         assignment_expression {
                init_expr($1);
          }
        | init_lbrace init_rbrace {



Home | Main Index | Thread Index | Old Index