summaryrefslogtreecommitdiff
path: root/gcc/fortran/parse.c
diff options
context:
space:
mode:
authorburnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4>2016-09-20 21:49:12 +0000
committerburnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4>2016-09-20 21:49:12 +0000
commitc9c81ef3c667aaa14c498a5449ec6d134b4b66ff (patch)
tree0ac440db6513ee01deb5e5dc6142769d1e5b7b2d /gcc/fortran/parse.c
parent12cdcb9d74f55c165366ca1b1eeec013a0ce72ef (diff)
parent891196d7325e4c55d92d5ac5cfe7161c4f36c0ce (diff)
downloadgcc-fortran-dev.tar.gz
Merge from trunk (r239915 to r240230)fortran-dev
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/fortran-dev@240290 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/fortran/parse.c')
-rw-r--r--gcc/fortran/parse.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/gcc/fortran/parse.c b/gcc/fortran/parse.c
index 86f2c427368..d78a2c07eec 100644
--- a/gcc/fortran/parse.c
+++ b/gcc/fortran/parse.c
@@ -2399,6 +2399,29 @@ accept_statement (gfc_statement st)
}
+/* Clear default character types with charlen pointers that are about
+ to become invalid. */
+
+static void
+clear_default_charlen (gfc_namespace *ns, const gfc_charlen *cl,
+ const gfc_charlen *end)
+{
+ gfc_typespec *ts;
+
+ for (ts = &ns->default_type[0]; ts < &ns->default_type[GFC_LETTERS]; ts++)
+ if (ts->type == BT_CHARACTER)
+ {
+ const gfc_charlen *cl2;
+ for (cl2 = cl; cl2 != end; cl2 = cl2->next)
+ if (ts->u.cl == cl2)
+ {
+ ts->u.cl = NULL;
+ ts->type = BT_UNKNOWN;
+ break;
+ }
+ }
+}
+
/* Undo anything tentative that has been built for the current
statement. */
@@ -2406,6 +2429,8 @@ static void
reject_statement (void)
{
/* Revert to the previous charlen chain. */
+ clear_default_charlen (gfc_current_ns,
+ gfc_current_ns->cl_list, gfc_current_ns->old_cl_list);
gfc_free_charlen (gfc_current_ns->cl_list, gfc_current_ns->old_cl_list);
gfc_current_ns->cl_list = gfc_current_ns->old_cl_list;