aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/check.c
diff options
context:
space:
mode:
authorJanus Weil <janus@gcc.gnu.org>2012-12-28 16:14:45 +0100
committerJanus Weil <janus@gcc.gnu.org>2012-12-28 16:14:45 +0100
commit5fabac29f7201639991f102e8354b3bb85ac2bc9 (patch)
tree3b53f87e7bddf9f3ed6effd0a4ad6511dd0ee276 /gcc/fortran/check.c
parentf968d60be0ef5ee2ebcf06f673f33d469602188c (diff)
downloadgcc-5fabac29f7201639991f102e8354b3bb85ac2bc9.zip
gcc-5fabac29f7201639991f102e8354b3bb85ac2bc9.tar.gz
gcc-5fabac29f7201639991f102e8354b3bb85ac2bc9.tar.bz2
re PR fortran/55692 (ICE on incorrect use of ASSOCIATED function)
2012-12-28 Janus Weil <janus@gcc.gnu.org> PR fortran/55692 * check.c (gfc_check_associated): Remove a "gcc_assert (0)". 2012-12-28 Janus Weil <janus@gcc.gnu.org> PR fortran/55692 * gfortran.dg/associated_7.f90: New. From-SVN: r194744
Diffstat (limited to 'gcc/fortran/check.c')
-rw-r--r--gcc/fortran/check.c8
1 files changed, 3 insertions, 5 deletions
diff --git a/gcc/fortran/check.c b/gcc/fortran/check.c
index 0923f12..4e8b046 100644
--- a/gcc/fortran/check.c
+++ b/gcc/fortran/check.c
@@ -895,12 +895,10 @@ gfc_check_associated (gfc_expr *pointer, gfc_expr *target)
where = &pointer->where;
- if (pointer->expr_type == EXPR_VARIABLE || pointer->expr_type == EXPR_FUNCTION)
- attr1 = gfc_expr_attr (pointer);
- else if (pointer->expr_type == EXPR_NULL)
+ if (pointer->expr_type == EXPR_NULL)
goto null_arg;
- else
- gcc_assert (0); /* Pointer must be a variable or a function. */
+
+ attr1 = gfc_expr_attr (pointer);
if (!attr1.pointer && !attr1.proc_pointer)
{