StringIntegerMap_serialize Subroutine

public subroutine StringIntegerMap_serialize(map, buffer)

Arguments

Type IntentOptional Attributes Name
type(StringIntegerMap), intent(in), target :: map
integer, intent(inout), allocatable :: buffer(:)

Calls

proc~~stringintegermap_serialize~~CallsGraph proc~stringintegermap_serialize StringIntegerMap_serialize begin begin proc~stringintegermap_serialize->begin interface~serialize_buffer_length serialize_buffer_length proc~stringintegermap_serialize->interface~serialize_buffer_length interface~serialize_intrinsic serialize_intrinsic proc~stringintegermap_serialize->interface~serialize_intrinsic key key proc~stringintegermap_serialize->key next next proc~stringintegermap_serialize->next

Called by

proc~~stringintegermap_serialize~~CalledByGraph proc~stringintegermap_serialize StringIntegerMap_serialize none~serialize~18 FileMetadata%serialize none~serialize~18->proc~stringintegermap_serialize proc~historycollectionvector_serialize HistoryCollectionVector_serialize proc~historycollectionvector_serialize->none~serialize~18 proc~test_serialize test_serialize proc~test_serialize->none~serialize~18

Source Code

    subroutine StringIntegerMap_serialize(map,buffer)
       type (StringIntegerMap), target, intent(in):: map
       integer, allocatable,intent(inout) :: buffer(:)
       type (StringIntegerMapIterator) :: iter
       character(len=:),pointer :: key
       integer,pointer :: value
       integer :: length
 
       if (allocated(buffer)) deallocate(buffer)
       allocate(buffer(0))
       iter = map%begin()
       do while (iter /= map%end())
          key => iter%key()
          buffer=[buffer,serialize_intrinsic(key)]
          value => iter%value()
          buffer = [buffer, serialize_intrinsic(value)]
          call iter%next() 
       enddo
       length = serialize_buffer_length(length) + size(buffer)
       buffer = [serialize_intrinsic(length),buffer]

    end subroutine StringIntegerMap_serialize