src/gray_params.f90: handle missing mandatory parameters
This commit is contained in:
parent
b582eb19b8
commit
6a91eaa3a8
@ -203,6 +203,25 @@ module gray_params
|
|||||||
type(misc_parameters) :: misc
|
type(misc_parameters) :: misc
|
||||||
end type
|
end type
|
||||||
|
|
||||||
|
! List of mandatory GRAY parameters
|
||||||
|
integer, parameter :: max_name_size = 40
|
||||||
|
character(len=*), parameter :: mandatory(*) = [ &
|
||||||
|
character(len=max_name_size) :: &
|
||||||
|
"antenna.alpha", &
|
||||||
|
"antenna.beta", &
|
||||||
|
"antenna.iox", &
|
||||||
|
"antenna.ibeam", &
|
||||||
|
"antenna.filenm", &
|
||||||
|
"equilibrium.filenm", &
|
||||||
|
"profiles.irho", &
|
||||||
|
"profiles.iprof", &
|
||||||
|
"profiles.filenm", &
|
||||||
|
"raytracing.dst", &
|
||||||
|
"raytracing.nrayr", &
|
||||||
|
"raytracing.nrayth", &
|
||||||
|
"misc.rwall" &
|
||||||
|
]
|
||||||
|
|
||||||
! All GRAY input data
|
! All GRAY input data
|
||||||
type gray_data
|
type gray_data
|
||||||
type(equilibrium_data) :: equilibrium
|
type(equilibrium_data) :: equilibrium
|
||||||
@ -355,15 +374,31 @@ contains
|
|||||||
|
|
||||||
subroutine read_gray_config(filename, params, err)
|
subroutine read_gray_config(filename, params, err)
|
||||||
! Reads the GRAY parameters from the gray.ini configuration file
|
! Reads the GRAY parameters from the gray.ini configuration file
|
||||||
use ini_parser, only : parse_ini, property_handler, ini_error
|
use ini_parser, only : parse_ini, property_handler, ini_error, ERR_SUCCESS
|
||||||
|
use logger, only : log_error
|
||||||
|
|
||||||
! subroutine arguments
|
! subroutine arguments
|
||||||
character(len=*), intent(in) :: filename
|
character(len=*), intent(in) :: filename
|
||||||
type(gray_parameters), intent(out) :: params
|
type(gray_parameters), intent(out) :: params
|
||||||
integer(kind(ini_error)), intent(out) :: err
|
integer(kind(ini_error)), intent(out) :: err
|
||||||
|
|
||||||
|
integer, parameter :: max_lines = 100
|
||||||
|
integer :: count, i
|
||||||
|
character(len=max_name_size) :: provided(max_lines), name
|
||||||
|
|
||||||
|
! parse the configuration
|
||||||
|
count = 1
|
||||||
call parse_ini(filename, ini_handler, err)
|
call parse_ini(filename, ini_handler, err)
|
||||||
|
if (err /= ERR_SUCCESS) return
|
||||||
|
|
||||||
|
! check if all mandatory parameters were given
|
||||||
|
do i = 1, size(mandatory)
|
||||||
|
name = mandatory(i)
|
||||||
|
if (findloc(provided, trim(name), count) /= 0) cycle
|
||||||
|
call log_error('mandatory parameter `'//trim(name)//'` is missing!', &
|
||||||
|
mod='gray_params', proc='read_gray_config')
|
||||||
|
err = 1
|
||||||
|
end do
|
||||||
|
|
||||||
contains
|
contains
|
||||||
|
|
||||||
@ -376,6 +411,10 @@ contains
|
|||||||
integer(kind(ini_error)) :: err
|
integer(kind(ini_error)) :: err
|
||||||
|
|
||||||
err = update_parameter(params, section // "." // name, value)
|
err = update_parameter(params, section // "." // name, value)
|
||||||
|
|
||||||
|
! store the parameter name
|
||||||
|
provided(count) = section // "." // name
|
||||||
|
count = count + 1
|
||||||
end function ini_handler
|
end function ini_handler
|
||||||
|
|
||||||
end subroutine read_gray_config
|
end subroutine read_gray_config
|
||||||
|
@ -137,7 +137,7 @@ contains
|
|||||||
cycle
|
cycle
|
||||||
|
|
||||||
case (ERR_VALUE)
|
case (ERR_VALUE)
|
||||||
write (msg, '("invalid value for property ",a,": ", a)') name, value
|
write (msg, '("invalid value for property `",a,"`: ", a)') name, value
|
||||||
call log_error(msg, proc='parse_ini', mod='ini_parser')
|
call log_error(msg, proc='parse_ini', mod='ini_parser')
|
||||||
deallocate(line)
|
deallocate(line)
|
||||||
error = ERR_VALUE
|
error = ERR_VALUE
|
||||||
|
Loading…
Reference in New Issue
Block a user