aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran
diff options
context:
space:
mode:
authorJanus Weil <janus@gcc.gnu.org>2010-06-09 16:14:08 +0200
committerJanus Weil <janus@gcc.gnu.org>2010-06-09 16:14:08 +0200
commitf1a0b754cf8762f602d0f6053579927e9df1dc2f (patch)
treec5f8e7de1381e23fc8ef82411496bad02709550b /gcc/fortran
parent6ef9e52dc64abfac9301b21136cecd951ff2a156 (diff)
downloadgcc-f1a0b754cf8762f602d0f6053579927e9df1dc2f.zip
gcc-f1a0b754cf8762f602d0f6053579927e9df1dc2f.tar.gz
gcc-f1a0b754cf8762f602d0f6053579927e9df1dc2f.tar.bz2
re PR fortran/44211 ([OOP] ICE with TBP of pointer component of derived type array)
2010-06-09 Janus Weil <janus@gcc.gnu.org> PR fortran/44211 * resolve.c (resolve_typebound_function,resolve_typebound_subroutine): Resolve references. 2010-06-09 Janus Weil <janus@gcc.gnu.org> PR fortran/44211 * gfortran.dg/typebound_call_14.f03: New test. From-SVN: r160478
Diffstat (limited to 'gcc/fortran')
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/resolve.c6
2 files changed, 12 insertions, 0 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index a19f9c6..e1faa4d 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,9 @@
+2010-06-09 Janus Weil <janus@gcc.gnu.org>
+
+ PR fortran/44211
+ * resolve.c (resolve_typebound_function,resolve_typebound_subroutine):
+ Resolve references.
+
2010-06-09 Kai Tietz <kai.tietz@onevision.com>
* resolve.c (resolve_deallocate_expr): Avoid warning
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c
index 2ee82af..8fabf4e 100644
--- a/gcc/fortran/resolve.c
+++ b/gcc/fortran/resolve.c
@@ -5415,6 +5415,9 @@ resolve_typebound_function (gfc_expr* e)
if (st == NULL)
return resolve_compcall (e, NULL);
+ if (resolve_ref (e) == FAILURE)
+ return FAILURE;
+
/* Get the CLASS declared type. */
declared = get_declared_from_expr (&class_ref, &new_ref, e);
@@ -5487,6 +5490,9 @@ resolve_typebound_subroutine (gfc_code *code)
if (st == NULL)
return resolve_typebound_call (code, NULL);
+ if (resolve_ref (code->expr1) == FAILURE)
+ return FAILURE;
+
/* Get the CLASS declared type. */
declared = get_declared_from_expr (&class_ref, &new_ref, code->expr1);