truncate_ga_varop Subroutine

public subroutine truncate_ga_varop(me)

Arguments

Type IntentOptional Attributes Name
type(grw_varoparray_type) :: me

Called by

proc~~truncate_ga_varop~~CalledByGraph proc~truncate_ga_varop truncate_ga_varop interface~truncate~20 truncate interface~truncate~20->proc~truncate_ga_varop

Contents

Source Code


Source Code

  subroutine truncate_ga_varop(me)
    !------------------------------------------------------------------------
    type(grw_varoparray_type) :: me !< array to truncate
    !------------------------------------------------------------------------
    type(tem_varsys_op_type), allocatable :: tarray(:)
    !------------------------------------------------------------------------
    integer :: ii
    !------------------------------------------------------------------------

    ! nothing to do if container size is not larger than the number of values
    ! in the array.
    if (me%containersize > me%nvals) then
      allocate(tarray(me%nvals))
      do ii = 1, me%nvals
        tarray(ii) = me%val(ii)
      end do
      call move_alloc(tarray, me%val)
      me%containersize = me%nvals
    end if

  end subroutine truncate_ga_varop