diff options
author | Steven G. Kargl <kargl@gcc.gnu.org> | 2015-10-02 00:53:00 +0000 |
---|---|---|
committer | Steven G. Kargl <kargl@gcc.gnu.org> | 2015-10-02 00:53:00 +0000 |
commit | d30ecc9c2bc9fc8373433302c9e351d545eed061 (patch) | |
tree | 8c640f85bd6e070ddea91ee5fcaa3000942fb513 /gcc/fortran/decl.c | |
parent | 220ab6b433ee3a360c52032445676758991ed7d9 (diff) | |
download | gcc-d30ecc9c2bc9fc8373433302c9e351d545eed061.zip gcc-d30ecc9c2bc9fc8373433302c9e351d545eed061.tar.gz gcc-d30ecc9c2bc9fc8373433302c9e351d545eed061.tar.bz2 |
PR fortran.67802
2015-10-01 Steven G. Kargl <kargl@gcc.gnu.org>
PR fortran.67802
* decl.c (add_init_expr_to_sym): Numeric constant for character
length must be an INTEGER.
2015-10-01 Steven G. Kargl <kargl@gcc.gnu.org>
PR fortran.67802
* gfortran.dg/pr67802.f90: New test.
From-SVN: r228365
Diffstat (limited to 'gcc/fortran/decl.c')
-rw-r--r-- | gcc/fortran/decl.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c index 39c1136..39e0805 100644 --- a/gcc/fortran/decl.c +++ b/gcc/fortran/decl.c @@ -1439,7 +1439,12 @@ add_init_expr_to_sym (const char *name, gfc_expr **initp, locus *var_locus) /* Update initializer character length according symbol. */ else if (sym->ts.u.cl->length->expr_type == EXPR_CONSTANT) { - int len = mpz_get_si (sym->ts.u.cl->length->value.integer); + int len; + + if (!gfc_specification_expr (sym->ts.u.cl->length)) + return false; + + len = mpz_get_si (sym->ts.u.cl->length->value.integer); if (init->expr_type == EXPR_CONSTANT) gfc_set_constant_character_len (len, init, -1); |