Mentions légales du service

Skip to content
Snippets Groups Projects
Commit cbe3f469 authored by Vincent Lefèvre's avatar Vincent Lefèvre
Browse files

Completed tests/tcopysign.c to test with a reused argument.

(merged part of changeset r14227 from the trunk)

[From SVN r14468 (branches/4.1)]
parent 3959e4c9
No related branches found
No related tags found
No related merge requests found
......@@ -26,26 +26,41 @@ static void
copysign_variant (mpfr_ptr z, mpfr_srcptr x, mpfr_srcptr y,
mpfr_rnd_t rnd_mode, int k)
{
mpfr_srcptr p;
/* invalid sign, to test that the sign is always correctly set */
MPFR_SIGN (z) = 0;
if (k >= 6)
{
MPFR_ASSERTN (MPFR_PREC (z) >= MPFR_PREC (x));
mpfr_set (z, x, MPFR_RNDN);
p = z;
k -= 6;
}
else
p = x;
mpfr_clear_flags ();
switch (k)
{
case 0:
mpfr_copysign (z, x, y, MPFR_RNDN);
mpfr_copysign (z, p, y, rnd_mode);
return;
case 1:
(mpfr_copysign) (z, x, y, MPFR_RNDN);
(mpfr_copysign) (z, p, y, rnd_mode);
return;
case 2:
mpfr_setsign (z, x, mpfr_signbit (y), MPFR_RNDN);
mpfr_setsign (z, p, mpfr_signbit (y), rnd_mode);
return;
case 3:
mpfr_setsign (z, x, (mpfr_signbit) (y), MPFR_RNDN);
mpfr_setsign (z, p, (mpfr_signbit) (y), rnd_mode);
return;
case 4:
(mpfr_setsign) (z, x, mpfr_signbit (y), MPFR_RNDN);
(mpfr_setsign) (z, p, mpfr_signbit (y), rnd_mode);
return;
case 5:
(mpfr_setsign) (z, x, (mpfr_signbit) (y), MPFR_RNDN);
(mpfr_setsign) (z, p, (mpfr_signbit) (y), rnd_mode);
return;
}
}
......@@ -64,7 +79,7 @@ main (void)
for (i = 0; i <= 1; i++)
for (j = 0; j <= 1; j++)
for (k = 0; k <= 5; k++)
for (k = 0; k < 12; k++)
{
mpfr_set_nan (x);
i ? MPFR_SET_NEG (x) : MPFR_SET_POS (x);
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment