diff options
author | Paul Thomas <pault@gcc.gnu.org> | 2021-01-25 10:27:51 +0000 |
---|---|---|
committer | Paul Thomas <pault@gcc.gnu.org> | 2021-01-25 10:27:51 +0000 |
commit | c6b0e33febbf73abfcc2bb0e28f0b62afe3b0f2a (patch) | |
tree | 938d3c78385f2c7ad4d7deb04a28cbb03855e18c /gcc | |
parent | 28229916e1b131ad5d17a73603f65229e0a92f58 (diff) | |
download | gcc-c6b0e33febbf73abfcc2bb0e28f0b62afe3b0f2a.zip gcc-c6b0e33febbf73abfcc2bb0e28f0b62afe3b0f2a.tar.gz gcc-c6b0e33febbf73abfcc2bb0e28f0b62afe3b0f2a.tar.bz2 |
Fortran: Fix deferred character lengths in array constructors [PR98517].
2021-01-25 Steve Kargl <kargl@gcc.gnu.org>
gcc/fortran
PR fortran/98517
* resolve.c (resolve_charlen): Check that length expression is
present before testing for scalar/integer..
gcc/testsuite/
PR fortran/98517
* gfortran.dg/charlen_18.f90 : New test.
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/fortran/resolve.c | 3 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/charlen_18.f90 | 18 |
2 files changed, 20 insertions, 1 deletions
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c index c075d0f..11b5dbc 100644 --- a/gcc/fortran/resolve.c +++ b/gcc/fortran/resolve.c @@ -12446,7 +12446,8 @@ resolve_charlen (gfc_charlen *cl) } /* cl->length has been resolved. It should have an integer type. */ - if (cl->length->ts.type != BT_INTEGER || cl->length->rank != 0) + if (cl->length + && (cl->length->ts.type != BT_INTEGER || cl->length->rank != 0)) { gfc_error ("Scalar INTEGER expression expected at %L", &cl->length->where); diff --git a/gcc/testsuite/gfortran.dg/charlen_18.f90 b/gcc/testsuite/gfortran.dg/charlen_18.f90 new file mode 100644 index 0000000..5ad2874 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/charlen_18.f90 @@ -0,0 +1,18 @@ +! { dg-do compile } +! { dg-options "-fdec-structure" } +! +! Check fix for PR98517 +! +! Contributed by Eric Reischer <emr-gnu@hev.psu.edu> +! + SUBROUTINE TEST_BUG + IMPLICIT NONE + + CHARACTER*(*) DEF_VAL + PARAMETER (DEF_VAL = 'ABCDEFGH') + + STRUCTURE /SOME_STRUCT/ + CHARACTER*64 SOME_VAR /DEF_VAL/ + END STRUCTURE + + END |