aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/resolve.c
diff options
context:
space:
mode:
authorLinus Koenig <link@sig-st.de>2020-04-13 16:30:44 +0200
committerThomas König <tkoenig@gcc.gnu.org>2020-04-13 16:32:38 +0200
commitefbf7392079222ef00db2d39998faf5513055181 (patch)
tree0a4017806092556e4a00f0199d04f98abd8883da /gcc/fortran/resolve.c
parent8d213cbbe1856e6088282aa0076646cec694b030 (diff)
downloadgcc-efbf7392079222ef00db2d39998faf5513055181.zip
gcc-efbf7392079222ef00db2d39998faf5513055181.tar.gz
gcc-efbf7392079222ef00db2d39998faf5513055181.tar.bz2
ICE on wrong code [PR94192].
The idea is not have another resolution of a pointer if an error has occurred previously. 2020-04-13 Linus Koenig <link@sig-st.de> PR fortran/94192 * resolve.c (resolve_fl_var_and_proc): Set flag "error" to 1 if pointer is found to not have an assumed rank or a deferred shape. * simplify.c (simplify_bound): If an error has been issued for a given pointer, one should not attempt to find its bounds. 2020-04-13 Linus Koenig <link@sig-st.de> PR fortran/94192 * gfortran.dg/bound_resolve_after_error_1.f90: New test.
Diffstat (limited to 'gcc/fortran/resolve.c')
-rw-r--r--gcc/fortran/resolve.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c
index ccd2a5e..9b95200 100644
--- a/gcc/fortran/resolve.c
+++ b/gcc/fortran/resolve.c
@@ -12622,6 +12622,7 @@ resolve_fl_var_and_proc (gfc_symbol *sym, int mp_flag)
{
gfc_error ("Array pointer %qs at %L must have a deferred shape or "
"assumed rank", sym->name, &sym->declared_at);
+ sym->error = 1;
return false;
}
}