diff options
author | Paul Thomas <pault@gcc.gnu.org> | 2005-05-31 17:19:11 +0000 |
---|---|---|
committer | Paul Thomas <pault@gcc.gnu.org> | 2005-05-31 17:19:11 +0000 |
commit | 2b052ce2f5a1c84ca9efded4df9308669b9e25e5 (patch) | |
tree | 9a856e4a4daa847c9ca97e91ae29830d2728f4b1 /gcc/fortran/trans-expr.c | |
parent | d763bb10051498ab4bafe220b644f2aa414de381 (diff) | |
download | gcc-2b052ce2f5a1c84ca9efded4df9308669b9e25e5.zip gcc-2b052ce2f5a1c84ca9efded4df9308669b9e25e5.tar.gz gcc-2b052ce2f5a1c84ca9efded4df9308669b9e25e5.tar.bz2 |
re PR fortran/18109 (ICE with explicit array of strings)
2005-05-30 Paul Thomas <pault@gcc.gnu.org>
PR fortran/18109
PR fortran/18283
PR fortran/19107
* fortran/trans-array.c (gfc_conv_expr_descriptor): Obtain the
string length from the expression typespec character length value
and set temp_ss->stringlength and backend_decl. Obtain the
tree expression from gfc_conv_expr rather than gfc_conv_expr_val.
Dereference the expression to obtain the character.
* fortran/trans-expr.c (gfc_conv_component_ref): Remove the
dereference of scalar character pointer structure components.
* fortran/trans-expr.c (gfc_trans_subarray_assign): Obtain the
string length for the structure component from the component
expression.
From-SVN: r100400
Diffstat (limited to 'gcc/fortran/trans-expr.c')
-rw-r--r-- | gcc/fortran/trans-expr.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/gcc/fortran/trans-expr.c b/gcc/fortran/trans-expr.c index cb6f167..3d7dc72 100644 --- a/gcc/fortran/trans-expr.c +++ b/gcc/fortran/trans-expr.c @@ -281,7 +281,7 @@ gfc_conv_component_ref (gfc_se * se, gfc_ref * ref) se->string_length = tmp; } - if (c->pointer && c->dimension == 0) + if (c->pointer && c->dimension == 0 && c->ts.type != BT_CHARACTER) se->expr = gfc_build_indirect_ref (se->expr); } @@ -1671,6 +1671,9 @@ gfc_trans_subarray_assign (tree dest, gfc_component * cm, gfc_expr * expr) gfc_start_scalarized_body (&loop, &body); gfc_conv_tmp_array_ref (&lse); + if (cm->ts.type == BT_CHARACTER) + lse.string_length = cm->ts.cl->backend_decl; + gfc_conv_expr (&rse, expr); tmp = gfc_trans_scalar_assign (&lse, &rse, cm->ts.type); |