aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJerry DeLisle <jvdelisle@gcc.gnu.org>2019-06-22 19:58:47 +0000
committerJerry DeLisle <jvdelisle@gcc.gnu.org>2019-06-22 19:58:47 +0000
commitb1be0054be0149ad735e662912e01ebd258cea49 (patch)
treece4faece62008dcdeb8ded3738ea6ae5fa589eb3 /gcc
parentd9fe6cc4251d68866779f3e8d86af1a050fa2ae5 (diff)
downloadgcc-b1be0054be0149ad735e662912e01ebd258cea49.zip
gcc-b1be0054be0149ad735e662912e01ebd258cea49.tar.gz
gcc-b1be0054be0149ad735e662912e01ebd258cea49.tar.bz2
re PR fortran/89782 (Can do an internal READ of a character array when it is a parameter, but not a scalar character parameter)
2019-06-22 Jerry DeLisle <jvdelisle@gcc.gnu.org> PR fortran/89782 * io.c (gfc_resolve_dt): Check that internal units are not character PARAMETER. * gfortran.dg/io_constraints.f90: New test. From-SVN: r272594
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/io.c8
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.dg/io_constraints_14.f9013
4 files changed, 32 insertions, 0 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 4289227..6489a04 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,9 @@
+2019-06-22 Jerry DeLisle <jvdelisle@gcc.gnu.org>
+
+ PR fortran/89782
+ * io.c (gfc_resolve_dt): Check that internal units are not
+ character PARAMETER.
+
2019-06-21 Steven G. Kargl <kargl@gcc.gnu.org>
PR fortran/67884
diff --git a/gcc/fortran/io.c b/gcc/fortran/io.c
index 425c2b8..cd21c6b 100644
--- a/gcc/fortran/io.c
+++ b/gcc/fortran/io.c
@@ -3328,6 +3328,14 @@ gfc_resolve_dt (gfc_dt *dt, locus *loc)
return false;
}
+ if (e->symtree && e->symtree->n.sym->attr.flavor == FL_PARAMETER
+ && e->ts.type == BT_CHARACTER)
+ {
+ gfc_error ("UNIT specification at %L must "
+ "not be a character PARAMETER", &e->where);
+ return false;
+ }
+
if (gfc_resolve_expr (e)
&& (e->ts.type != BT_INTEGER
&& (e->ts.type != BT_CHARACTER || e->expr_type != EXPR_VARIABLE)))
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index e4f4cf8..edd7064 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2019-06-22 Jerry DeLisle <jvdelisle@gcc.gnu.org>
+
+ PR fortran/89782
+ * gfortran.dg/io_constraints.f90: New test.
+
2019-06-22 Iain Sandoe <iain@sandoe.co.uk>
* gcc.target/powerpc/pr64205.c: Require effective target dfp.
diff --git a/gcc/testsuite/gfortran.dg/io_constraints_14.f90 b/gcc/testsuite/gfortran.dg/io_constraints_14.f90
new file mode 100644
index 0000000..e5b62b1
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/io_constraints_14.f90
@@ -0,0 +1,13 @@
+! { dg-do compile }
+program pr89782
+ character(len=*),parameter :: VALUES(*)=[character(len=10) :: 'NaN','NAN','nan','Inf','INF','inf','Infinity']
+ character(len=*),parameter :: VALUE='NaN'
+ real(4) :: var
+ do i=1,size(VALUES)
+ read(VALUES(i),*) float ! { dg-error "character PARAMETER" }
+ write(VALUES(i),*)float ! { dg-error "character PARAMETER" }
+ enddo
+ read(var,*)float ! { dg-error "INTEGER expression or a CHARACTER" }
+ read(VALUE,*)float ! { dg-error "character PARAMETER" }
+ write(VALUE,*)float ! { dg-error "character PARAMETER" }
+end program pr89782