Files
llvm/flang/test/Semantics/declarations02.f90
Peter Klausler 69e2665c8b [flang] BIND(C,NAME=...) corrections
The Fortran standard's various restrictions on the use of BIND(C)
often depend more on the presence or absence of an explicit NAME=
specification rather than on its value, but semantics and module
file generation aren't making distinctions between explicit NAME=
specifications that happen to match the default name and declarations
that don't have NAME=.  Tweak semantics and module file generation
to conform, and also complain when named BIND(C) attributes are
erroneously applied to entities that can't support them, like
ABSTRACT interfaces.

Differential Revision: https://reviews.llvm.org/D145107
2023-03-02 10:10:06 -08:00

35 lines
1.2 KiB
Fortran

! RUN: %python %S/test_errors.py %s %flang_fc1
module m
!ERROR: 'x1' may not have both the BIND(C) and PARAMETER attributes
integer, parameter, bind(c, name="a") :: x1 = 1
!ERROR: 'x2' may not have both the BIND(C) and PARAMETER attributes
integer, bind(c), parameter :: x2 = 1
!ERROR: 'x3' may not have both the BIND(C) and PARAMETER attributes
integer, parameter :: x3 = 1
bind(c) :: x3
type :: my_type1
integer :: x4
end type
type, bind(c) :: my_type2
integer :: x5
end type
!ERROR: 't1' may not have both the BIND(C) and PARAMETER attributes
!ERROR: The derived type of a BIND(C) object must also be BIND(C)
type(my_type1), bind(c), parameter :: t1 = my_type1(1)
!ERROR: 't2' may not have both the BIND(C) and PARAMETER attributes
type(my_type2), bind(c), parameter :: t2 = my_type2(1)
type(my_type2), parameter :: t3 = my_type2(1) ! no error
!ERROR: 't4' may not have both the BIND(C) and PARAMETER attributes
!ERROR: The derived type of a BIND(C) object must also be BIND(C)
type(my_type1), parameter :: t4 = my_type1(1)
!ERROR: 't5' may not have both the BIND(C) and PARAMETER attributes
type(my_type2), parameter :: t5 = my_type2(1)
bind(c) :: t4, t5
end