2021-09-06 16:19:20 +08:00
|
|
|
! RUN: %python %S/test_errors.py %s %flang_fc1
|
2020-03-20 11:07:01 +08:00
|
|
|
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
|
2020-05-13 00:53:58 +08:00
|
|
|
!ERROR: Procedure component 'nonpointerfield' must have POINTER attribute
|
|
|
|
procedure(publicProc), public :: nonpointerField
|
2020-03-20 11:07:01 +08:00
|
|
|
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
|