summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorvlefevre <vlefevre@280ebfd0-de03-0410-8827-d642c229c3f4>2021-03-09 10:28:45 +0000
committervlefevre <vlefevre@280ebfd0-de03-0410-8827-d642c229c3f4>2021-03-09 10:28:45 +0000
commit618351b9a051e1a6fa3c5a1b40afc7ae2ba3b7cf (patch)
tree3f0934c62731429b552415c545b79308898d7025
parent2240e86e9e2dea5ea5d5dfb98d437b54ff79d87d (diff)
downloadmpfr-618351b9a051e1a6fa3c5a1b40afc7ae2ba3b7cf.tar.gz
Completed tests/tcopysign.c to test with a reused argument.
(merged part of changeset r14227 from the trunk) git-svn-id: https://scm.gforge.inria.fr/anonscm/svn/mpfr/branches/4.1@14468 280ebfd0-de03-0410-8827-d642c229c3f4
-rw-r--r--tests/tcopysign.c29
1 files changed, 22 insertions, 7 deletions
diff --git a/tests/tcopysign.c b/tests/tcopysign.c
index 24d14fba9..354f6ad2d 100644
--- a/tests/tcopysign.c
+++ b/tests/tcopysign.c
@@ -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);