import functools
import click
from veros.settings import SETTINGS
BACKENDS = ['numpy', 'bohrium']
LOGLEVELS = ['trace', 'debug', 'info', 'warning', 'error', 'critical']
class VerosSetting(click.ParamType):
name = 'setting'
current_key = None
def convert(self, value, param, ctx):
assert param.nargs == 2
if self.current_key is None:
if value not in SETTINGS:
self.fail('Unknown setting %s' % value)
self.current_key = value
return value
assert self.current_key in SETTINGS
setting = SETTINGS[self.current_key]
self.current_key = None
if setting.type is bool:
return click.BOOL(value)
return setting.type(value)
[docs]def cli(run):
"""Decorator that wraps the decorated function with the Veros setup command line interface.
Example:
>>> @veros.tools.cli.cli()
>>> def run_setup(override):
... sim = MyVerosSetup(override=override)
... sim.run()
...
>>> if __name__ == '__main__':
... run_setup()
This script then automatically supports settings to be specified from the command line::
$ python my_setup.py --help
Usage: my_setup.py [OPTIONS]
Options:
-b, --backend [numpy|bohrium] Backend to use for computations (default:
numpy)
-v, --loglevel [trace|debug|info|warning|error|critical]
Log level used for output (default: info)
-s, --override SETTING VALUE Override default setting, may be specified
multiple times
-p, --profile-mode Write a performance profile for debugging
(default: false)
-n, --num-proc INTEGER... Number of processes in x and y dimension
(requires execution via mpirun)
--help Show this message and exit.
"""
@click.command('veros-run')
@click.option('-b', '--backend', default='numpy', type=click.Choice(BACKENDS),
help='Backend to use for computations (default: numpy)', envvar='VEROS_BACKEND')
@click.option('-v', '--loglevel', default='info', type=click.Choice(LOGLEVELS),
help='Log level used for output (default: info)', envvar='VEROS_LOGLEVEL')
@click.option('-s', '--override', nargs=2, multiple=True, metavar='SETTING VALUE',
type=VerosSetting(), default=tuple(),
help='Override default setting, may be specified multiple times')
@click.option('-p', '--profile-mode', is_flag=True, default=False, type=click.BOOL, envvar='VEROS_PROFILE',
help='Write a performance profile for debugging (default: false)')
@click.option('-n', '--num-proc', nargs=2, default=[1, 1], type=click.INT,
help='Number of processes in x and y dimension (requires execution via mpirun)')
@functools.wraps(run)
def wrapped(*args, **kwargs):
from veros import runtime_settings
kwargs['override'] = dict(kwargs['override'])
for setting in ('backend', 'profile_mode', 'num_proc', 'loglevel'):
if setting not in kwargs:
continue
setattr(runtime_settings, setting, kwargs.pop(setting))
run(*args, **kwargs)
return wrapped