Module Name:    src
Committed By:   rillig
Date:           Tue May  9 14:46:36 UTC 2023

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

Log Message:
tests/lint: demonstrate wrong warning about losing accuracy


To generate a diff of this commit:
cvs rdiff -u -r1.26 -r1.27 src/tests/usr.bin/xlint/lint1/msg_132.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/msg_132.c
diff -u src/tests/usr.bin/xlint/lint1/msg_132.c:1.26 src/tests/usr.bin/xlint/lint1/msg_132.c:1.27
--- src/tests/usr.bin/xlint/lint1/msg_132.c:1.26	Tue Mar 28 14:44:34 2023
+++ src/tests/usr.bin/xlint/lint1/msg_132.c	Tue May  9 14:46:36 2023
@@ -1,4 +1,4 @@
-/*	$NetBSD: msg_132.c,v 1.26 2023/03/28 14:44:34 rillig Exp $	*/
+/*	$NetBSD: msg_132.c,v 1.27 2023/05/09 14:46:36 rillig Exp $	*/
 # 3 "msg_132.c"
 
 // Test for message: conversion from '%s' to '%s' may lose accuracy [132]
@@ -24,6 +24,8 @@ typedef signed short s16_t;
 typedef signed int s32_t;
 typedef signed long long s64_t;
 
+_Bool cond;
+char ch;
 
 u8_t u8;
 u16_t u16;
@@ -365,3 +367,28 @@ test_ic_bitand(void)
 	/* expect+1: warning: conversion from 'unsigned int' to 'unsigned char' may lose accuracy [132] */
 	u8 = u16 & u32;
 }
+
+void
+test_ic_conditional(char c1, char c2)
+{
+	/* Both operands are representable as char. */
+	/* FIXME */
+	/* expect+1: warning: conversion from 'int' to 'char' may lose accuracy [132] */
+	ch = cond ? '?' : ':';
+
+	/*
+	 * Both operands are representable as char. Clang-Tidy 17 wrongly
+	 * warns about a narrowing conversion from 'int' to signed type
+	 * 'char'.
+	 */
+	/* FIXME */
+	/* expect+1: warning: conversion from 'int' to 'char' may lose accuracy [132] */
+	ch = cond ? c1 : c2;
+
+	/* FIXME */
+	/* expect+1: warning: conversion from 'int' to 'signed char' may lose accuracy [132] */
+	s8 = cond ? s8 : u8;
+
+	/* expect+1: warning: conversion from 'int' to 'unsigned char' may lose accuracy [132] */
+	u8 = cond ? s8 : u8;
+}

Reply via email to