blob: d9a845b073bca6663597726df6fbe5697e187ffb (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
! { dg-do compile }
! Type-bound procedures
! Check for correct access-checking on type-bound procedures.
MODULE m
IMPLICIT NONE
TYPE t
CONTAINS
PROCEDURE, NOPASS, PRIVATE :: priv => proc
PROCEDURE, NOPASS, PUBLIC :: publ => proc
END TYPE t
CONTAINS
SUBROUTINE proc ()
END SUBROUTINE proc
! This is inside the module.
SUBROUTINE test1 ()
IMPLICIT NONE
TYPE(t) :: obj
CALL obj%priv () ! { dg-bogus "PRIVATE" }
CALL obj%publ ()
END SUBROUTINE test1
END MODULE m
! This is outside the module.
SUBROUTINE test2 ()
USE m
IMPLICIT NONE
TYPE(t) :: obj
CALL obj%priv () ! { dg-error "PRIVATE" }
CALL obj%publ ()
END SUBROUTINE test2
! { dg-final { cleanup-modules "m" } }
|