Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

/*	$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;
}

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;
}