anvarputattrint.f90

Path: src/anvarputattrint.f90
Last Update: Fri Aug 05 00:58:31 JST 2005

Copyright (C) GFD Dennou Club, 2000. All rights reserved

Methods

Included Modules

an_types an_file an_vartable netcdf_f77 dc_url dc_error

Public Instance methods

var :type(AN_VARIABLE), intent(in)
name :character(len = *), intent(in)
value(:) :integer, intent(in)
err :logical, intent(out), optional

[Source]

subroutine ANVarPutAttrInt(var, name, value, err)

    implicit none
    type(AN_VARIABLE), intent(in):: var
    character(len = *), intent(in):: name
    type(an_variable_entry):: ent
    integer, intent(in):: value(:)
    logical, intent(out), optional:: err
    integer:: stat
continue
    stat = vtable_lookup(var, ent)
    if (stat /= NF_NOERR) goto 999
    if (size(value) == 0) then
        if (name(1:1) == GT_PLUS) then
            stat = nf_del_att(ent%fileid, NF_GLOBAL, name=name(2:))
        else
            stat = nf_del_att(ent%fileid, ent%varid, name=name)
        endif
        goto 999
    endif
    stat = ANFileDefineMode(ent%fileid)
    if (stat /= NF_NOERR) goto 999
    if (name(1:1) == GT_PLUS) then
        stat = nf_put_att_int(ent%fileid, NF_GLOBAL, name=name(2:),             xtype=NF_INT, len=size(value), ivals=value)
    else
        stat = nf_put_att_int(ent%fileid, ent%varid, name=name,             xtype=NF_INT, len=size(value), ivals=value)
    endif
    999 continue
    call StoreError(stat, 'ANVarPutAttrInt', err)
end subroutine

[Validate]