gdncattrinquire.f90
Go to the documentation of this file.
1 ! -*- mode: f90; coding: utf-8 -*-
2 ! Copyright (C) GFD Dennou Club, 2000. All rights reserved.
3 
4 subroutine gdncattrinquire(var, attrname, xtype)
8  use netcdf, only: nf90_max_name, nf90_noerr, nf90_inquire_attribute
9  use dc_url, only: gt_plus
10  implicit none
11  type(gd_nc_variable), intent(in):: var
12  character(len=*), intent(in):: attrname
13  character(len=*), intent(out), optional:: xtype
14  type(gd_nc_variable_entry):: ent
15  integer:: varid, i_xtype, stat
16  character(len=NF90_MAX_NAME):: anam
17  stat = vtable_lookup(var, ent)
18  if (stat /= nf90_noerr) return
19  if (present(xtype)) then
20  call inquireplus(var, attrname, varid, anam)
21  stat = nf90_inquire_attribute(ent%fileid, varid, anam, xtype=i_xtype)
22  if (stat /= nf90_noerr) i_xtype = 0
23  call gdncxtypename(i_xtype, xtype)
24  endif
25 end subroutine
26 
27 subroutine gdncattrinquireplus(var, attrname, varid, nf_attrname)
28  !
29  ! 実際にアクセスするときに使う varid, attrname を得る.
30  ! attrname の先頭が '+' ---> 大域属性を強制指示.
31  ! attrname の先頭が '-' ---> 変数属性、大域属性の順で検索.
32  !
35  use dc_url, only: gt_plus
36  use netcdf, only: nf90_global, nf90_noerr, nf90_inquire_attribute
37  type(gd_nc_variable), intent(in):: var
38  character(len=*), intent(in):: attrname
39  integer, intent(out):: varid
40  type(gd_nc_variable_entry):: ent
41  character(len=*), intent(out):: nf_attrname
42  integer:: stat, n
43  stat = vtable_lookup(var, ent)
44  if (stat /= nf90_noerr) return
45  if (attrname(1:1) == gt_plus) then
46  varid = nf90_global
47  nf_attrname = attrname(2: )
48  else if (attrname(1:1) == '-') then
49  varid = ent%varid
50  nf_attrname = attrname(2: )
51  stat = nf90_inquire_attribute(ent%fileid, varid, nf_attrname, len = n)
52  if (stat == nf90_noerr) return
53  varid = nf90_global
54  else
55  varid = ent%varid
56  nf_attrname = attrname
57  endif
58 end subroutine gdncattrinquireplus
integer function, public vtable_lookup(var, entry)
subroutine gdncattrinquireplus(var, attrname, varid, nf_attrname)
character, parameter, public gt_plus
Definition: dc_url.f90:92
subroutine gdncattrinquire(var, attrname, xtype)
subroutine gdncxtypename(ixtype, xtype)