annotate gcc/testsuite/gfortran.dg/internal_dummy_3.f08 @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +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 }
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
2 ! { dg-options "-std=f2008 " }
111
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 ! PR fortran/34162
kono
parents:
diff changeset
5 ! Internal procedures as actual arguments (like restricted closures).
kono
parents:
diff changeset
6 ! More challenging test involving recursion.
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 ! Contributed by Daniel Kraft, d@domob.eu.
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 MODULE m
kono
parents:
diff changeset
11 IMPLICIT NONE
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 ABSTRACT INTERFACE
kono
parents:
diff changeset
14 FUNCTION returnValue ()
kono
parents:
diff changeset
15 INTEGER :: returnValue
kono
parents:
diff changeset
16 END FUNCTION returnValue
kono
parents:
diff changeset
17 END INTERFACE
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19 PROCEDURE(returnValue), POINTER :: first
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 CONTAINS
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 RECURSIVE SUBROUTINE test (level, current, previous)
kono
parents:
diff changeset
24 INTEGER, INTENT(IN) :: level
kono
parents:
diff changeset
25 PROCEDURE(returnValue), OPTIONAL :: previous, current
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 IF (PRESENT (current)) THEN
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
28 IF (current () /= level - 1) STOP 1
111
kono
parents:
diff changeset
29 END IF
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 IF (PRESENT (previous)) THEN
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
32 IF (previous () /= level - 2) STOP 2
111
kono
parents:
diff changeset
33 END IF
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 IF (level == 1) THEN
kono
parents:
diff changeset
36 first => myLevel
kono
parents:
diff changeset
37 END IF
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
38 IF (first () /= 1) STOP 3
111
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 IF (level == 10) RETURN
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 IF (PRESENT (current)) THEN
kono
parents:
diff changeset
43 CALL test (level + 1, myLevel, current)
kono
parents:
diff changeset
44 ELSE
kono
parents:
diff changeset
45 CALL test (level + 1, myLevel)
kono
parents:
diff changeset
46 END IF
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 CONTAINS
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 FUNCTION myLevel ()
kono
parents:
diff changeset
51 INTEGER :: myLevel
kono
parents:
diff changeset
52 myLevel = level
kono
parents:
diff changeset
53 END FUNCTION myLevel
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 END SUBROUTINE test
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 END MODULE m
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 PROGRAM main
kono
parents:
diff changeset
60 USE :: m
kono
parents:
diff changeset
61 IMPLICIT NONE
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 CALL test (1)
kono
parents:
diff changeset
64 END PROGRAM main