#!/usr/bin/env ruby # -*- f90 -*- # vi: set sw=4 ts=8: require("intrinsic_types") # # "anvarputnum.f90" Generator with Ruby. # print <<"__EndOfFortran90Code__" !-- #{rb2f90_header_comment}! !++ != AN_VARIABLES ¤Î½ÐÎÏ ! != Put AN_VARIABLES ! ! Authors:: Yasuhiro MORIKAWA, Eizi TOYODA ! Version:: $Id: anvarputnum.rb2f90,v 1.1.1.1 2008-09-23 09:56:36 morikawa Exp $ ! Tag Name:: $Name: gtool5-20090217 $ ! Copyright:: Copyright (C) GFD Dennou Club, 2000-2005. All rights reserved. ! License:: See COPYRIGHT[link:../../COPYRIGHT] ! __EndOfFortran90Code__ types = ["Real", "Double", "Int"] types.each{ |type| print <<"__EndOfFortran90Code__" subroutine ANVarPut#{type}(var, start, count, stride, imap, siz, value, iostat) use dc_types, only: DP use an_types, only: AN_VARIABLE use an_vartable, only: an_variable_entry, vtable_lookup use netcdf_f77, only: nf_noerr, nf_einval, nf_put_varm_#{type} use an_file, only: anfiledatamode use dc_trace, only: BeginSub, EndSub, DbgMessage implicit none type(AN_VARIABLE), intent(in):: var integer, intent(in):: start(:) integer, intent(in):: count(:) integer, intent(in):: stride(:) integer, intent(in):: imap(:) integer, intent(in):: siz #{$type_intent_in[type]}, intent(in):: value(siz) integer, intent(out):: iostat integer:: ndims type(an_variable_entry):: ent character(len = *), parameter:: subname = "ANVarPut#{type}" continue call BeginSub(subname) iostat = vtable_lookup(var, ent) if (iostat /= nf_noerr) goto 999 ndims = 0 if (associated(ent%dimids)) ndims = size(ent%dimids) if (min(size(start), size(count), size(stride), size(imap)) < ndims) then iostat = nf_einval goto 999 endif call DbgMessage("f=%d v=%d sta=%*d c=%*d str=%*d imap=%*d", & & i=(/ent%fileid, ent%varid, start, count, stride, imap/), & & n=(/ndims, ndims, ndims, ndims/)) iostat = anfiledatamode(ent%fileid) if (iostat /= nf_noerr) return iostat = nf_put_varm_#{type}(ent%fileid, ent%varid, & & start, count, stride, imap, value) 999 continue call EndSub(subname, "iostat=%d", i=(/iostat/)) end subroutine ANVarPut#{type} __EndOfFortran90Code__ } print <<"__EndOfFooter__" !-- ! vi:set readonly sw=4 ts=8: ! #{rb2f90_emacs_readonly}! !++ __EndOfFooter__