Module Name:    src
Committed By:   rillig
Date:           Mon Jul 26 18:06:43 UTC 2021

Modified Files:
        src/tests/usr.bin/xlint/lint1: expr_precedence.c expr_precedence.exp

Log Message:
tests/lint: show bug in conditional expression (since 2021-07-15)

Since cgram.y 1.325 from 2021-07-15, conditional expressions did not
accept a comma-expression in the then-branch anymore.  In practice, this
is an edge case though since comma expressions are rare.


To generate a diff of this commit:
cvs rdiff -u -r1.5 -r1.6 src/tests/usr.bin/xlint/lint1/expr_precedence.c \
    src/tests/usr.bin/xlint/lint1/expr_precedence.exp

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/tests/usr.bin/xlint/lint1/expr_precedence.c
diff -u src/tests/usr.bin/xlint/lint1/expr_precedence.c:1.5 src/tests/usr.bin/xlint/lint1/expr_precedence.c:1.6
--- src/tests/usr.bin/xlint/lint1/expr_precedence.c:1.5	Mon Jul 26 17:27:22 2021
+++ src/tests/usr.bin/xlint/lint1/expr_precedence.c	Mon Jul 26 18:06:43 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: expr_precedence.c,v 1.5 2021/07/26 17:27:22 rillig Exp $	*/
+/*	$NetBSD: expr_precedence.c,v 1.6 2021/07/26 18:06:43 rillig Exp $	*/
 # 3 "expr_precedence.c"
 
 /*
@@ -51,3 +51,27 @@ assignment_associativity(int arg)
 
 	left = arg;
 }
+
+void
+conditional_associativity(_Bool cond1, _Bool cond2, int a, int b, int c)
+{
+	/* The then-expression can be an arbitrary expression. */
+	var = cond1 ? cond2 ? a : b : c;
+	var = cond1 ? (cond2 ? a : b) : c;
+
+	/* The then-expression can even be a comma-expression. */
+	/* expect+1: error: syntax error ',' [249] *//* FIXME */
+	var = cond1 ? cond2 ? a, b : (b, a) : c;
+
+	var = cond1 ? a : cond2 ? b : c;
+	/*
+	 * In almost all programming languages, '?:' is right-associative,
+	 * which allows for easy chaining.
+	 */
+	var = cond1 ? a : (cond2 ? b : c);
+	/*
+	 * In PHP, '?:' is left-associative, which is rather surprising and
+	 * requires more parentheses to get the desired effect.
+	 */
+	var = (cond1 ? a : cond2) ? b : c;
+}
Index: src/tests/usr.bin/xlint/lint1/expr_precedence.exp
diff -u src/tests/usr.bin/xlint/lint1/expr_precedence.exp:1.5 src/tests/usr.bin/xlint/lint1/expr_precedence.exp:1.6
--- src/tests/usr.bin/xlint/lint1/expr_precedence.exp:1.5	Mon Jul 26 17:27:22 2021
+++ src/tests/usr.bin/xlint/lint1/expr_precedence.exp	Mon Jul 26 18:06:43 2021
@@ -2,3 +2,4 @@ expr_precedence.c(15): error: syntax err
 expr_precedence.c(18): error: non-constant initializer [177]
 expr_precedence.c(35): error: 'var' undefined [99]
 expr_precedence.c(35): error: syntax error '=' [249]
+expr_precedence.c(64): error: syntax error ',' [249]

Reply via email to