gtool5 Fortran 90/95 Library 1.0.0-rc5
日本語
Loading...
Searching...
No Matches
gtvaraddmember.f90 File Reference

Add gt_structure_member attribute to structure variable. More...

Go to the source code of this file.

Functions/Subroutines

subroutine gtvaraddmember (var, member_url, link_name)

Detailed Description

Add gt_structure_member attribute to structure variable.

Author
Eizi TOYODA, Yasuhiro MORIKAWA

This subroutine is provided as gtdata_generic#Add_Member through gtdata_generic.

Definition in file gtvaraddmember.f90.

Function/Subroutine Documentation

◆ gtvaraddmember()

subroutine gtvaraddmember ( type(gt_variable), intent(inout) var,
character(len = *), intent(in) member_url,
character(len = *), intent(in), optional link_name )

Add member to structure variable

Adds the variable name part of member_url to the gt_structure_member attribute of variable var (see "4. Structure Variables" in gtool4 netCDF Convention).

Parameters
[in,out]varVariable handle
[in]member_urlURL of member variable to add
[in]link_nameLink name (optional)

Definition at line 44 of file gtvaraddmember.f90.

45 use gtdata_types, only: gt_variable
46 use dc_types, only: string
47 use dc_url, only: urlsplit
49 use dc_error
50 implicit none
51 type(GT_VARIABLE), intent(inout):: var
52 character(len = *), intent(in):: member_url
53 character(len = *), intent(in), optional:: link_name
54 character(len = string):: members, myshortname, conv
55continue
56 ! 短縮名称の決定
57 ! 既存のメンバ名に重複しないものを選ぶ
58 call get_attr(var, 'gt_structure_member', members)
59 if (present(link_name)) then
60 if (index(members, ' ' //link_name) == 0) then
61 myshortname = link_name
62 goto 1000
63 endif
64 endif
65 conv = member_url
66 call urlsplit(conv, var=myshortname)
67 ! fake 判定
68 if (index(members, trim(myshortname)) /= 0) then
69 call storeerror(gt_efake, "GTVarAddMember(making unique name)")
70 endif
711000 continue
72 members = trim(members) // ' ' // trim(myshortname)
73 call put_attr(var, 'gt_structure_member', trim(members))
74 myshortname = 'gt_structure_link_' // trim(myshortname)
75 call put_attr(var, myshortname, trim(member_url))
76
Error handling module.
Definition dc_error.f90:454
subroutine, public storeerror(number, where, err, cause_c, cause_i)
Definition dc_error.f90:891
integer, parameter, public gt_efake
Positive error numbers are reserved for libc system error messages. Due to high system dependency and...
Definition dc_error.f90:503
Provides kind type parameter values.
Definition dc_types.f90:55
integer, parameter, public string
Character length for string
Definition dc_types.f90:137
Variable URL string parser.
Definition dc_url.f90:61

References dc_error::gt_efake, dc_error::storeerror(), and dc_types::string.

Here is the call graph for this function: