+2013-01-15 Paul Thomas <pault@gcc.gnu.org>
+
+ PR fortran/54286
+ * expr.c (gfc_check_pointer_assign): Check for presence of
+ 's2' before using it.
+
2013-01-14 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/55806
name = s2->name;
}
- if (s2->attr.proc_pointer && s2->ts.interface)
+ if (s2 && s2->attr.proc_pointer && s2->ts.interface)
s2 = s2->ts.interface;
if (s1 == s2 || !s1 || !s2)
+2013-01-15 Paul Thomas <pault@gcc.gnu.org>
+
+ PR fortran/54286
+ * gfortran.dg/proc_ptr_result_8.f90 : Add module 'm' to check
+ case where interface is null.
+
2013-01-14 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/55806
! Test fix for PR54286.
!
! Contributed by Janus Weil <janus@gcc.gnu.org>
+! Module 'm' added later because original fix missed possibility of
+! null interfaces - thanks to Dominique Dhumieres <dominiq@lps.ens.fr>
!
+module m
+ type :: foobar
+ real, pointer :: array(:)
+ procedure (), pointer, nopass :: f
+ end type
+contains
+ elemental subroutine fooAssgn (a1, a2)
+ type(foobar), intent(out) :: a1
+ type(foobar), intent(in) :: a2
+ allocate (a1%array(size(a2%array)))
+ a1%array = a2%array
+ a1%f => a2%f
+ end subroutine
+end module m
+
implicit integer (a)
type :: t
procedure(a), pointer, nopass :: p