llvm/flang/test/Semantics/bind-c04.f90

! RUN: %python %S/test_errors.py %s %flang_fc1
! Check for C1520
! If proc-language-binding-spec (bind(c)) with NAME= is specified, then
! proc-decl-list shall contain exactly one proc-decl, which shall neither have
! the POINTER attribute nor be a dummy procedure.

subroutine sub(x, y)

  interface
    subroutine proc() bind(c)
    end
  end interface

  abstract interface
    !ERROR: An ABSTRACT interface may not have a BIND attribute with a name
    subroutine aproc1() bind(c,name="foo")
    end
    subroutine aproc2() bind(c) ! ok
    end
  end interface

  !ERROR: A procedure declaration statement with a binding name may not declare multiple procedures
  procedure(proc), bind(c, name="aaa") :: pc1, pc2

  !ERROR: A procedure pointer may not have a BIND attribute with a name
  procedure(proc), bind(c, name="bbb"), pointer :: pc3

  !ERROR: An internal or dummy procedure may not have a BIND(C,NAME=) binding label
  procedure(proc), bind(c, name="ccc") :: x

  procedure(proc), bind(c) :: pc4, pc5

  !ERROR: A procedure pointer may not have a BIND attribute with a name
  procedure(proc), bind(c, name="pc6"), pointer :: pc6

  procedure(proc), bind(c), pointer :: pc7

  procedure(proc), bind(c) :: y

  !WARNING: Attribute 'BIND(C)' cannot be used more than once
  !ERROR: A procedure pointer may not have a BIND attribute with a name
  procedure(proc), bind(c, name="pc8"), bind(c), pointer :: pc8

end