276 lines
5 KiB
Fortran
276 lines
5 KiB
Fortran
! RUN: %python %S/test_errors.py %s %flang_fc1
|
|
module m1
|
|
implicit none
|
|
contains
|
|
subroutine foo(x)
|
|
real :: x
|
|
end subroutine
|
|
end module
|
|
|
|
!Note: PGI, Intel, GNU, and NAG allow this; Sun does not
|
|
module m2
|
|
use m1
|
|
implicit none
|
|
!WARNING: 'foo' should not be the name of both a generic interface and a procedure unless it is a specific procedure of the generic
|
|
interface foo
|
|
module procedure s
|
|
end interface
|
|
contains
|
|
subroutine s(i)
|
|
integer :: i
|
|
end subroutine
|
|
end module
|
|
|
|
subroutine foo
|
|
!ERROR: Cannot use-associate 'foo'; it is already declared in this scope
|
|
use m1
|
|
end
|
|
|
|
subroutine bar
|
|
!ERROR: Cannot use-associate 'bar'; it is already declared in this scope
|
|
use m1, bar => foo
|
|
end
|
|
|
|
!OK to use-associate a type with the same name as a generic
|
|
module m3a
|
|
type :: foo
|
|
end type
|
|
end
|
|
module m3b
|
|
use m3a
|
|
interface foo
|
|
end interface
|
|
end
|
|
|
|
! Can't have derived type and function with same name
|
|
module m4a
|
|
type :: foo
|
|
end type
|
|
contains
|
|
!ERROR: 'foo' is already declared in this scoping unit
|
|
function foo(x)
|
|
end
|
|
end
|
|
! Even if there is also a generic interface of that name
|
|
module m4b
|
|
type :: foo
|
|
end type
|
|
interface foo
|
|
procedure :: foo
|
|
end interface foo
|
|
contains
|
|
!ERROR: 'foo' is already declared in this scoping unit
|
|
function foo(x)
|
|
end
|
|
end
|
|
module m4c
|
|
type :: foo
|
|
end type
|
|
interface foo
|
|
!ERROR: 'foo' is already declared in this scoping unit
|
|
real function foo()
|
|
end function foo
|
|
end interface foo
|
|
end
|
|
|
|
! Use associating a name that is a generic and a derived type
|
|
module m5a
|
|
interface g
|
|
end interface
|
|
type g
|
|
end type
|
|
end module
|
|
module m5b
|
|
use m5a
|
|
interface g
|
|
procedure f
|
|
end interface
|
|
type(g) :: x
|
|
contains
|
|
function f(i)
|
|
end function
|
|
end module
|
|
subroutine s5
|
|
use m5b
|
|
type(g) :: y
|
|
end
|
|
|
|
module m6
|
|
real :: f6
|
|
interface g6
|
|
!ERROR: 'f6' is already declared in this scoping unit
|
|
real function f6()
|
|
end function f6
|
|
end interface g6
|
|
end module m6
|
|
|
|
module m7
|
|
integer :: f7
|
|
interface g7
|
|
!ERROR: 'f7' is already declared in this scoping unit
|
|
real function f7()
|
|
end function f7
|
|
end interface g7
|
|
end module m7
|
|
|
|
module m8
|
|
real :: f8
|
|
interface g8
|
|
!ERROR: 'f8' is already declared in this scoping unit
|
|
subroutine f8()
|
|
end subroutine f8
|
|
end interface g8
|
|
end module m8
|
|
|
|
module m9
|
|
type f9
|
|
end type f9
|
|
interface f9
|
|
real function f9()
|
|
end function f9
|
|
end interface f9
|
|
contains
|
|
!ERROR: 'f9' is already declared in this scoping unit
|
|
function f9(x)
|
|
end function f9
|
|
end module m9
|
|
|
|
module m10
|
|
type :: t10
|
|
end type t10
|
|
interface f10
|
|
function f10()
|
|
end function f10
|
|
end interface f10
|
|
contains
|
|
!ERROR: 'f10' is already declared in this scoping unit
|
|
function f10(x)
|
|
end function f10
|
|
end module m10
|
|
|
|
module m11
|
|
type :: t11
|
|
end type t11
|
|
interface i11
|
|
function f11()
|
|
end function f11
|
|
end interface i11
|
|
contains
|
|
!ERROR: 'f11' is already declared in this scoping unit
|
|
function f11(x)
|
|
end function f11
|
|
end module m11
|
|
|
|
module m12
|
|
interface f12
|
|
function f12()
|
|
end function f12
|
|
end interface f12
|
|
contains
|
|
!ERROR: 'f12' is already declared in this scoping unit
|
|
function f12(x)
|
|
end function f12
|
|
end module m12
|
|
|
|
module m13
|
|
interface f13
|
|
function f13()
|
|
end function f13
|
|
end interface f13
|
|
contains
|
|
!ERROR: 'f13' is already declared in this scoping unit
|
|
function f13()
|
|
end function f13
|
|
end module m13
|
|
|
|
! Not an error
|
|
module m14
|
|
interface gen1
|
|
module procedure s
|
|
end interface
|
|
generic :: gen2 => s
|
|
contains
|
|
subroutine s(x)
|
|
integer(1) :: x
|
|
end subroutine s
|
|
end module m14
|
|
module m15
|
|
use m14
|
|
interface gen1
|
|
module procedure gen1
|
|
end interface
|
|
generic :: gen2 => gen2
|
|
contains
|
|
subroutine gen1(x)
|
|
integer(2) :: x
|
|
end subroutine gen1
|
|
subroutine gen2(x)
|
|
integer(4) :: x
|
|
end subroutine gen2
|
|
end module m15
|
|
|
|
module m15a
|
|
interface foo
|
|
module procedure foo
|
|
end interface
|
|
contains
|
|
function foo()
|
|
end
|
|
end
|
|
|
|
module m15b
|
|
interface foo
|
|
module procedure foo
|
|
end interface
|
|
contains
|
|
function foo(x)
|
|
end
|
|
end
|
|
|
|
subroutine test15
|
|
use m15a
|
|
!ERROR: Cannot use-associate generic interface 'foo' with specific procedure of the same name when another such interface and procedure are in scope
|
|
use m15b
|
|
end
|
|
|
|
module m16a
|
|
type foo
|
|
integer j
|
|
end type
|
|
interface foo
|
|
module procedure bar
|
|
end interface
|
|
contains
|
|
function bar(j)
|
|
end
|
|
end
|
|
|
|
module m16b
|
|
type foo
|
|
integer j, k
|
|
end type
|
|
interface foo
|
|
module procedure bar
|
|
end interface
|
|
contains
|
|
function bar(x,y)
|
|
end
|
|
end
|
|
|
|
subroutine test16
|
|
use m16a
|
|
!ERROR: Generic interface 'foo' has ambiguous derived types from modules 'm16a' and 'm16b'
|
|
use m16b
|
|
end
|
|
|
|
subroutine test17
|
|
use m15a
|
|
!ERROR: Cannot use-associate generic interface 'foo' with derived type of the same name when another such interface and procedure are in scope
|
|
use m16a
|
|
end
|
|
|
|
subroutine test18
|
|
use m16a
|
|
!ERROR: Cannot use-associate generic interface 'foo' with specific procedure of the same name when another such interface and derived type are in scope
|
|
use m15a
|
|
end
|