append an array of values to the growing 2d array.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
type(grw_real2darray_type) | :: | me |
array to append the value to |
|||
real(kind=rk), | intent(in) | :: | val(:) |
array of values to append |
||
integer, | intent(in) | :: | pos2 |
position in second dimension (can grow) |
||
integer, | intent(in), | optional | :: | length |
optional length to expand the array |
subroutine placeat_arrayga2d_real(me, val, pos2, length)
! --------------------------------------------------------------------------
!> array to append the value to
type(grw_real2darray_type) :: me
!> array of values to append
real(kind=rk), intent(in) :: val(:)
!> position in second dimension (can grow)
integer, intent(in) :: pos2
!> optional length to expand the array
integer, intent(in), optional :: length
! --------------------------------------------------------------------------
integer :: expandlength
! --------------------------------------------------------------------------
if (me%nvals == huge(me%nvals)) then
write(*,*) "reached end of integer range for growing array!"
write(*,*) "aborting!!"
stop
end if
if (pos2 > me%containersize) then
expandlength = pos2 - me%containersize
if( present( length ) ) expandlength = max(expandlength, length)
! expand the array, if its boundary is reached
call expand( me = me, length = expandlength )
end if
me%nvals = max(pos2, me%nvals)
me%val( : , pos2 ) = val(:)
end subroutine placeat_arrayga2d_real