gdncfilesync.f90

Path: gtdata/gtdata_netcdf/gtdata_netcdf_file/gdncfilesync.f90
Last Update: Mon May 25 18:49:24 +0900 2009

Methods

Included Modules

gtdata_netcdf_file_types gtdata_netcdf_file_internal gtdata_netcdf_file_generic netcdf_f77 dc_error

Public Instance methods

Subroutine :
fileid :integer, intent(in), optional
stat :integer, intent(out), optional

[Source]

subroutine GDNcFileSync(fileid, stat)
  use gtdata_netcdf_file_types, only: GD_NC_FILE_ID_ENTRY
  use gtdata_netcdf_file_internal, only: id_head, id_used
  use gtdata_netcdf_file_generic, only: GDNcFileDataMode
  use netcdf_f77, only: nf_sync, NF_NOERR
  use dc_error
  integer, intent(in), optional:: fileid
  integer, intent(out), optional:: stat
  integer:: ncid, mystat
  type(GD_NC_FILE_ID_ENTRY), pointer:: identptr
continue
  mystat = NF_NOERR
  if (present(fileid)) then
    ncid = fileid
    mystat = GDNcFileDataMode(ncid)
    if (mystat /= NF_NOERR) goto 999
    mystat = nf_sync(ncid)
  else if (id_used) then
    identptr => id_head
    do
      if (.not. associated(identptr)) exit
      ncid = identptr % id
      mystat = GDNcFileDataMode(ncid)
      if (mystat /= NF_NOERR) exit
      mystat = nf_sync(ncid)
      if (mystat /= NF_NOERR) exit
      identptr => identptr % next
    enddo
  endif
999 continue
  ! 自発的には StoreError しない。StoreError の SysdepAbort
  ! からも呼ばれる可能性があるためである。
  if (present(stat)) stat = mystat
end subroutine GDNcFileSync

[Validate]