annotate gcc/testsuite/gfortran.dg/mod_sign0_1.f90 @ 132:d34655255c78

update gcc-8.2
author mir3636
date Thu, 25 Oct 2018 10:21:07 +0900
parents 84e7813d76e9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 ! { dg-do run }
kono
parents:
diff changeset
2 ! PR fortran/49010
kono
parents:
diff changeset
3 ! MOD/MODULO sign of zero.
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 ! We wish to provide the following guarantees:
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 ! MOD(A, P): The result has the sign of A and a magnitude less than
kono
parents:
diff changeset
8 ! that of P.
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 ! MODULO(A, P): The result has the sign of P and a magnitude less than
kono
parents:
diff changeset
11 ! that of P.
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 ! Here we test only with constant arguments (evaluated with
kono
parents:
diff changeset
14 ! mpfr_fmod), as we don't want to cause failures on targets with a
kono
parents:
diff changeset
15 ! crappy libm. But, a target where fmod follows C99 Annex F is
kono
parents:
diff changeset
16 ! fine. Also, targets where GCC inline expands fmod (such as x86(-64))
kono
parents:
diff changeset
17 ! are also fine.
kono
parents:
diff changeset
18 program mod_sign0_1
kono
parents:
diff changeset
19 implicit none
kono
parents:
diff changeset
20 real :: r, t
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 r = mod (4., 2.)
kono
parents:
diff changeset
23 t = sign (1., r)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
24 if (t < 0.) STOP 1
111
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 r = modulo (4., 2.)
kono
parents:
diff changeset
27 t = sign (1., r)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
28 if (t < 0.) STOP 2
111
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 r = mod (-4., 2.)
kono
parents:
diff changeset
31 t = sign (1., r)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
32 if (t > 0.) STOP 3
111
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 r = modulo (-4., 2.)
kono
parents:
diff changeset
35 t = sign (1., r)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
36 if (t < 0.) STOP 4
111
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 r = mod (4., -2.)
kono
parents:
diff changeset
39 t = sign (1., r)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
40 if (t < 0.) STOP 5
111
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 r = modulo (4., -2.)
kono
parents:
diff changeset
43 t = sign (1., r)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
44 if (t > 0.) STOP 6
111
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 r = mod (-4., -2.)
kono
parents:
diff changeset
47 t = sign (1., r)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
48 if (t > 0.) STOP 7
111
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 r = modulo (-4., -2.)
kono
parents:
diff changeset
51 t = sign (1., r)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
52 if (t > 0.) STOP 8
111
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 end program mod_sign0_1