+2017-10-07 Thomas Koenig <tkoenig@gcc.gnu.org>
+
+ PR fortran/49232
+ * expr.c (gfc_check_pointer_assign): Error
+ for non-contiguous rhs.
+
2017-10-07 Thomas Koenig <tkoenig@gcc.gnu.org>
* gfortran.h (async_io_dt): Add external reference.
}
}
+ /* Error for assignments of contiguous pointers to targets which is not
+ contiguous. Be lenient in the definition of what counts as
+ congiguous. */
+
+ if (lhs_attr.contiguous && !gfc_is_simply_contiguous (rvalue, false, true))
+ gfc_error ("Assignment to contiguous pointer from non-contiguous "
+ "target at %L", &rvalue->where);
+
/* Warn if it is the LHS pointer may lives longer than the RHS target. */
if (warn_target_lifetime
&& rvalue->expr_type == EXPR_VARIABLE
+2017-10-07 Thomas Koenig <tkoenig@gcc.gnu.org>
+
+ PR fortran/49232
+ * gfortran.dg/contiguous_4.f90: New test.
+
2017-10-06 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/66690
--- /dev/null
+! { dg-do compile }
+program cont_01_neg
+ implicit none
+ real, pointer, contiguous :: r(:)
+ real, pointer, contiguous :: r2(:,:)
+ real, target :: x(45)
+ real, target :: x2(5,9)
+ integer :: i
+ integer :: n=1
+
+ x = (/ (real(i),i=1,45) /)
+ x2 = reshape(x,shape(x2))
+ r => x(::3) ! { dg-error "Assignment to contiguous pointer" }
+ r2 => x2(2:,:) ! { dg-error "Assignment to contiguous pointer" }
+ r2 => x2(:,2:3)
+ r => x2(2:3,1)
+ r => x(::1)
+ r => x(::n) ! { dg-error "Assignment to contiguous pointer" }
+end program