MAPL_TextColumnVector Module

$ public :: foreach

$ ! ======================= $ ! insert $ ! ======================= $ subroutine vector_insert_size_kind( & $ & this, index, value, unused, rc) $ class(TextColumnVector), target, intent(inout) :: this $ $ integer(kind=GFTL_SIZE_KIND), intent(in) :: index $ $ class(TextColumn), intent(in) :: value $ type (KeywordEnforcer), optional, intent(in) :: unused $ integer, optional, intent(out) :: rc $ $ class(TextColumn), allocatable :: temp $ integer(kind=GFTL_SIZE_KIND) :: i, n $ $ if (.false.) print*,shape(unused) $ $ n = this%vsize $ if (index==n+1) then $ call this%push_back(value) $ ! Workaround for NAG -6221 - temp needs some status $ allocate(temp, source=value) $ return $ endif $ call this%grow_to(this%vsize+1) $ allocate(temp, source=this%elements(n)%item) $ call this%resize(n+1, temp, rc=rc) $ $ do i = n, index, -1 $ call move_alloc(from=this%elements(index-1)%item,to=this%elements(index)%item) $ end do $ $ allocate(this%elements(index)%item, source=value) $ $ return $ end subroutine vector_insert_size_kind $ $ $ subroutine vector_insert_default(this, index, value) $ class(TextColumnVector), intent(inout) :: this $ integer, intent(in) :: index $ class(TextColumn), intent(in) :: value $ $ call this%insert(int(index,kind=GFTL_SIZE_KIND), value) $ end subroutine vector_insert_default


Uses

  • module~~mapl_textcolumnvector~~UsesGraph module~mapl_textcolumnvector MAPL_TextColumnVector module~mapl_textcolumn MAPL_TextColumn module~mapl_textcolumnvector->module~mapl_textcolumn module~mapl_abstractmeternode MAPL_AbstractMeterNode module~mapl_textcolumn->module~mapl_abstractmeternode module~mapl_abstractmeter MAPL_AbstractMeter module~mapl_abstractmeternode->module~mapl_abstractmeter iso_fortran_env iso_fortran_env module~mapl_abstractmeter->iso_fortran_env module~mapl_errorhandlingmod mapl_ErrorHandlingMod module~mapl_abstractmeter->module~mapl_errorhandlingmod

Used by

  • module~~mapl_textcolumnvector~~UsedByGraph module~mapl_textcolumnvector MAPL_TextColumnVector module~mapl_multicolumn MAPL_MultiColumn module~mapl_multicolumn->module~mapl_textcolumnvector module~mapl_profiler mapl_Profiler module~mapl_profiler->module~mapl_textcolumnvector module~mapl_profiler->module~mapl_multicolumn module~mapl_profilereporter MAPL_ProfileReporter module~mapl_profiler->module~mapl_profilereporter module~mapl_profilereporter->module~mapl_textcolumnvector module~mapl_profilereporter->module~mapl_multicolumn module~base_implementation Base_Implementation module~base_implementation->module~mapl_profiler module~bundletestsupport BundleTestSupport module~bundletestsupport->module~mapl_profiler module~extdata_drivergridcompmod ExtData_DriverGridCompMod module~extdata_drivergridcompmod->module~mapl_profiler module~mapl MAPL module~mapl->module~mapl_profiler module~mapl3g_maplframework mapl3g_MaplFramework module~mapl3g_maplframework->module~mapl_profiler module~mapl_applicationsupport MAPL_ApplicationSupport module~mapl_applicationsupport->module~mapl_profiler module~mapl_capgridcompmod MAPL_CapGridCompMod module~mapl_capgridcompmod->module~mapl_profiler module~mapl_genericmod MAPL_GenericMod module~mapl_genericmod->module~mapl_profiler module~mapl_nuopcwrappermod MAPL_NUOPCWrapperMod module~mapl_nuopcwrappermod->module~mapl_profiler module~mapl_verticaldatamod MAPL_VerticalDataMod module~mapl_verticaldatamod->module~mapl_profiler module~pfio_abstractservermod pFIO_AbstractServerMod module~pfio_abstractservermod->module~mapl_profiler module~pfio_mpiservermod pFIO_MpiServerMod module~pfio_mpiservermod->module~mapl_profiler module~pfio_multigroupservermod pFIO_MultiGroupServerMod module~pfio_multigroupservermod->module~mapl_profiler module~pfio_serverthreadmod pFIO_ServerThreadMod module~pfio_serverthreadmod->module~mapl_profiler module~test_advancedmeter test_AdvancedMeter module~test_advancedmeter->module~mapl_profiler module~test_column test_Column module~test_column->module~mapl_profiler module~test_distributedmeter test_DistributedMeter module~test_distributedmeter->module~mapl_profiler module~test_exclusivecolumn test_ExclusiveColumn module~test_exclusivecolumn->module~mapl_profiler module~test_meternode test_MeterNode module~test_meternode->module~mapl_profiler module~test_meternodeiterator test_MeterNodeIterator module~test_meternodeiterator->module~mapl_profiler module~test_namecolumn test_NameColumn module~test_namecolumn->module~mapl_profiler module~test_percentagecolumn test_PercentageColumn module~test_percentagecolumn->module~mapl_profiler module~test_profilereporter test_ProfileReporter module~test_profilereporter->module~mapl_profiler module~test_timeprofiler test_TimeProfiler module~test_timeprofiler->module~mapl_profiler program~main~4 main program~main~4->module~mapl_profiler program~main~9 main program~main~9->module~mapl_profiler program~regrid_util Regrid_Util program~regrid_util->module~mapl_profiler

Variables

Type Visibility Attributes Name Initial
integer, public, parameter :: BAD_ALLOC = 2
integer, public, parameter :: GFTL_SIZE_KIND = selected_int_kind(18)
integer, public, parameter :: ILLEGAL_INPUT = 3
integer, public, parameter :: LENGTH_ERROR = 4
integer, public, parameter :: OUT_OF_RANGE = 1
integer, public, parameter :: SUCCESS = 0
integer, public, parameter :: TYPE_HAS_NO_DEFAULT_VALUE = 5
type(NO_TYPE_), public, parameter :: NO_TYPE__ = NO_TYPE_()

Interfaces

public interface TextColumnVector

  • private function vector_new_vector_empty() result(v)

    Arguments

    None

    Return Value type(TextColumnVector)

  • private function vector_new_vector_fill_size_kind(n, value) result(v)

    Arguments

    Type IntentOptional Attributes Name
    integer(kind=GFTL_SIZE_KIND), intent(in) :: n
    class(TextColumn), intent(in), optional :: value

    Return Value type(TextColumnVector)

  • private function vector_new_vector_fill_default(n, value) result(v)

    Arguments

    Type IntentOptional Attributes Name
    integer, intent(in) :: n
    class(TextColumn), intent(in), optional :: value

    Return Value type(TextColumnVector)

  • private function vector_new_vector_range(first, last) result(v)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVectorIterator), intent(in) :: first
    type(TextColumnVectorIterator), intent(in) :: last

    Return Value type(TextColumnVector)

  • private function vector_new_vector_copy(x) result(v)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVector) :: x

    Return Value type(TextColumnVector)

public interface advance

  • private subroutine vector_iter_advance_size_kind(it, n)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVectorIterator), intent(inout) :: it
    integer(kind=selected_int_kind(18)), intent(in) :: n
  • private subroutine vector_iter_advance_default(it, n)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVectorIterator), intent(inout) :: it
    integer, intent(in) :: n

public interface begin

public interface distance

  • private function vector_iter_distance(a, b) result(distance)

    Arguments

    Type IntentOptional Attributes Name
    class(TextColumnVectorIterator), intent(in) :: a
    type(TextColumnVectorIterator), intent(in) :: b

    Return Value integer(kind=selected_int_kind(18))

public interface end

public interface find

  • private function vector_find_basic(do_not_use, unused) result(j)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVectorIterator), intent(in) :: do_not_use
    type(KeywordEnforcer), intent(in) :: unused

    Return Value type(vector_keywordenforcer)

public interface find_if

public interface find_if_not

public interface ftn_begin

  • private function vector_iter_ftn_begin(cont) result(begin)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVector), intent(in), target :: cont

    Return Value type(TextColumnVectorIterator)

public interface ftn_end

public interface next

public interface operator(+)

  • private function vector_iter_a_plus_n_size_kind(a, n) result(new_iter)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVectorIterator), intent(in) :: a
    integer(kind=selected_int_kind(18)), intent(in) :: n

    Return Value type(TextColumnVectorIterator)

  • private function vector_iter_n_plus_a_size_kind(n, a) result(new_iter)

    Arguments

    Type IntentOptional Attributes Name
    integer(kind=selected_int_kind(18)), intent(in) :: n
    type(TextColumnVectorIterator), intent(in) :: a

    Return Value type(TextColumnVectorIterator)

  • private function vector_iter_n_plus_a_default(n, a) result(new_iter)

    Arguments

    Type IntentOptional Attributes Name
    integer, intent(in) :: n
    type(TextColumnVectorIterator), intent(in) :: a

    Return Value type(TextColumnVectorIterator)

  • private function vector_iter_a_plus_n_default(a, n) result(new_iter)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVectorIterator), intent(in) :: a
    integer, intent(in) :: n

    Return Value type(TextColumnVectorIterator)

public interface operator(-)

  • private function vector_iter_a_minus_n_size_kind(a, n) result(new_iter)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVectorIterator), intent(in) :: a
    integer(kind=selected_int_kind(18)), intent(in) :: n

    Return Value type(TextColumnVectorIterator)

  • private function vector_iter_a_minus_n_default(a, n) result(new_iter)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVectorIterator), intent(in) :: a
    integer, intent(in) :: n

    Return Value type(TextColumnVectorIterator)

  • private function vector_iter_a_minus_b(a, b) result(n)

    Arguments

    Type IntentOptional Attributes Name
    type(TextColumnVectorIterator), intent(in) :: a
    type(TextColumnVectorIterator), intent(in) :: b

    Return Value integer(kind=selected_int_kind(18))

public interface operator(/=)

public interface operator(==)

public interface prev

public interface swap

  • private subroutine vector_swap(this, x)

    Arguments

    Type IntentOptional Attributes Name
    class(TextColumnVector), intent(inout), target :: this
    type(TextColumnVector), intent(inout), target :: x

Derived Types

type, public ::  KeywordEnforcer

type, public ::  NO_TYPE_

type, public ::  TextColumnVector

Constructor

private function vector_new_vector_empty ()
private function vector_new_vector_fill_size_kind (n, value)
private function vector_new_vector_fill_default (n, value)
private function vector_new_vector_range (first, last)
private function vector_new_vector_copy (x)

Type-Bound Procedures

generic, public :: at => at_default
generic, public :: at => of_default
generic, public :: at => at_size_kind
generic, public :: at => of_size_kind
procedure, public :: at_default => vector_at_default
procedure, public :: at_size_kind => vector_at_size_kind
procedure, public :: back => vector_back
procedure, public :: begin => vector_begin
procedure, public :: capacity => vector_capacity
procedure, public :: clear => vector_clear
procedure, public :: empty => vector_empty
procedure, public :: end => vector_end
generic, public :: erase => erase_one
generic, public :: erase => erase_range
procedure, public :: erase_one => vector_erase_one
procedure, public :: erase_range => vector_erase_range
procedure, public :: front => vector_front
procedure, public :: ftn_begin => vector_ftn_begin
procedure, public :: ftn_end => vector_ftn_end
generic, public :: insert => vector_insert_one
generic, public :: insert => vector_insert_count_size_kind
generic, public :: insert => vector_insert_count_default
generic, public :: insert => vector_insert_range
procedure, public, nopass :: max_size => vector_max_size
generic, public :: of => of_default
generic, public :: of => of_size_kind
procedure, public :: of_default => vector_of_default
procedure, public :: of_size_kind => vector_of_size_kind
procedure, public :: pop_back => vector_pop_back
procedure, public :: push_back => vector_push_back
procedure, public :: rbegin => vector_rbegin
procedure, public :: rend => vector_rend
generic, public :: reserve => reserve_default
generic, public :: reserve => reserve_size_kind
procedure, public :: reserve_default => vector_reserve_default
procedure, public :: reserve_size_kind => vector_reserve_size_kind
procedure, public :: reset => vector_reset
generic, public :: resize => resize_default
generic, public :: resize => resize_size_kind
procedure, public :: resize_default => vector_resize_default
procedure, public :: resize_size_kind => vector_resize_size_kind
generic, public :: set => set_default
generic, public :: set => set_size_kind
procedure, public :: set_default => vector_set_default
procedure, public :: set_size_kind => vector_set_size_kind
procedure, public :: shrink_to_fit => vector_shrink_to_fit
procedure, public :: size => vector_size
procedure, public :: swap => vector_swap
procedure, public :: vector_insert_count_default
procedure, public :: vector_insert_count_size_kind
procedure, public :: vector_insert_one
procedure, public :: vector_insert_range
generic, public :: write(formatted) => write_formatted
procedure, public :: write_formatted => vector_write_formatted

type, public ::  TextColumnVectorIterator

Type-Bound Procedures

generic, public :: add => vector_iter_add_n_default
generic, public :: add => vector_iter_add_n_size_kind
procedure, public :: next => vector_iter_next
generic, public :: of => vector_iter_of
generic, public :: of => vector_iter_of_offset_default
generic, public :: of => vector_iter_of_offset_size_kind
procedure, public :: prev => vector_iter_prev

$ procedure :: back_inserter => vector_back_inserter $ procedure :: front_inserter => vector_front_inserter $ procedure :: inserter => vector_inserter $ procedure :: make_move_iterator => vector_make_move_iterator

Read more…
generic, public :: sub => vector_iter_sub_n_default
generic, public :: sub => vector_iter_sub_n_size_kind
procedure, public :: vector_iter_add_n_default
procedure, public :: vector_iter_add_n_size_kind
procedure, public :: vector_iter_of
procedure, public :: vector_iter_of_offset_default
procedure, public :: vector_iter_of_offset_size_kind
procedure, public :: vector_iter_sub_n_default
procedure, public :: vector_iter_sub_n_size_kind

type, public ::  VectorRIterator

$ procedure :: back_inserter => vector_back_inserter $ procedure :: front_inserter => vector_front_inserter $ procedure :: inserter => vector_inserter $ procedure :: make_move_iterator => vector_make_move_iterator

Type-Bound Procedures

generic, public :: add => vector_riter_add_n_default
generic, public :: add => vector_riter_add_n_size_kind
procedure, public :: next => vector_riter_next
generic, public :: of => vector_riter_of
generic, public :: of => vector_riter_of_offset_size_kind
generic, public :: of => vector_riter_of_offset_default
procedure, public :: prev => vector_riter_prev
generic, public :: sub => vector_riter_sub_n_default
generic, public :: sub => vector_riter_sub_n_size_kind
procedure, public :: vector_riter_add_n_default
procedure, public :: vector_riter_add_n_size_kind
procedure, public :: vector_riter_of
procedure, public :: vector_riter_of_offset_default
procedure, public :: vector_riter_of_offset_size_kind
procedure, public :: vector_riter_sub_n_default
procedure, public :: vector_riter_sub_n_size_kind