summaryrefslogtreecommitdiff
path: root/gcc/fortran/expr.c
diff options
context:
space:
mode:
authorkargl <kargl@138bc75d-0d04-0410-961f-82ee72b054a4>2016-11-24 18:27:58 +0000
committerkargl <kargl@138bc75d-0d04-0410-961f-82ee72b054a4>2016-11-24 18:27:58 +0000
commit10066eabb34f4036b4ae0e1c9e88ac5245c6921e (patch)
tree22bb3c1416369168cbf9ac5707841d5e6e9e4475 /gcc/fortran/expr.c
parent973c7ac918df80992fe4e9e8f5e168db48b2688f (diff)
2016-11-24 Steven G. Kargl <kargl@gcc.gnu.org>
PR fortran/78500 * expr.c (gfc_check_vardef_contextm): Fix NULL pointer dereference. * interface.c (matching_typebound_op): Ditto. 2016-11-24 Steven G. Kargl <kargl@gcc.gnu.org> PR fortran/78500 * gfortran.dg/class_result_4.f90: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@242846 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/fortran/expr.c')
-rw-r--r--gcc/fortran/expr.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/gcc/fortran/expr.c b/gcc/fortran/expr.c
index b028d81ba6d0..60f6080877f4 100644
--- a/gcc/fortran/expr.c
+++ b/gcc/fortran/expr.c
@@ -5291,7 +5291,8 @@ gfc_check_vardef_context (gfc_expr* e, bool pointer, bool alloc_obj,
component. Note that (normal) assignment to procedure pointers is not
possible. */
check_intentin = !own_scope;
- ptr_component = (sym->ts.type == BT_CLASS && CLASS_DATA (sym))
+ ptr_component = (sym->ts.type == BT_CLASS && sym->ts.u.derived
+ && CLASS_DATA (sym))
? CLASS_DATA (sym)->attr.class_pointer : sym->attr.pointer;
for (ref = e->ref; ref && check_intentin; ref = ref->next)
{