NetBSD/tests/usr.bin/xlint/lint1/d_c99_complex_split.c

88 lines
1.9 KiB
C
Raw Normal View History

/* $NetBSD: d_c99_complex_split.c,v 1.13 2023/03/28 14:44:34 rillig Exp $ */
# 3 "d_c99_complex_split.c"
/*
* Checks that the real and imaginary parts of a complex number can be
* accessed (since C99).
*/
/* lint1-extra-flags: -X 351 */
int
b(double a)
{
return a == 0;
}
void
a(void)
{
double _Complex z = 0;
if (b(__real__ z) && b(__imag__ z))
return;
2014-04-17 22:34:44 +04:00
}
void sink(double _Complex);
/*
* Before tree.c 1.275 from 2021-04-09, lint wrongly warned that when
* '__real__ c' was assigned, 'c may be used before set'.
*
* As of 2021-04-09, support for _Complex is still very incomplete, see
* build_real_imag for details. For example, lint does not know that after
* the assignment to '__real__ c', the variable is partially initialized.
*/
void
set_complex_complete(double re, double im)
{
double _Complex c;
__real__ c = re;
__imag__ c = im;
sink(c);
}
/*
* Before tree.c 1.275 from 2021-04-09, lint wrongly warned that when
* '__real__ c' was assigned, 'c may be used before set [158]'.
*
* As of 2021-04-09, support for _Complex is still very incomplete, see
* build_real_imag for details.
*/
void
set_complex_only_real(double re)
{
double _Complex c;
__real__ c = re;
/* __imag__ c is left uninitialized */
sink(c); /* XXX: may be used before set */
}
/*
* Before tree.c 1.275 from 2021-04-09, lint wrongly warned that when
* '__imag__ c' was assigned, 'c may be used before set [158]'.
*
* As of 2021-04-09, support for _Complex is still very incomplete, see
* build_real_imag for details.
*/
void
set_complex_only_imag(double im)
{
double _Complex c;
/* __real__ c is left uninitialized */
__imag__ c = im;
sink(c); /* XXX: may be used before set */
}
void
precedence_cast_expression(void)
{
double _Complex z = 0;
if (b(__real__(double _Complex)z) && b(__imag__(double _Complex)z))
return;
if (b(__real__(z)) && b(__imag__(z)))
return;
}