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

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 ! { dg-do compile }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 ! PR fortran/88072
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 ! Original code contributed by Andrew Wood <andrew at fluidgravity dot co.uk>
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 module m1
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 implicit none
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 type, abstract, public :: t1
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 integer, dimension(:), allocatable :: i
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 contains
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 procedure(f1), deferred :: f
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 end type t1
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 type, extends(t1), public :: t2 ! { dg-error "must be ABSTRACT because" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 contains
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 procedure :: f => f2 ! { dg-error "mismatch for the overriding" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17 end type t2
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 abstract interface
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 function f1(this) ! { dg-error "must be dummy, allocatable or" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 import
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 class(t1) :: this
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23 class(t1) :: f1
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24 end function f1
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 end interface
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26 contains
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 type(t2) function f2(this)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 class(t2) :: this
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29 end function f2
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 end module m1