StringAttributeMap_serialize Subroutine

public subroutine StringAttributeMap_serialize(map, buffer, rc)

Arguments

Type IntentOptional Attributes Name
type(StringAttributeMap), intent(in), target :: map
integer, intent(inout), allocatable :: buffer(:)
integer, intent(out), optional :: rc

Calls

proc~~stringattributemap_serialize~~CallsGraph proc~stringattributemap_serialize StringAttributeMap_serialize interface~serialize_buffer_length serialize_buffer_length proc~stringattributemap_serialize->interface~serialize_buffer_length interface~serialize_intrinsic serialize_intrinsic proc~stringattributemap_serialize->interface~serialize_intrinsic none~begin~83 StringAttributeMap%begin proc~stringattributemap_serialize->none~begin~83 none~key~196 StringAttributeMapIterator%key proc~stringattributemap_serialize->none~key~196 none~next~81 StringAttributeMapIterator%next proc~stringattributemap_serialize->none~next~81 none~serialize~18 UnlimitedEntity%serialize proc~stringattributemap_serialize->none~serialize~18 proc~mapl_return MAPL_Return proc~stringattributemap_serialize->proc~mapl_return none~serialize~18->interface~serialize_buffer_length none~serialize~18->interface~serialize_intrinsic none~serialize~18->proc~mapl_return interface~mapl_assert MAPL_Assert none~serialize~18->interface~mapl_assert none~get_rank UnlimitedEntity%get_rank none~serialize~18->none~get_rank at at proc~mapl_return->at insert insert proc~mapl_return->insert proc~mapl_throw_exception MAPL_throw_exception proc~mapl_return->proc~mapl_throw_exception none~get_rank->proc~mapl_return none~get_shape UnlimitedEntity%get_shape none~get_rank->none~get_shape none~get_shape->proc~mapl_return

Called by

proc~~stringattributemap_serialize~~CalledByGraph proc~stringattributemap_serialize StringAttributeMap_serialize none~serialize~10 Variable%serialize none~serialize~10->proc~stringattributemap_serialize none~serialize~19 CoordinateVariable%serialize none~serialize~19->none~serialize~10 none~serialize~25 FileMetadata%serialize none~serialize~25->none~serialize~10 proc~stringvariablemap_serialize StringVariableMap_serialize none~serialize~25->proc~stringvariablemap_serialize proc~stringvariablemap_serialize->none~serialize~10 proc~test_serialize~5 test_serialize proc~test_serialize~5->none~serialize~10 proc~historycollectionvector_serialize HistoryCollectionVector_serialize proc~historycollectionvector_serialize->none~serialize~25 proc~stringvariablemap_get_length StringVariableMap_get_length proc~stringvariablemap_get_length->proc~stringvariablemap_serialize proc~test_serialize~4 test_serialize proc~test_serialize~4->none~serialize~25 proc~test_serialize~6 test_serialize proc~test_serialize~6->none~serialize~19

Source Code

    subroutine StringAttributeMap_serialize(map,buffer, rc)
       type (StringAttributeMap), target, intent(in):: map
       integer, allocatable,intent(inout) :: buffer(:)
       integer, optional, intent(out) :: rc

       type (StringAttributeMapIterator) :: iter
       character(len=:),pointer :: key
       type(Attribute),pointer :: attr_ptr
       integer :: length
       integer, allocatable :: tmp_buffer(:)

       if (allocated(buffer)) deallocate(buffer)
       allocate(buffer(0))
       iter = map%begin()
       do while (iter /= map%end())
          key => iter%key()
          buffer=[buffer,serialize_intrinsic(key)]
          attr_ptr => iter%value()
          call attr_ptr%serialize(tmp_buffer)
          buffer = [buffer, tmp_buffer]
          deallocate(tmp_buffer)
          call iter%next()
       enddo
       length = serialize_buffer_length(length)+size(buffer)
       buffer = [serialize_intrinsic(length),buffer]
       _RETURN(_SUCCESS)
    end subroutine StringAttributeMap_serialize