Module Name: src
Committed By: rillig
Date: Sun Aug 1 13:09:38 UTC 2021
Modified Files:
src/tests/usr.bin/xlint/lint1: c11_generic_expression.c
Log Message:
tests/lint: document why lint does not check _Generic selections
To generate a diff of this commit:
cvs rdiff -u -r1.8 -r1.9 \
src/tests/usr.bin/xlint/lint1/c11_generic_expression.c
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/c11_generic_expression.c
diff -u src/tests/usr.bin/xlint/lint1/c11_generic_expression.c:1.8 src/tests/usr.bin/xlint/lint1/c11_generic_expression.c:1.9
--- src/tests/usr.bin/xlint/lint1/c11_generic_expression.c:1.8 Sun Jul 11 20:37:21 2021
+++ src/tests/usr.bin/xlint/lint1/c11_generic_expression.c Sun Aug 1 13:09:38 2021
@@ -1,4 +1,4 @@
-/* $NetBSD: c11_generic_expression.c,v 1.8 2021/07/11 20:37:21 rillig Exp $ */
+/* $NetBSD: c11_generic_expression.c,v 1.9 2021/08/01 13:09:38 rillig Exp $ */
# 3 "c11_generic_expression.c"
/*
@@ -94,3 +94,13 @@ primary_expression(void)
{
return _Generic(0, int: assignment_expression)(0, 0);
}
+
+/*
+ * The types don't match, therefore build_generic_selection returns NULL,
+ * which is then silently ignored by init_expr. This situation is already
+ * covered by the compilers, so there is no need for lint to double-check it.
+ */
+const char *x = _Generic(
+ (__uint128_t)1 + 1.0f,
+ int: 1
+);