[flang-commits] [PATCH] D136905: [flang] Catch inconsistent function/subroutine usage of procedure pointer components

Peter Klausler via Phabricator via flang-commits flang-commits at lists.llvm.org
Sat Oct 29 16:41:14 PDT 2022


This revision was automatically updated to reflect the committed changes.
Closed by commit rG874fc5339e7c: [flang] Catch inconsistent function/subroutine usage of procedure pointer… (authored by klausler).

Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D136905/new/

https://reviews.llvm.org/D136905

Files:
  flang/lib/Semantics/resolve-names.cpp
  flang/test/Semantics/resolve09.f90


Index: flang/test/Semantics/resolve09.f90
===================================================================
--- flang/test/Semantics/resolve09.f90
+++ flang/test/Semantics/resolve09.f90
@@ -113,3 +113,16 @@
 function b8()
   b8 = 0.0
 end
+
+subroutine s9
+  type t
+    procedure(), nopass, pointer :: p1, p2
+  end type
+  type(t) x
+  print *, x%p1()
+  call x%p2
+  !ERROR: Cannot call function 'p1' like a subroutine
+  call x%p1
+  !ERROR: Cannot call subroutine 'p2' like a function
+  print *, x%p2()
+end subroutine
Index: flang/lib/Semantics/resolve-names.cpp
===================================================================
--- flang/lib/Semantics/resolve-names.cpp
+++ flang/lib/Semantics/resolve-names.cpp
@@ -6951,7 +6951,15 @@
   common::visit(
       common::visitors{
           [&](const parser::Name &x) { HandleProcedureName(procFlag, x); },
-          [&](const parser::ProcComponentRef &x) { Walk(x); },
+          [&](const parser::ProcComponentRef &x) {
+            Walk(x);
+            const parser::Name &name{x.v.thing.component};
+            if (Symbol * symbol{name.symbol}) {
+              if (IsProcedure(*symbol)) {
+                SetProcFlag(name, *symbol, procFlag);
+              }
+            }
+          },
       },
       std::get<parser::ProcedureDesignator>(call.t).u);
   Walk(std::get<std::list<parser::ActualArgSpec>>(call.t));


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D136905.471793.patch
Type: text/x-patch
Size: 1386 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/flang-commits/attachments/20221029/fc9bed2c/attachment-0001.bin>


More information about the flang-commits mailing list