llvm/flang/test/Semantics/declarations02.f90

! RUN: %python %S/test_errors.py %s %flang_fc1 -pedantic

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

  !ERROR: 'x4' may not have both the ALLOCATABLE and PARAMETER attributes
  !ERROR: 'x4' may not have both the ASYNCHRONOUS and PARAMETER attributes
  !ERROR: 'x4' may not have both the SAVE and PARAMETER attributes
  !ERROR: 'x4' may not have both the TARGET and PARAMETER attributes
  !ERROR: 'x4' may not have both the VOLATILE and PARAMETER attributes
  !ERROR: The entity 'x4' with an explicit SAVE attribute must be a variable, procedure pointer, or COMMON block
  !ERROR: An entity may not have the ASYNCHRONOUS attribute unless it is a variable
  integer, parameter :: x4 = 1
  allocatable x4
  asynchronous x4
  save x4
  target x4
  volatile x4

  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
  !WARNING: The derived type of an interoperable object should 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
  !WARNING: The derived type of an interoperable object should 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