annotate gcc/testsuite/gfortran.dg/dummy_procedure_11.f90 @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
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 !
kono
parents:
diff changeset
3 ! PR 60507: Passing function call into procedure argument not caught
kono
parents:
diff changeset
4 !
kono
parents:
diff changeset
5 ! Contributed by Vladimir Fuka <vladimir.fuka@gmail.com>
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 type :: t
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
8 procedure(g), pointer, nopass :: ppc
111
kono
parents:
diff changeset
9 end type
kono
parents:
diff changeset
10
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
11 procedure(g), pointer :: pp
111
kono
parents:
diff changeset
12 type(t)::x
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 print *, f(g)
kono
parents:
diff changeset
15 print *, f(g()) ! { dg-error "Expected a procedure for argument" }
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
16 pp => g
111
kono
parents:
diff changeset
17 print *, f(pp)
kono
parents:
diff changeset
18 print *, f(pp()) ! { dg-error "Expected a procedure for argument" }
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
19 x%ppc => g
111
kono
parents:
diff changeset
20 print *, f(x%ppc)
kono
parents:
diff changeset
21 print *, f(x%ppc()) ! { dg-error "Expected a procedure for argument" }
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 contains
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 real function f(fun)
kono
parents:
diff changeset
26 procedure(g) :: fun
kono
parents:
diff changeset
27 f = fun()
kono
parents:
diff changeset
28 end function
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 real function g()
kono
parents:
diff changeset
31 g = 1.
kono
parents:
diff changeset
32 end function
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 end