annotate gcc/testsuite/gfortran.dg/whole_file_10.f90 @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +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 compile }
kono
parents:
diff changeset
2 ! Test the fix for the fifth problem in PR40011, where the
kono
parents:
diff changeset
3 ! entries were not resolved, resulting in a segfault.
kono
parents:
diff changeset
4 !
kono
parents:
diff changeset
5 ! Contributed by Dominique d'Humieres <dominiq@lps.ens.fr>
kono
parents:
diff changeset
6 !
kono
parents:
diff changeset
7 recursive function fac(i) result (res)
kono
parents:
diff changeset
8 integer :: i, j, k, res
kono
parents:
diff changeset
9 k = 1
kono
parents:
diff changeset
10 goto 100
kono
parents:
diff changeset
11 entry bifac(i,j) result (res)
kono
parents:
diff changeset
12 k = j
kono
parents:
diff changeset
13 100 continue
kono
parents:
diff changeset
14 if (i < k) then
kono
parents:
diff changeset
15 res = 1
kono
parents:
diff changeset
16 else
kono
parents:
diff changeset
17 res = i * bifac(i-k,k)
kono
parents:
diff changeset
18 end if
kono
parents:
diff changeset
19 end function
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 program test
kono
parents:
diff changeset
22 external fac
kono
parents:
diff changeset
23 external bifac
kono
parents:
diff changeset
24 integer :: fac, bifac
kono
parents:
diff changeset
25 print *, fac(5)
kono
parents:
diff changeset
26 print *, bifac(5,2)
kono
parents:
diff changeset
27 print*, fac(6)
kono
parents:
diff changeset
28 print *, bifac(6,2)
kono
parents:
diff changeset
29 print*, fac(0)
kono
parents:
diff changeset
30 print *, bifac(1,2)
kono
parents:
diff changeset
31 end program test