src/gray_cli.f90: allow enabling or disabling all units

This commit is contained in:
Michele Guerini Rocco 2023-09-13 16:55:35 +02:00
parent 8425e5e286
commit 59dfcb7799
Signed by: rnhmjoj
GPG Key ID: BFBAF4C975F76450
2 changed files with 25 additions and 13 deletions

View File

@ -54,6 +54,7 @@ contains
print '(a)', ' (default: gray.ini)' print '(a)', ' (default: gray.ini)'
print '(a)', ' -s, --sum FILE sum the output profiles from a list of files' print '(a)', ' -s, --sum FILE sum the output profiles from a list of files'
print '(a)', ' -u, --units ID[,ID...] select which units to output (default: 4, 7);' print '(a)', ' -u, --units ID[,ID...] select which units to output (default: 4, 7);'
print '(a)', ' use `all` to enable all, or `none` for no units.'
print '(a)', ' see the manual for all unit IDs.' print '(a)', ' see the manual for all unit IDs.'
print '(a)', ' -g, --gray-param ID=VAL set a GRAY parameter, overriding the value' print '(a)', ' -g, --gray-param ID=VAL set a GRAY parameter, overriding the value'
print '(a)', ' specified via --params-file/--config-file;' print '(a)', ' specified via --params-file/--config-file;'
@ -102,7 +103,7 @@ contains
subroutine parse_cli_options(opts) subroutine parse_cli_options(opts)
! Parse the CLI arguments and initialise the options ! Parse the CLI arguments and initialise the options
use units, only : ucenr, usumm use units, only : ucenr, usumm, all_enabled
use logger, only : WARNING use logger, only : WARNING
implicit none implicit none
@ -161,19 +162,29 @@ contains
case ('-u', '--units') case ('-u', '--units')
call get_next_command(i, temp) call get_next_command(i, temp)
! resize the array if (temp == 'none') then
commas = count([(temp(i:i) == ',', i = 1, len(temp))]) ! disable all output units
deallocate(opts%units) deallocate(opts%units)
allocate(opts%units(commas + 1)) allocate(opts%units(0))
elseif (temp == 'all') then
! enable all output units
all_enabled = .true.
else
! resize the array
commas = count([(temp(i:i) == ',', i = 1, len(temp))])
deallocate(opts%units)
allocate(opts%units(commas + 1))
! read the list of table IDs ! read the list of table IDs
read (temp, *, iostat=error) opts%units read (temp, *, iostat=error) opts%units
if (error > 0) then if (error > 0) then
print '(a,a)', 'invalid table IDs: ', temp print '(a,a)', 'invalid table IDs: ', temp
deallocate(argument) deallocate(argument)
deallocate(temp) deallocate(temp)
call exit(1) call exit(1)
end if
end if end if
deallocate(temp) deallocate(temp)
case ('-g', '--gray-param') case ('-g', '--gray-param')

View File

@ -20,6 +20,7 @@ module units
#endif #endif
! List of active units ! List of active units
logical, save :: all_enabled = .false.
integer, allocatable, save :: active_units(:) integer, allocatable, save :: active_units(:)
contains contains
@ -66,7 +67,7 @@ contains
integer, intent(in) :: unit integer, intent(in) :: unit
logical :: on logical :: on
on = any(active_units == unit) on = all_enabled .or. any(active_units == unit)
end function unit_active end function unit_active