Commit 5abde510 by Thomas Koenig

re PR fortran/49232 (Pointer assignment of stride to CONTIGUOUS pointer not diagnosed as invalid)

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>

	PR fortran/49232
	* gfortran.dg/contiguous_4.f90: New test.

From-SVN: r253509
parent a4792d44
2017-10-07 Thomas Koenig <tkoenig@gcc.gnu.org> 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. * gfortran.h (async_io_dt): Add external reference.
* io.c (async_io_dt): Add variable. * io.c (async_io_dt): Add variable.
(compare_to_allowed_values): Add prototyte. Add optional argument (compare_to_allowed_values): Add prototyte. Add optional argument
......
...@@ -3851,6 +3851,14 @@ gfc_check_pointer_assign (gfc_expr *lvalue, gfc_expr *rvalue) ...@@ -3851,6 +3851,14 @@ gfc_check_pointer_assign (gfc_expr *lvalue, gfc_expr *rvalue)
} }
} }
/* 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. */ /* Warn if it is the LHS pointer may lives longer than the RHS target. */
if (warn_target_lifetime if (warn_target_lifetime
&& rvalue->expr_type == EXPR_VARIABLE && 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> 2017-10-06 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/66690 PR c++/66690
......
! { 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
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment