]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR fortran/84394 (compiler error when using modules with derived types in block...
authorThomas Koenig <tkoenig@gcc.gnu.org>
Sun, 17 Mar 2019 12:54:29 +0000 (12:54 +0000)
committerThomas Koenig <tkoenig@gcc.gnu.org>
Sun, 17 Mar 2019 12:54:29 +0000 (12:54 +0000)
2019-03-17  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/84394
Backport from trunk
* symbol.c (gfc_add_subroutine): If we are encountering a
subrtoutine within a BLOCK DATA and the name starts with an
underscore, do not check.

2019-03-17  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/84394
Backport from trunk
* gfortran.dg/blockdata_11.f90: New test.

From-SVN: r269741

gcc/fortran/ChangeLog
gcc/fortran/symbol.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/blockdata_11.f90 [new file with mode: 0644]

index 9c8df3a488ca34e97434f8f7d79dcec8540b99f1..f2426344410cdd9ab99b7066cad46186ac6934ad 100644 (file)
@@ -1,3 +1,11 @@
+2019-03-17  Thomas Koenig  <tkoenig@gcc.gnu.org>
+
+       PR fortran/84394
+       Backport from trunk
+       * symbol.c (gfc_add_subroutine): If we are encountering a
+       subrtoutine within a BLOCK DATA and the name starts with an
+       underscore, do not check.
+
 2019-03-16  Thomas Koenig  <tkoenig@gcc.gnu.org>
 
        PR fortran/66089
index f3ab8af5ad3e923cfe68d5d174d92b851c5acea4..d42f2ed5bee9dd6f5a5342d97ac52804b48e593b 100644 (file)
@@ -1595,7 +1595,15 @@ gfc_add_subroutine (symbol_attribute *attr, const char *name, locus *where)
     return false;
 
   attr->subroutine = 1;
-  return check_conflict (attr, name, where);
+
+  /* If we are looking at a BLOCK DATA statement and we encounter a
+     name with a leading underscore (which must be
+     compiler-generated), do not check. See PR 84394.  */
+
+  if (name && *name != '_' && gfc_current_state () != COMP_BLOCK_DATA)
+    return check_conflict (attr, name, where);
+  else
+    return true;
 }
 
 
index 85a261b6d719634dd7e57f23b1ece48dc1329512..53aaf96cc17c744580bc079cc76b3899aeed4e01 100644 (file)
@@ -1,3 +1,9 @@
+2019-03-17  Thomas Koenig  <tkoenig@gcc.gnu.org>
+
+       PR fortran/84394
+       Backport from trunk
+       * gfortran.dg/blockdata_11.f90: New test.
+
 2019-03-17  H.J. Lu  <hongjiu.lu@intel.com>
 
        Backport from mainline
diff --git a/gcc/testsuite/gfortran.dg/blockdata_11.f90 b/gcc/testsuite/gfortran.dg/blockdata_11.f90
new file mode 100644 (file)
index 0000000..4aee18b
--- /dev/null
@@ -0,0 +1,33 @@
+! { dg-do run }
+! PR 84394 - this used to complain about private procedures in
+! BLOCK data.
+module mod1
+   implicit none
+   type :: type1
+      integer :: i1
+   end type type1
+end module
+
+module mod2
+   implicit none
+   contains
+      subroutine sub1
+         integer vals
+         common /block1/ vals(5)
+         if (any(vals /= [1, 2, 3, 4, 5])) stop 1
+      end subroutine
+end module
+
+block data blkdat
+  use mod1
+  integer vals
+  common /block1/ vals(5)
+  data vals/1, 2, 3, 4, 5/
+end block data blkdat
+
+program main
+  use mod2, only: sub1
+  implicit none
+  call sub1
+end program
+