xref: /netbsd-src/tests/usr.bin/xlint/lint1/lex_wide_string.c (revision 708a1296c5016725128ec08bc700cf7eda4da4f3)
1*708a1296Srillig /*	$NetBSD: lex_wide_string.c,v 1.5 2024/02/02 22:45:48 rillig Exp $	*/
23ce615ebSrillig # 3 "lex_wide_string.c"
33ce615ebSrillig 
43ce615ebSrillig /*
53ce615ebSrillig  * Test lexical analysis of wide string constants.
63ce615ebSrillig  *
73ce615ebSrillig  * C99 6.4.5 "String literals"
83ce615ebSrillig  */
93ce615ebSrillig 
10b2baa501Srillig /* lint1-extra-flags: -X 351 */
11b2baa501Srillig 
123ce615ebSrillig void sink(const int *);
133ce615ebSrillig 
143ce615ebSrillig void
test(void)153ce615ebSrillig test(void)
163ce615ebSrillig {
173ce615ebSrillig 	sink(L"");
183ce615ebSrillig 
193ce615ebSrillig 	sink(L"hello, world\n");
203ce615ebSrillig 
213ce615ebSrillig 	sink(L"\0");
223ce615ebSrillig 
233ce615ebSrillig 	sink(L"\0\0\0\0");
243ce615ebSrillig 
25c83f7defSrillig 	/* expect+1: error: no hex digits follow \x [74] */
263ce615ebSrillig 	sink(L"\x");
273ce615ebSrillig 
28c83f7defSrillig 	/* expect+1: warning: dubious escape \y [79] */
293ce615ebSrillig 	sink(L"\y");
300b138779Srillig 
310b138779Srillig 	sink(L"first" L"second");
320b138779Srillig 
330b138779Srillig 	/* expect+1: error: cannot concatenate wide and regular string literals [292] */
340b138779Srillig 	sink(L"wide" "plain");
353ce615ebSrillig }
36*708a1296Srillig 
37*708a1296Srillig /*
38*708a1296Srillig  * Since lint always runs in the default "C" locale, it does not support any
39*708a1296Srillig  * multibyte character encoding, thus treating each byte as a separate
40*708a1296Srillig  * character. If lint were to support UTF-8, the array dimension would be 3
41*708a1296Srillig  * instead of 7.
42*708a1296Srillig  */
43*708a1296Srillig /* expect+1: error: negative array dimension (-7) [20] */
44*708a1296Srillig typedef int mblen[-(int)(sizeof(L"Ä��") / sizeof(L""))];
45