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 +);