MONC
checkpointcommon.F90
Go to the documentation of this file.
1 
3 #ifndef TEST_MODE
4  use netcdf, only : nf90_ebaddim, nf90_enotatt, nf90_enotvar, nf90_noerr, nf90_strerror
5 #else
7 #endif
8  use logging_mod, only : log_error, log_log
9  implicit none
10 
11  character(len=*), parameter :: x_dim_key = "x", & !< X dimension/variable key
12  y_dim_key="y", &
13  z_dim_key="z", &
14  zn_dim_key="zn", &
15  q_dim_key="q", &
16  u_key = "u_nogal", &
17  v_key = "v_nogal", &
18  w_key = "w", &
19  q_key = "q", &
20  zu_key = "zu", &
21  zv_key = "zv", &
22  zw_key = "zw" , &
23  zq_key = "zq", &
24  x_key = "x", &
25  y_key = "y", &
26  z_key = "z", &
27  zn_key="zn", &
28  th_key = "th", &
29  zth_key = "zth", &
30  p_key = "p", &
31  timestep="timestep", &
32  time_key="time",&
33  dtm_key="dtm",&
34  dtm_new_key="dtm_new",&
35  absolute_new_dtm_key="absolute_new_dtm",&
36  ugal="ugal",&
37  vgal="vgal",&
38  empty_dim_key="empty_dim", &
39  key_value_pair_key="kvp", &
40  options_dim_key="number_options", &
41  options_key="options_database", &
42  string_dim_key="string",&
43  title_attribute_key="title",&
44  created_attribute_key="created",&
45  nqfields="nqfields", &
46  q_indices_dim_key="active_q_indicies", &
47  q_indices_key="q_indicies", &
48  x_resolution="x_resolution", &
49  y_resolution="y_resolution", &
50  x_top="x_top", &
51  y_top="y_top", &
52  x_bottom="x_bottom", &
53  y_bottom="y_bottom", &
54  q_field_anonymous_name="q_qfield", &
55  zq_field_anonymous_name="zq_qfield", &
56  thref="thref", &
57  olubar="olubar", &
58  olzubar="olzubar", &
59  olvbar="olvbar", &
60  olzvbar="olzvbar", &
61  olthbar="olthbar", &
62  olzthbar="olzthbar", &
63  olqbar="olqbar", &
64  olqbar_anonymous_name="olqbar_qfield", &
65  olzqbar="olzqbar", &
66  olzqbar_anonymous_name="olzqbar_qfield"
67 
68  integer, parameter :: max_string_length = 100
69 
70 contains
71 
76  subroutine check_status(status, found_flag)
77  integer, intent(in) :: status
78  logical, intent(out), optional :: found_flag
79 
80  if (present(found_flag)) then
81  found_flag = status /= nf90_ebaddim .and. status /= nf90_enotatt .and. status /= nf90_enotvar
82  if (.not. found_flag) return
83  end if
84 
85  if (status /= nf90_noerr) then
86  call log_log(log_error, "NetCDF returned error code of "//trim(nf90_strerror(status)))
87  end if
88  end subroutine check_status
89 
93  subroutine remove_null_terminator_from_string(net_cdf_string)
94  character(len=*), intent(inout) :: net_cdf_string
95  integer :: i
96  do i=1,len(net_cdf_string)
97  if (iachar(net_cdf_string(i:i)) == 0) then
98  net_cdf_string(i:len(net_cdf_string)) = ' '
99  exit
100  end if
101  end do
103 end module checkpointer_common_mod
character(len= *), parameter olubar
character(len= *), parameter p_key
Pressure variable NetCDF key.
character(len= *), parameter zn_key
character(len= *), parameter olzthbar
character(len= *), parameter y_key
character(len= *), parameter u_key
U variable NetCDF key.
character(len= *), parameter key_value_pair_key
Key-value pair dimension key.
character(len= *), parameter thref
integer, parameter nf90_noerr
character(len= *), parameter q_key
Q variable NetCDF key.
character(len= *), parameter empty_dim_key
Empty dimension key.
character(len= *), parameter y_dim_key
Y dimension/variable key.
integer, parameter, public log_error
Only log ERROR messages.
Definition: logging.F90:11
character(len= *), parameter y_top
character(len= *), parameter zv_key
Logging utility.
Definition: logging.F90:2
character(len= *), parameter olzqbar_anonymous_name
Common checkpoint functionality which is used by reader and writers to NetCDF checkpoints.
character(len= *), parameter created_attribute_key
character(len= *), parameter zq_field_anonymous_name
character(len= *), parameter zth_key
character(len= *), parameter x_key
integer, parameter max_string_length
Maximum string length (stored size)
character(len= *), parameter timestep
Timestep NetCDF key.
character(len= *), parameter time_key
character(len= *), parameter zu_key
character(len= *), parameter z_dim_key
Z dimension/variable key.
character(len= *), parameter options_dim_key
Options dimension key.
character(len= *), parameter olzvbar
character(len= *), parameter v_key
V variable NetCDF key.
integer, parameter nf90_enotatt
character(len= *), parameter olvbar
character(len= *), parameter absolute_new_dtm_key
character(len= *), parameter q_indices_key
subroutine, public log_log(level, message, str)
Logs a message at the specified level. If the level is above the current level then the message is ig...
Definition: logging.F90:75
character(len= *), parameter z_key
character(len= *), parameter x_bottom
character(len= *), parameter string_dim_key
String dimension key.
character(len= *), parameter w_key
W variable NetCDF key.
character(len= *), parameter title_attribute_key
character(len= *), parameter dtm_key
subroutine check_status(status, found_flag)
Will check a NetCDF status and write to log_log error any decoded statuses. Can be used to decode whe...
character(len= *), parameter q_dim_key
character(len= *), parameter olzubar
character(len= *), parameter y_bottom
character(len= *), parameter dtm_new_key
character(len= *), parameter olzqbar
integer, parameter nf90_enotvar
character(len= *), parameter q_field_anonymous_name
character(len= *), parameter zn_dim_key
character(len= *), parameter olthbar
character(len= *), parameter x_resolution
character(len= *), parameter olqbar_anonymous_name
character(len= *), parameter q_indices_dim_key
character(len=10) function nf90_strerror(status)
character(len= *), parameter x_dim_key
X dimension/variable key.
character(len= *), parameter th_key
Theta variable NetCDF key.
character(len= *), parameter olqbar
character(len= *), parameter zq_key
character(len= *), parameter vgal
character(len= *), parameter zw_key
character(len= *), parameter ugal
character(len= *), parameter x_top
integer, parameter nf90_ebaddim
character(len= *), parameter options_key
Options variable key.
character(len= *), parameter nqfields
character(len= *), parameter y_resolution
subroutine remove_null_terminator_from_string(net_cdf_string)
Removes NetCDF C style null termination of string. This is placed right at the end, after any spaces so trim will not actually trim any spaces due to null terminator.