blob: 1f320522489cb04f01ce146108dc4b20e5edbae5 [file] [log] [blame]
! { dg-do run }
!
! PR fortran/53526
!
! Check handling of move_alloc with coarrays
!
implicit none
integer, allocatable :: u[:], v[:], w(:)[:,:], x(:)[:,:]
allocate (u[4:*])
call move_alloc (u, v)
if (allocated (u)) call abort ()
if (lcobound (v, dim=1) /= 4) call abort ()
if (ucobound (v, dim=1) /= 3 + num_images()) call abort ()
allocate (w(-2:3)[4:5,-1:*])
call move_alloc (w, x)
if (allocated (w)) call abort ()
if (lbound (x, dim=1) /= -2) call abort ()
if (ubound (x, dim=1) /= 3) call abort ()
if (any (lcobound (x) /= [4, -1])) call abort ()
if (any (ucobound (x) /= [5, -2 + (num_images()+1)/2])) call abort ()
end