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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
! RUN: %S/test_errors.sh %s %t %flang_fc1
module m
! C755 The same proc-component-attr-spec shall not appear more than once in a
! given proc-component-def-stmt.
! C759 PASS and NOPASS shall not both appear in the same
! proc-component-attr-spec-list.
!
! R741 proc-component-def-stmt ->
! PROCEDURE ( [proc-interface] ) , proc-component-attr-spec-list
! :: proc-decl-list
! proc-component-attr-spec values are:
! PUBLIC, PRIVATE, NOPASS, PASS, POINTER
type :: procComponentType
!WARNING: Attribute 'PUBLIC' cannot be used more than once
procedure(publicProc), public, pointer, public :: publicField
!WARNING: Attribute 'PRIVATE' cannot be used more than once
procedure(privateProc), private, pointer, private :: privateField
!WARNING: Attribute 'NOPASS' cannot be used more than once
procedure(nopassProc), nopass, pointer, nopass :: noPassField
!WARNING: Attribute 'PASS' cannot be used more than once
procedure(passProc), pass, pointer, pass :: passField
!ERROR: Attributes 'PASS' and 'NOPASS' conflict with each other
procedure(passNopassProc), pass, pointer, nopass :: passNopassField
!WARNING: Attribute 'POINTER' cannot be used more than once
procedure(pointerProc), pointer, public, pointer :: pointerField
!ERROR: Procedure component 'nonpointerfield' must have POINTER attribute
procedure(publicProc), public :: nonpointerField
contains
procedure :: noPassProc
procedure :: passProc
procedure :: passNopassProc
procedure :: publicProc
procedure :: privateProc
end type procComponentType
contains
subroutine publicProc(arg)
class(procComponentType) :: arg
end
subroutine privateProc(arg)
class(procComponentType) :: arg
end
subroutine noPassProc(arg)
class(procComponentType) :: arg
end
subroutine passProc(arg)
class(procComponentType) :: arg
end
subroutine passNopassProc(arg)
class(procComponentType) :: arg
end
subroutine pointerProc(arg)
class(procComponentType) :: arg
end
end module m
|