blob: 3691292b5424e37f5ca9757b7e2274da904941ee (
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
|
! { 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
|