aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/resolve.c
diff options
context:
space:
mode:
authorJanne Blomqvist <jb@gcc.gnu.org>2018-02-01 21:47:15 +0200
committerJanne Blomqvist <jb@gcc.gnu.org>2018-02-01 21:47:15 +0200
commitae976c332dca908d826a71cdc81d28af71552939 (patch)
treedc33b16aeeea0a1c2662e6a74f0bbacf7a44ac71 /gcc/fortran/resolve.c
parentbfa28724748054a50075ce6f39b18c5ce111c73c (diff)
downloadgcc-ae976c332dca908d826a71cdc81d28af71552939.zip
gcc-ae976c332dca908d826a71cdc81d28af71552939.tar.gz
gcc-ae976c332dca908d826a71cdc81d28af71552939.tar.bz2
PR 83975 Associate target with non-constant character length
When associating a variable of type character, if the length of the target isn't known at compile time, generate an error. See PR 83344 for more details. Regtested on x86_64-pc-linux-gnu. gcc/fortran/ChangeLog: 2018-02-01 Janne Blomqvist <jb@gcc.gnu.org> PR 83975 PR 83344 * resolve.c (resolve_assoc_var): Generate an error if target length unknown. From-SVN: r257310
Diffstat (limited to 'gcc/fortran/resolve.c')
-rw-r--r--gcc/fortran/resolve.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c
index 9c8ba86..60b9bc3 100644
--- a/gcc/fortran/resolve.c
+++ b/gcc/fortran/resolve.c
@@ -8634,11 +8634,16 @@ resolve_assoc_var (gfc_symbol* sym, bool resolve_target)
if (!sym->ts.u.cl)
sym->ts.u.cl = target->ts.u.cl;
- if (!sym->ts.u.cl->length && !sym->ts.deferred
- && target->expr_type == EXPR_CONSTANT)
- sym->ts.u.cl->length
- = gfc_get_int_expr (gfc_charlen_int_kind,
- NULL, target->value.character.length);
+ if (!sym->ts.u.cl->length && !sym->ts.deferred)
+ {
+ if (target->expr_type == EXPR_CONSTANT)
+ sym->ts.u.cl->length =
+ gfc_get_int_expr (gfc_charlen_int_kind, NULL,
+ target->value.character.length);
+ else
+ gfc_error ("Not Implemented: Associate target with type character"
+ " and non-constant length at %L", &target->where);
+ }
}
/* If the target is a good class object, so is the associate variable. */