[flang-commits] [flang] e2ac99b - [flang] Add check for conflict of BIND(C) and Parameter attributes

via flang-commits flang-commits at lists.llvm.org
Thu Jun 2 05:59:14 PDT 2022


Author: PeixinQiao
Date: 2022-06-02T20:58:05+08:00
New Revision: e2ac99b79d6f36de93775aa683a4e439cb4b5344

URL: https://github.com/llvm/llvm-project/commit/e2ac99b79d6f36de93775aa683a4e439cb4b5344
DIFF: https://github.com/llvm/llvm-project/commit/e2ac99b79d6f36de93775aa683a4e439cb4b5344.diff

LOG: [flang] Add check for conflict of BIND(C) and Parameter attributes

The entity with BIND(C) attribute cannot be a named constant, so the
BIND(C) and parameter attributes are conflicted. Add check for it.

Reviewed By: klausler

Differential Revision: https://reviews.llvm.org/D126654

Added: 
    flang/test/Semantics/declarations02.f90

Modified: 
    flang/lib/Semantics/check-declarations.cpp

Removed: 
    


################################################################################
diff  --git a/flang/lib/Semantics/check-declarations.cpp b/flang/lib/Semantics/check-declarations.cpp
index 805d89075e3f..b193252442db 100644
--- a/flang/lib/Semantics/check-declarations.cpp
+++ b/flang/lib/Semantics/check-declarations.cpp
@@ -1873,11 +1873,11 @@ static const std::string *DefinesBindCName(const Symbol &symbol) {
   }
 }
 
-// Check that BIND(C) names are distinct and BIND(C) variable declared in module
 void CheckHelper::CheckBindC(const Symbol &symbol) {
   if (!symbol.attrs().test(Attr::BIND_C)) {
     return;
   }
+  CheckConflicting(symbol, Attr::BIND_C, Attr::PARAMETER);
   if (symbol.has<ObjectEntityDetails>() && !symbol.owner().IsModule()) {
     messages_.Say(symbol.name(),
         "A variable with BIND(C) attribute may only appear in the specification part of a module"_err_en_US);

diff  --git a/flang/test/Semantics/declarations02.f90 b/flang/test/Semantics/declarations02.f90
new file mode 100644
index 000000000000..016888fff5e1
--- /dev/null
+++ b/flang/test/Semantics/declarations02.f90
@@ -0,0 +1,32 @@
+! 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
+  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
+  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


        


More information about the flang-commits mailing list