rose app-run [OPTIONS] [--] [COMMAND ...]
Run an application according to its configuration.
May run a builtin application (if the mode
setting in the configuration
specifies the name of a builtin application) or a command.
Determine the command to run in this order:
COMMAND
is specified, invoke the command.--command-key=KEY
option is defined, invoke the command
specified in [command]KEY
.ROSE_APP_COMMAND_KEY
environment variable is set, the command
specified in the [command]KEY
setting in the application
configuration whose KEY
matches it is used.ROSE_TASK_NAME
is defined and a setting
in the [command]
section has a key matching the value of the
environment variable, then the value of the setting is used as the
command.[command]default
.OPTIONS
--app-mode=MODE
MODE
. The default MODE
is
command
.--config=DIR, -C DIR
$PWD
)--command-key=KEY, -c KEY
[command]KEY
.--define=[SECTION]KEY=VALUE, -D [SECTION]KEY=VALUE
[SECTION]KEY
setting with a given
VALUE
.
Can be used to disable a setting using the syntax
--define=[SECTION]!KEY
or even --define=[!SECTION]
.--install-only, -i
--new, -N
$PWD
before doing anything. This option only
works with the --config=DIR
option and if $PWD
is not DIR
.--no-overwrite
--opt-conf-key=KEY, -O KEY, --opt-conf-key='(KEY)', -O '(KEY)'
KEY
.
The configurations are applied first-to-last. The (KEY)
syntax
denotes an optional configuration that can be missing. Otherwise, the
optional configuration must exist.--quiet, -q
--verbose, -v
ENVIRONMENT VARIABLES
optional ROSE_APP_COMMAND_KEY
[command]KEY
.optional ROSE_APP_MODE
optional ROSE_APP_OPT_CONF_KEYS
KEY
in this space delimited list switches on an optional
configuration. The configurations are applied first-to-last.optional ROSE_FILE_INSTALL_ROOT
rose app-upgrade [OPTIONS] [VERSION]
Upgrade an application configuration using metadata upgrade macros.
Alternatively, show the available upgrade/downgrade versions:
=
indicates the current version.*
indicates the default version to change to.If an application contains optional configurations, loop through each one, combine with the main, upgrade it, and re-create it as a diff vs the upgraded main configuration.
OPTIONS
--all-versions, -a
--config=DIR, -C DIR
DIR
instead of $PWD
.--downgrade, -d
--meta-path=PATH, -M PATH
PATH
to the metadata search path. (look here first).
This option can be used repeatedly to load multiple paths.--non-interactive, --yes, -y
--output=DIR, -O DIR
--quiet, -q
ARGUMENTS
VERSION
--non-interactive
is used, use the latest version
available. If --non-interactive
and --downgrade
are used, use
the earliest version available.ENVIRONMENT VARIABLES
optional ROSE_META_PATH
$ROSE_META_PATH
to the metadata search path.rose bush start [PORT] # start ad-hoc web service server (on PORT)
rose bush stop # stop ad-hoc web service server
rose bush stop -y # stop ad-hoc web service server w/o prompting
rose bush # print status of ad-hoc web service server
Start/stop ad-hoc Rose Bush web service server.
For rose bush start
, if PORT
is not specified, use port 8080.
Rose Bush is a web service for browsing users’ Rose suite logs via an HTTP interface.
OPTIONS
--non-interactive, --yes, -y
--service-root, -R
rose check-software [OPTIONS]
Check software dependencies for the rose documentation builder.
OPTIONS
# Print the value of OPTION in SECTION.
rose config SECTION OPTION
# Print the value of OPTION in SECTION in FILE.
rose config --file=FILE SECTION OPTION
# Print the value of OPTION in SECTION if exists, or VALUE otherwise.
rose config --default=VALUE SECTION OPTION
# Print the OPTION=VALUE pairs in SECTION.
rose config SECTION
# Print the value of a top level OPTION.
rose config OPTION
# Print the OPTION keys in SECTION.
rose config --keys SECTION
# Print the SECTION keys.
rose config --keys
# Exit with 0 if OPTION exists in SECTION, or 1 otherwise.
rose config -q SECTION OPTION
# Exit with 0 if SECTION exists, or 1 otherwise.
rose config -q SECTION
# Combine the configurations in FILE1 and FILE2, and dump the result.
rose config --file=FILE1 --file=FILE2
# Print the value of OPTION in SECTION of the metadata associated with
# the specified config FILE
rose config --file=FILE --meta SECTION OPTION
# Print the value of a specified metadata KEY
rose config --meta-key=KEY
Parse and print rose configuration files.
With no option and no argument, print the Rose site + user configuration.
OPTIONS
--default
--env-var-process, -E
--file=FILE, -f FILE
$THIS/../etc/rose.conf
and $HOME/.metomi/rose.conf
(where
$THIS
is the location of this command).--keys, -k
SECTION
keys in the configuration file
or the OPTION
keys in a SECTION
.--meta
FILE
.--meta-key=KEY
KEY
.
Cannot be used in conjunction with --file=FILE
.--no-opts
--print-conf
--print-ignored, -i
!OPTION=VALUE
where
relevant.--quiet, -q
SECTION
and/or OPTION
exist in the
configuration, or 1 otherwise.ENVIRONMENT VARIABLES
optional ROSE_META_PATH
$ROSE_META_PATH
to the metadata search path.# Display the metadata-annotated diff between two Rose config files.
rose config-diff FILE1 FILE2
# Display the metadata-annotated diff between two Rose config dirs.
rose config-diff DIR1 DIR2
# Display the diff, ignoring particular setting patterns
rose config-diff --ignore=namelist:foo FILE1 FILE2
# Display the diff with a particular diff tool
rose config-diff --diff-tool=kdiff3 FILE1 FILE2
# Display the diff with some diff tool specific options/arguments
rose config-diff FILE1 FILE2 -- [DIFF_OPTIONS] [DIFF_ARGUMENTS]
Display the metadata-annotated difference between two Rose config files.
OPTIONS
--diff-tool=TOOL
--graphical, -g
--ignore=PATTERN, -i PATTERN
PATTERN
in
their id. Can be specified more than once. PATTERN
may also be a
key used in site or user configuration which expands to a list of
patterns. See CONFIGURATION
below.--meta-path=PATH, -M PATH
PATH
to the metadata search path (look here first).
This option can be used repeatedly to load multiple paths.--opt-conf-key-1=KEY, --opt-conf-key-1='(KEY)'
KEY
. The configurations are applied first-to-last. The (KEY)
syntax denotes an optional configuration that can be missing.
Otherwise, the optional configuration must exist.--opt-conf-key-2=KEY, --opt-conf-key-2='(KEY)'
opt-conf-key
for the file in the second argument.
Each of these switches on an optional configuration identified by
KEY
. The configurations are applied first-to-last. The (KEY)
syntax denotes an optional configuration that can be missing.
Otherwise, the optional configuration must exist.--properties=PROPERTIES, -p PROPERTIES
ENVIRONMENT VARIABLES
optional ROSE_META_PATH
$ROSE_META_PATH
to the metadata search path.ARGUMENTS
PATH1, PATH2
PATH1
or PATH2
denotes read in from standard input.--
--
token are passed directly to the
diff tool.CONFIGURATION
[external]diff-tool, [external]gdiff-tool
You can override the default non-graphical and graphical diff tools by setting e.g:
[external]
diff-tool=diff3
gdiff-tool=kompare
in your site or user Rose configuration (rose.conf
).
[rose-config-diff]properties, [rose-config-diff]ignore{...}
You can override the default metadata properties to display by setting e.g:
[rose-config-diff]
properties=title,ns,description,help
in your site or user Rose configuration (rose.conf
).
You can also set shorthand ignore patterns by setting e.g.:
[rose-config-diff]
ignore{foo}=namelist:bar,namelist:baz
in the same location. This will allow you to run:
rose config-diff --ignore=foo ...
instead of:
rose config-diff --ignore=namelist:bar --ignore=namelist:baz ...
rose config-dump
rose config-dump -C /path/to/conf/dir
rose config-dump -f /path/to/file1 -f /path/to/file2
Re-dump Rose configuration files in the common format.
Load and dump "rose-*.conf"
files in place. Apply format-specific
pretty-printing.
By default, it recursively loads and dumps all rose-*.conf
files in the
current working directory.
OPTIONS
--config=DIR, -C DIR
DIR
before looking for configuration files.
(default=$PWD
)--file=FILE, -f FILE
--config=DIR
is
specified and FILE
is a relative path, FILE
is assumed to be
relative to DIR
.--no-pretty
--quiet, -q
rose config-edit [OPTIONS]... [PAGE_PATH]...
Launch the GTK+ GUI to edit a suite or application configuration.
If a suite contains more than 10 applications then they will only be loaded after startup, on demand.
OPTIONS
--config=DIR, -C DIR
A path to either:
suite.rc
and a directory called app
containing
subdirectories with files named rose-app.conf
,
in the format specified in the Rose pages.rose-app.conf
and an optional subdirectory called file
with other application files.--load-all-apps
--load-no-apps
--meta-path=PATH, -M PATH
PATH
to the search path for metadata (look here first).
This option can be used repeatedly to load multiple paths.--new
--no-metadata
--no-warn=WARNING-TYPE
Suppress warnings of the provided type. WARNING-TYPE
may be:
version
ARGUMENTS
PAGE_PATH
One or more paths to open on load, pages may be full or partial
namespaces e.g. foo/bar/env
or env
.
Note
Opens the shortest namespace that matches the provided string.
ENVIRONMENT VARIABLES
optional ROSE_META_PATH
$ROSE_META_PATH
to the metadata search path.# 1. Print date time point
# 1.1 Current date time with an optional offset
rose date [--offset=OFFSET]
rose date now [--offset=OFFSET]
rose date ref [--offset=OFFSET]
# 1.2 Task cycle date time with an optional offset
# Assume: export ROSE_TASK_CYCLE_TIME=20371225T000000Z
rose date -c [--offset=OFFSET]
rose date -c ref [--offset=OFFSET]
# 1.3 A specific date time with an optional offset
rose date 20380119T031407Z [--offset=OFFSET]
# 2. Print duration
# 2.1 Between now (+ OFFSET1) and a future date time (+ OFFSET2)
rose date now [--offset1=OFFSET1] 20380119T031407Z [--offset2=OFFSET2]
# 2.2 Between a date time in the past and now
rose date 19700101T000000Z now
# 2.3 Between task cycle time (+ OFFSET1) and a future date time
# Assume: export ROSE_TASK_CYCLE_TIME=20371225T000000Z
rose date -c ref [--offset1=OFFSET1] 20380119T031407Z
# 2.4 Between task cycle time and now (+ OFFSET2)
# Assume: export ROSE_TASK_CYCLE_TIME=20371225T000000Z
rose date -c ref now [--offset2=OFFSET2]
# 2.5 Between a date time in the past and the task cycle date time
# Assume: export ROSE_TASK_CYCLE_TIME=20371225T000000Z
rose date -c 19700101T000000Z ref
# 2.6 Between 2 specific date times
rose date 19700101T000000Z 20380119T031407Z
# 3. Convert ISO8601 duration
# 3.1 Into the total number of hours (H), minutes (M) or seconds (S)
# it represents, preceed negative durations with a double backslash
# (e.g. \\-PT1H)
rose date --as-total=s PT1H
Parse and print 1. a date time point or 2. a duration.
OPTIONS
--as-total=TIME_FORMAT
H
, minutes M
or seconds S
.--calendar=gregorian|360day|365day|366day
CALENDAR MODE
below.--offset1=OFFSET, --offset=OFFSET, -s OFFSET, -1 OFFSET
OFFSET FORMAT
below.--offset2=OFFSET, -2 OFFSET
OFFSET FORMAT
below.--parse-format=FORMAT, -p FORMAT
DATE-TIME
. See PARSE FORMAT
below.--print-format=FORMAT, --format=FORMAT, -f FORMAT
PRINT FORMAT
below.--use-task-cycle-time, -c
ROSE_TASK_CYCLE_TIME
environment variable as
the reference time instead of the current time.--utc, -u
CALENDAR MODE
The calendar mode is determined (in order) by:
--calendar=MODE
option.ROSE_CYCLING_MODE
environment variable.ENVIRONMENT VARIABLES
ROSE_CYCLING_MODE=gregorian|360day|365day|366day
ROSE_TASK_CYCLE_TIME
--use-task-cycle-time
option is set, the value of this environment
variable is used by the command as the reference time instead of the
current time.OFFSET FORMAT
OFFSET
must follow the ISO 8601 duration representations such as
PnW
or PnYnMnDTnHnMnS - P
followed by a series of nU
where U
is
the unit (Y
, M
, D
, H
, M
, S
) and n
is a positive integer,
where T
delimits the date series from the time series if any time units
are used. n
may also have a decimal (e.g. PT5.5M
) part for a unit
provided no smaller units are supplied. It is not necessary to
specify zero values for units. If OFFSET
is negative, prefix a -
.
For example:
P6D
- 6 day offsetPT6H
- 6 hour offsetPT1M
- 1 minute offset-PT1M
- (negative) 1 minute offsetP3M
- 3 month offsetP2W
- 2 week offset (note no other units may be combined with weeks)P2DT5.5H
- 2 day, 5.5 hour offset-P2YT4S
- (negative) 2 year, 4 second offsetThe following deprecated syntax is supported:
OFFSET
in the form nU
where U
is the unit (w
for weeks, d
for
days, h
for hours, m
for minutes and s
for seconds) and n
is a
positive or negative integer.
PARSE FORMAT
The format for parsing a date time point should be compatible with the POSIX strptime template format (see the strptime command help), with the following subset supported across all date/time ranges:
%F
, %H
, %M
, %S
, %Y
, %d
, %j
, %m
, %s
, %z
If not specified, the system will attempt to parse DATE-TIME
using
the following formats:
%a %b %d %H:%M:%S %Y
%a %b %d %H:%M:%S %Z %Y
%Y-%m-%dT%H:%M:%S
, %Y%m%dT%H%M%S
%Y%m%d%H
If none of these match, the date time point will be parsed according to the full ISO 8601 date/time standard.
PRINT FORMAT
For printing a date time point, the print format will default to the same format as the parse format. Also supports the isodatetime library dump syntax for these operations which follows ISO 8601 example syntax - for example:
CCYY-MM-DDThh:mm:ss
-> 1955-11-05T09:28:00
,CCYY
-> 1955
,CCYY-DDD
-> 1955-309
,CCYY-Www-D
-> 1955-W44-6
.Usage of this ISO 8601-like syntax should be as ISO 8601-compliant as possible.
Note that specifying an explicit timezone in this format (e.g.
CCYY-MM-DDThh:mm:ss+0100
or CCYYDDDThhmmZ
will automatically
adapt the date/time to that timezone i.e. apply the correct
hour/minute UTC offset.
For printing a duration, the following can be used in format statements:
y
: yearsm
: monthsd
: daysh
: hoursM
: minutess
: secondsFor example, for a duration P57DT12H
- y,m,d,h
-> 0,0,57,12
Alias - see rose config-edit
rose env-cat [OPTIONS] [FILE ...]
Substitute environment variables in input files and print.
If no argument is specified, read from STDIN. One FILE
argument may be
-
, which means read from STDIN.
In match-mode=default
, the command will look for $NAME
or ${NAME}
syntax and substitute them with the value of the environment variable
NAME
. A backslash in front of the syntax, e.g. \$NAME
or \${NAME}
will escape the substitution.
In match-mode=brace
, the command will look for ${NAME}
syntax only.
OPTIONS
--match-mode=MODE, -m MODE
brace
or default
.--output=FILE, -o FILE
FILE
is -
, write output to STDOUT.--unbound=STRING, --undef=STRING
STRING
, (which can be an empty string),
instead of failing.rose host-select [OPTIONS] [GROUP/HOST ...]
Select a host from a set of groups or names by load, by free memory or by random.
Use settings in $ROSE_HOME/etc/rose.conf
and $HOME/.metomi/rose.conf
to determine the ranking method.
Print the selected host name.
OPTIONS
--choice=N
N
hosts.--debug
--quiet, -q
--rank-method=METHOD[:METHOD-ARG]
Specify the method for ranking a list of hosts. The method can be:
load
Rank by average load as reported by uptime
divided by number of
virtual processors.
If METHOD-ARG
is specified, it must be 1
, 5
or 15
. The
default is to use the 15 minute load.
fs
Rank by % usage of a file system as reported by df
.
METHOD-ARG
must be a valid file system in all the given hosts
and host groups. The default is to use the ~
directory.
mem
free -m
to return
memory in Mbrandom
--threshold=[METHOD[:METHOD-ARG]:]VALUE
METHOD
and METHOD-ARG
(and the same defaults) as the --rank-method=METHOD[:METHOD-ARG]
option. (Obviously, the random
method does not make sense in this
case.) load
and fs
must not exceed threshold while mem
must be greater than threshold. A host not meeting a threshold
condition will be excluded from the ranking list.--timeout=FLOAT
--verbose, -v
CONFIGURATION
The command reads its settings from the [rose-host-select]
section in
$ROSE_HOME/etc/rose.conf
and $HOME/.metomi/rose.conf
. All settings
are optional. Type rose config rose-host-select
to print settings.
Valid settings are:
default = GROUP/HOST ...
group{NAME} = GROUP/HOST ...
method{NAME} = METHOD[:METHOD-ARG]
thresholds{NAME} = [METHOD[:METHOD-ARG]:]VALUE ...
timeout = FLOAT
rose macro [OPTIONS] [MACRO_NAME ...]
List or run macros associated with a suite or application.
Macros are listed/run according to the config dir ($PWD
unless
--config=DIR
is set):
rose-app.conf
file of that app.rose-suite.conf
,
rose-suite.info
and (unless --suite-only
is set) all
rose-app.conf
files.If a configuration contains optional configurations:
OPTIONS
--config=DIR, -C DIR
DIR
instead of $PWD
.--fix, -F
--meta-path=PATH, -M PATH
PATH
to the metadata search path (look here first).
This option can be used repeatedly to load multiple paths.--non-interactive, --yes, -y
--output=DIR, -O DIR
--quiet, -q
--suite-only
--transform, -T
--validate, -V
ARGUMENTS
MACRO_NAME ...
--fix
, --validate
are not used, list all available macros.
Otherwise, run the specified macro names.ENVIRONMENT VARIABLES
optional ROSE_META_PATH
$ROSE_META_PATH
to the metadata search path.rose make-docs [OPTIONS] [BUILD...]
Build the rose documentation in the requested BUILD
format(s).
OPTIONS
--venv
--dev
--strict
--debug
make
with the –debug option.--default-version=VERSION
BUILD
The format(s) to build the documentation in - default html. Avaliable formats are listed in the sphinx documentation (http://www.sphinx-doc.org/en/stable/builders.html). The most commonly used formats are:
html
singlehtml
latexpdf
clean
rm -rf doc
to remove all documentation).DEVELOPMENT BUILDS
For development purposes use the following BUILDs:
doctest
linkcheck
SOFTWARE ENVIRONMENT
The software dependencies can be found by running the command:
$ rose check-software --docs
Rose provides two ways of installing the Python dependencies for the Rose documentation builder:
Rose will automatically build a Python virtual environment when the –venv flag is used with this command. The virtual environment will be created in rose/venv and will be destroyed after use. Use the –dev flag to prevent the environment being destroyed for future use. Example:
$ rose make-docs --venv --dev html # create and keep a virtualenv
An environment file for creating a conda env can be found in etc/rose-docs-env.yaml. Example usage:
$ conda env create -f etc/rose-docs-env.yaml # create conda env
$ source activate rose-docs # activate conda env
$ rose make-docs html # make docs as normal
rose metadata-check [OPTIONS] [ID ...]
Validate configuration metadata.
OPTIONS
--config=DIR, -C DIR
rose-meta.conf
file, amongst other things.
If not specified, the current directory will be used.--property=PROPERTY, -p PROPERTY
ARGUMENTS
ID
env=FOO
or namelist:bar
. If specified, only
this section will be checked.rose metadata-gen [OPTIONS] [PROPERTY=VALUE ...]
Automatically generate metadata from an application or suite configuration. An aid for metadata development.
Warning
May Contain Thorns.
OPTIONS
--auto-type
type
and length
metadata.--config=DIR, -C DIR
--output=DIR, -O DIR
ARGUMENTS
PROPERTY[=VALUE] ...
key=value
pairs of properties to specify for
every setting e.g. compulsory=true
. If =VALUE
is missing,
the property will be set to a null string in each setting.rose metadata-graph [OPTIONS] [SECTION ...]
Graph configuration metadata.
OPTIONS
--config=DIR, -C DIR
--meta-path
, ROSE_META_PATH
). If the
configuration metadata is given, there will be no
configuration data used in the graphing.
If not specified, the current directory will be used.--meta-path=PATH, -M PATH
PATH
to the metadata search path (look here first).
This option can be used repeatedly to load multiple paths.--property=PROPERTY, -p PROPERTY
trigger
. If specified,
only this property will be graphed.ARGUMENTS
SECTION
ENVIRONMENT VARIABLES
optional ROSE_META_PATH
$ROSE_META_PATH
to the metadata search path.1. rose mpi-launch -f FILE
2. rose mpi-launch
3. rose mpi-launch COMMAND [ARGS ...]
Provide a portable way to launch an MPI command.
--command-file=FILE
(or -f FILE
) is specified, FILE
is
assumed to be the command file to be submitted to the MPI launcher
command.$PWD/rose-mpi-launch.rc
exists and
--command-file=FILE
(or -f FILE
) is not specified, it is assumed
to be the command file to be submitted to the MPI launcher command.COMMAND
with the MPI
launcher command.In all cases, the remaining arguments will be appended to the command line of the launcher program.
OPTIONS
--command-file=FILE, -f FILE
--debug
set -x
.--quiet, -q
--verbose, -v
-v
mode. Run printenv
,
ldd
on a binary executable, and ulimit -a
on -v -v
mode.CONFIGURATION
The command reads from the [rose-mpi-launch]
section in
$ROSE_HOME/etc/rose.conf
and $HOME/.metomi/rose.conf
.
Valid settings are:
launcher-list=LIST
Specify a list of launcher commands.
E.g:
launcher-list=poe mpiexec
launcher-fileopts.LAUNCHER=OPTION-TEMPLATE
Specify the options to a LAUNCHER
for launching with a command file.
The template string should contain $ROSE_COMMAND_FILE
(or
${ROSE_COMMAND_FILE}
), which will be expanded to the path to the
command file.
E.g.:
launcher-fileopts.mpiexec=-f $ROSE_COMMAND_FILE
launcher-fileopts.poe=-cmdfile $ROSE_COMMAND_FILE
launcher-(pre|post)opts.LAUNCHER=OPTION-TEMPLATE
Specify the options to a LAUNCHER
for launching with a command.
preopts
are options placed after the launcher command but before
COMMAND
. postopts
are options placed after COMMAND
but before
the remaining arguments.
E.g.:
launcher-preopts.mpiexec=-n $PROC
ENVIRONMENT VARIABLES
optional ROSE_LAUNCHER
optional ROSE_LAUNCHER_LIST
launcher-list
setting in configuration.optional ROSE_LAUNCHER_FILEOPTS
launcher-fileopts.LAUNCHER
setting for the selected
LAUNCHER
.optional ROSE_LAUNCHER_PREOPTS
launcher-preopts.LAUNCHER
setting for the selected
LAUNCHER
.optional ROSE_LAUNCHER_POSTOPTS
launcher-postopts.LAUNCHER
setting for the selected
LAUNCHER
.optional ROSE_LAUNCHER_ULIMIT_OPTS
rose mpi-launch --inner $@
. Specify the arguments to ulimit
.
E.g. Setting this variable to -a -s unlimited -d unlimited -a
results in ulimit -a; ulimit -s unlimited; ulimit -d unlimited;
ulimit -a
.optional NPROC
DIAGNOSTICS
Return 0 on success, 1 or exit code of the launcher program on failure.
rose-namelist-dump [OPTIONS] [FILE ...]
Convert namelist files into a Rose application configuration snippet.
Each argument should be the path to an empty file or a file containing
Fortran namelist groups. A -
can be used once in the argument list to
specify the standard input. If no argument is given, it assumes the
standard input is specified. Where possible, use relative path for file
names, as the file names appear as-specified in the generated
configuration.
OPTIONS
--case=MODE
MODE="upper"
), upper case
(MODE="lower"
)
or unchanged (default
).--lower, -l
--case=lower
.--output=FILE, -o FILE
-
, i.e. the
standard output.-u, --upper
--case=upper
.Alias - see rose suite-gcontrol
Alias - see rose suite-log
rose stem [options]
Run a suitable suite with a specified set of source tree(s).
Default values of some of these settings are suite-dependent, specified
in the rose-suite.conf
file.
EXAMPLES
rose stem --group=developer
rose stem --source=/path/to/source --source=/other/source --group=mygroup
rose stem --source=foo=/path/to/source --source=bar=fcm:bar_tr@head
OPTIONS
All options of rose suite-run are supported. Additional options are:
--source=SOURCE, -s SOURCE, --source=PROJECT=SOURCE, -s PROJECT=SOURCE
--source
arguments. The project which is
associated with a given source is normally automatically determined
using FCM, however the project can be specified by putting the
project name as the first part of this argument separated by an
equals sign as in the third example above.
Defaults to .
if not specified.--group=GROUP[,GROUP2[,...]], -g GROUP[,GROUP2[,...]]
--group
arguments. The suite will then convert the
groups into a series of tasks to run..--task=TASK[,TASK2[,...]], -t TASK[,TASK2[,...]]
--group
.JINJA2 VARIABLES
Note that <project>
refers to the FCM keyword name of the repository in
upper case.
HOST_SOURCE_<project>
host:/path/wc
.HOST_SOURCE_<project>_BASE
fcm-make
config files. Working
copies in this list have their hostname prefixed.RUN_NAMES
SOURCE_<project>
HOST_
variable of similar name, paths to working copies do NOT
include the host name.SOURCE_<project>_BASE
fcm-make
config files. Unlike
the HOST_
variable of similar name, paths to working copies do NOT
include the host name.SOURCE_<project>_REV
fcm-make
config files.rose suite-clean [OPTIONS] [SUITE-NAME [...]]
Remove items created by “rose suite-run”.
If no argument is specified, use the base-name of $PWD
as suite name.
Correctly remove runtime directories created by rose suite-run including those on remote job hosts.
OPTIONS
--name=NAME, -n NAME
NAME
to the argument list.--non-interactive, --yes, -y
--only=ITEM
--only=ITEM
option is specified, only files and/or
directories matching an ITEM
will be removed. An ITEM
should be a
glob pattern (bash extglob) for matching a relative path in the run
directory of the suite(s).--quiet, -q
--verbose, -v
DIAGNOSTICS
Return the difference between the number of arguments and number of successfully cleaned suites, i.e. 0 if all successful.
rose suite-cmp-vc NAME
rose suite-cmp-vc --name=NAME
# If CYLC_SUITE_NAME is exported, compare source info of the current
# suite from within a suite task if no name is specified.
rose suite-cmp-vc
Compare VCS information of a suite source between installation and now.
Version control system information of a suite is installed under log/rose-suite-run.version file. This command attempts to regenerate the information from the recorded source, and compare the original file with the latest information.
Return 0 if no difference. Print unified diff and return 1 if difference found. Return 2 on other errors.
ARGUMENTS
OPTIONS
--name=NAME, -n NAME
--quiet, -q
--verbose, -v
rose suite-gcontrol [OPTIONS] [--name=SUITE-NAME] [-- EXTRA-ARGS ...]
Launch suite engine’s suite control GUI for a suite.
If --name=SUITE-NAME
is not specified, the name will be determined by
locating a rose-suite.conf
file in $PWD
or its nearest parent
directories. In a normal suite, the basename of the (nearest parent)
directory containing the rose-suite.conf
file is assumed to be the
suite name. In a project containing a rose stem suite, the basename of
the (nearest parent) directory containing the rose-stem/rose-suite.conf
file is assumed to be the suite name.
This wrapper is to deal with the use case where a suite may be running on dedicated servers at a site. The wrapper will make an attempt to detect where the suite is running or last run.
OPTIONS
--all
--name=SUITE-NAME
--quiet, -q
--verbose, -v
# Cylc interface
rose suite-hook [OPTIONS] EVENT SUITE MSG
rose task-hook [OPTIONS] EVENT SUITE TASK_ID MSG
Deprecated. Use cylc built-in event handlers instead.
Provide a common event hook for cylc suites and tasks.
--mail
specified.--shutdown
specified.OPTIONS
--debug
--mail-cc=LIST
--mail
option is specified. Specify a
comma separated list of additional addresses to email.--mail
--retrieve-job-logs
--shutdown
--quiet, -q
--verbose, -v
Alias - see rose suite-run
1. rose suite-log [--view]
2. rose suite-log --update [ITEM ...]
rose suite-log --update '*' # all task jobs
3. rose suite-log --archive CYCLE ...
rose suite-log --archive '*' # all cycles
View or update suite log.
If --name=SUITE-NAME
is not specified, the name will be determined by
locating a rose-suite.conf
file in $PWD
or its nearest parent
directories. In a normal suite, the basename of the (nearest parent)
directory containing the rose-suite.conf
file is assumed to be the
suite name. In a project containing a rose stem suite, the basename of
the (nearest parent) directory containing the rose-stem/rose-suite.conf
file is assumed to be the suite name.
OPTIONS
--archive
--update
.--force, -f
rose suite-log --update '*'
.--name=SUITE-NAME, -n SUITE-NAME
$PWD
.--prune-remote
--tidy-remote
--prune-remote
instead.--update, -U
--user=USER-NAME, -u USER-NAME
--view
Alias - see rose suite-log
rose suite-restart [OPTIONS] [[--] CYLC-RESTART-ARGS]
# Restart cylc suite with name equal to basename of $PWD.
rose suite-restart
# Restart cylc suite NAME
rose suite-restart --name=NAME
# Restart cylc suite NAME with a given state dump
rose suite-restart --name=NAME -- state.20141118T161121.195326Z
# Restart cylc suite NAME on given host
rose suite-restart --name=NAME --host=my-suite-host
Restart a shutdown suite from its last known state without reinstalling it.
If re-installation is required, use rose suite-run --restart
.
ARGUMENTS
OPTIONS
--host=HOST
--name=NAME, -n NAME
NAME
in cylc, instead of using the basename of
the current working directory.--no-gcontrol
cylc gui
. Default is to run cylc gui
if the suite is
running and the DISPLAY
environment variable is defined.--quiet, -q
--verbose, -v
rose suite-run [OPTIONS] [[--] CYLC-RUN-ARGS]
# Install and run a Cylc suite in $PWD.
rose suite-run
# As above, but start the suite in simulation mode.
rose suite-run -- --mode=simulation
# Install and run the suite in $PWD, and register it as "my.suite".
rose suite-run -n my.suite
# Install and run suite in "/dir/to/my.suite".
# Equivalent to (cd /dir/to/my.suite && rose suite-run).
rose suite-run -C /dir/to/my.suite
Install and run a Cylc suite.
Install a suite (in $PWD
), register it in Cylc using the basename of
the configuration directory or the option specified in --name=NAME
.
Invoke cylc run
on it. Arguments (and options after --
) are passed
to cylc run
.
OPTIONS
--config=DIR, -C DIR
$PWD
)--define=[SECTION]KEY=VALUE, -D [SECTION]KEY=VALUE
[SECTION]KEY
setting with a given
VALUE
. Can be used to disable a setting using the syntax
--define=[SECTION]!KEY
or even --define=[!SECTION]
.
See also --define-suite
.--define-suite=KEY=VALUE, -S KEY=VALUE
--define
, but with an implicit [SECTION]
for suite variables.--host=HOST
--install-only, -i
--no-gcontrol
.--local-install-only, -l
--validate-suite-only
--log-keep=DAYS
--log-name=NAME
in previous runs) will not be housekept.--log-name=NAME
log.NAME
to point to the
log directory of the current run. Named log directories will not be
automatically archived or housekept. Only works with --run=run
.--name=NAME, -n NAME
NAME
in Cylc, instead of using the basename of
the configuration directory.--new, -N
rose suite-clean -y && rose suite-run
and will remove
previous runs. Users may want to take extra care when using this
option.--no-gcontrol
cylc gui
. Default is to run cylc gui
if the suite is
running and the DISPLAY
environment variable is defined.--no-log-archive
--no-overwrite
--no-strict
--opt-conf-key=KEY, -O KEY, --opt-conf-key='(KEY)', -O '(KEY)'
KEY
. The configurations are applied first-to-last. The (KEY)
syntax denotes an optional configuration that can be missing.
Otherwise, the optional configuration must exist.--quiet, -q
--reload
--run=reload
.--restart
--run=restart
.--run=reload|restart|run
cylc reload|restart|run
according to this option.
(default=run
)--verbose, -v
ENVIRONMENT VARIABLES
rose suite-run provides the following environment variables to the suite.
ROSE_ORIG_HOST
optional ROSE_SUITE_OPT_CONF_KEYS
KEY
in this space delimited list switches on an optional
configuration. The configurations are applied first-to-last.SUITE VARIABLES
[jinja2:suite.rc]
or [empy:suite.rc]
section.SEE ALSO
cylc help gui
cylc help register
cylc help run
rose suite-scan [...]
Run cylc scan [...]
.
rose suite-shutdown [OPTIONS] [--name=SUITE-NAME] [[--] EXTRA-ARGS ...]
Shutdown a running suite.
If --name=SUITE-NAME
is not specified, the name will be determined by
locating a rose-suite.conf
file in $PWD
or its nearest parent
directories. In a normal suite, the basename of the (nearest parent)
directory containing the rose-suite.conf
file is assumed to be the
suite name. In a project containing a rose stem suite, the basename of
the (nearest parent) directory containing the rose-stem/rose-suite.conf
file is assumed to be the suite name.
This wrapper also deals with the use case where a suite may be running on dedicated servers at a site. The wrapper will make an attempt to detect where the suite is running or last run.
OPTIONS
--all
--name=SUITE-NAME
--non-interactive, --yes, -y
--quiet, -q
--verbose, -v
-- --EXTRA-ARGS
EXTRA-ARGS
.Alias - see rose suite-shutdown
rose task-env [OPTIONS]
eval $(rose task-env)
Provide an environment for cycling suite task.
Print KEY=VALUE
of the following to the STDOUT:
ROSE_SUITE_DIR
ROSE_SUITE_DIR_REL
$HOME
.ROSE_SUITE_NAME
ROSE_TASK_NAME
ROSE_TASK_CYCLE_TIME
ROSE_CYCLING_MODE
ROSE_TASK_LOG_ROOT
ROSE_DATA
ROSE_DATAC
ROSE_DATAC????
The path to the data directory of the cycle time with an offset
relative to the current cycle time. ????
is a duration:
A __
(double underscore) prefix denotes a cycle time in the
future (because a minus sign cannot be used in an environment
variable). Otherwise, it is a cycle time in the past.
The rest should be either an ISO 8601 duration, such as:
P2W
- 2 weeksPT12H
- 12 hoursP1DT6H
- 1 day, 6 hoursP4M
- 4 monthsPT5M
- 5 minutesOr, for the case of integer cycling suites:
P1
- 1 cycle before the current cycleP5
- 5 cycles before the current cycleDeprecated syntax:
nW
denotes n
weeks.n
or nD
denotes n
days.Tn
or TnH
denotes n
hours.TnM
denotes n
minutes.TnS
denotes s
seconds.E.g. ROSE_DATACPT6H
is the data directory of 6 hours before the
current cycle time.
E.g. ROSE_DATACP1D
and ROSE_DATACPT24H
are both the data
directory of 1 day before the current cycle time.
ROSE_ETC
ROSE_TASK_PREFIX
ROSE_TASK_SUFFIX
OPTIONS
--cycle=TIME, -t TIME
TIME
can be in an ISO date/time format,
CCYYMMDDhh
(deprecated) date/time format, or a TIME-DELTA
string
described in the --cycle-offset=TIME-DELTA
option.--cycle-offset=TIME-DELTA, -T TIME-DELTA
Specify one or more cycle offsets to determine what
ROSE_DATAC????
environment variables to export. The TIME-DELTA
argument uses the syntax explained above in the ROSE_DATAC????
environment variable.
E.g. --cycle-offset=PT3H --cycle-offset=PT6H
will tell
rose task-env to export ROSE_DATACPT3H
and ROSE_DATACPT6H
.
Note
The main usage of this option is to reference a cycle time in the past, so a positive offset is used to go backward in time, and a negative offset is used to go forward in time.
E.g. --cycle-offset=-PT3H
will tell rose task-env to export
ROSE_DATAC__PT3H
for ROSE_DATAC
of 3 hours ahead of the current
cycle time.
--path=[NAME=]PATTERN, -P [NAME=]PATTERN
NAME
(or PATH
if NAME
is not
specified).
If a relative path is given, it is relative to $ROSE_SUITE_DIR
. An
empty value resets the default and any previous --path=PATTERN
settings.
(Default for PATH
is "share/fcm[_-]make*/*/bin"
and
"work/fcm[_-]make*/*/bin"
)--prefix-delim=DELIMITER
_
)--suffix-delim=DELIMITER
_
)--quiet, -q
--verbose, -v
USAGE IN SUITES
rose task-env
can be used to make environment variables available to a
suite by defining its suite.rc
env-script
option as
env-script = eval $(rose task-env)
.
Alias - see rose suite-hook
rose task-run [OPTIONS] [--] [APP-COMMAND ...]
Provide an environment to run a suite task.
Provides environment variables documented in rose task-env. It is worth noting that if the environment variables are already provided by rose task-env, this command will not override them.
Normally, the suite task will select a Rose application configuration
that has the same name as the task. This can be overridden by the
--app-key=KEY
option or the ROSE_TASK_APP
environment variable.
OPTIONS
All options of rose app-run and rose task-env are supported. Additional options are:
--app-key=KEY
ENVIRONMENT VARIABLES
All environment variables of rose app-run and rose task-env are supported. All environment variables documented in rose task-env are passed to the application rose task-run runs. The following environment variables are used by rose task-run:
ROSE_TASK_APP
SEE ALSO
rose test-battery
Run Rose self tests.
Change directory to Rose source tree, and runs this shell command:
exec prove -j "$NPROC" -s -r "${@:-t}"
where NPROC
is the number of processors on your computer (or the
setting [t]prove-options
in the site/user configuration file). If you
do not want to run the full test suite, you can specify the names of
individual test files or their containing directories as extra arguments.
EXAMPLES
# Run the full test suite with the default options.
rose test-battery
# Run the full test suite with 12 processes.
rose test-battery -j 12
# Run only tests under "t/rose-app-run/" with 12 processes.
rose test-battery -j 12 t/rose-app-run
# Run only "t/rose-app-run/07-opt.t" in verbose mode.
rose test-battery -v t/rose-app-run/07-opt.t
SEE ALSO
prove(1)
# Print list of available suites.
rose tutorial
# Copy SUITE to DIR (defaults to ~/cylc-run/SUITE).
rose tutorial SUITE [DIR]
Make a copy of one of the tutorial SUITE in the cylc-run directory.
rosie checkout [OPTIONS] ID ...
Checkout local copies of suites.
For each ID
in the argument list, checkout a working copy of the suite
identified by ID
to the standard location.
OPTIONS
--force, -f
ID
already exists, remove
it. Continue to the next ID
if checkout of a suite fails.--quiet, -q
--verbose, -v
Alias - see rosie checkout
Alias - see rosie create
rosie create [OPTIONS]
rosie copy [OPTIONS] FROM-ID
Create a new suite, and optionally copy items from an existing one.
Assign an ID
and create the directory structure in the central
repository for a new suite.
The location of the repository for the new suite is determined in order of preference:
--prefix=PREFIX
optionFROM-ID
[rosie-id]prefix-default
option in the site/user configuration.If FROM-ID
is specified, copy items from the existing suite FROM-ID
when the suite is created. It is worth noting that revision history of
the copied items can only be preserved if FROM-ID
is in the same
repository of the new suite.
The syntax of the FROM-ID is PREFIX-xxNNN[/BRANCH][@REV] (e.g. my-su173, my-su173/trunk, my-su173/trunk@HEAD). If REV is not specified, the last changed revision of the branch is used. If BRANCH is not specified, “trunk” is used.
OPTIONS
--info-file=FILE
FILE
containing the discovery information for the
new suite. If FILE
is -
, read from STDIN. The default behaviour
is to open an editor to add suite discovery information.--meta-suite
--no-checkout
--non-interactive, --yes, -y
--prefix=PREFIX
--project=PROJECT
--quiet, -q
--verbose, -v
rosie delete [OPTIONS] [--] [ID ...]
Delete suites.
Check the standard working copy location for a checked out suite
matching ID
and remove it if there is no uncommitted change (or if
--force
is specified).
Delete the suite directory structure from the HEAD of the central
repository matching the ID
.
If no ID
is specified and $PWD
is a working copy of a suite, use the
ID
of the suite in the working copy.
OPTIONS
--force, -f
ID
if delete of a suite fails.--local-only
--non-interactive, --yes, -y
--quiet, -q
--verbose, -v
rosie disco start [PORT] # start ad-hoc web service server (on PORT)
rosie disco stop # stop ad-hoc web service server
rosie disco stop -y # stop ad-hoc web service server w/o prompting
rosie disco # print status of ad-hoc web service server
Start/stop ad-hoc Rosie suite discovery web service server.
For rosie disco start
, if PORT
is not specified, use port 8080.
OPTIONS
--non-interactive, --yes, -y
--service-root, -R
rosie go [OPTIONS] [...]
Launch the Rosie client GTK+ GUI.
If arguments are specified, rosie go will perform an initial lookup based on the arguments, which can be an address, a query, or search words. See rosie lookup for detail.
Unless an option is used to specify the initial search type the argument is interpreted as follows:
An address URL may contain shell meta characters, so remember to put it in quotes.
Search strings may contain SQL wildcard characters. E.g.
%
(percent) is a substitute for zero or more characters._
(underscore) is a substitute for a single character.If no argument is specified, rosie go will display a list of all your locally checked out suites.
OPTIONS
--address-mode, --url, -A, -U
--lookup-mode=address
.--all-revs
--lookup-mode=MODE
MODE
can be address
, query
or
search
.--prefix=PREFIX
--query, -Q
--lookup-mode=query
.--search, -S
--lookup-mode=search
.SEE ALSO
rosie graph [OPTIONS] [ID]
Graph suite copy ancestry.
OPTIONS
--distance=DISTANCE, -d DISTANCE
ID
to be plotted. For example, if the distance is 1, only the
parents and children (but not siblings) of ID
will be plotted.
If not given, this is unlimited. Requires ID
to be specified.--output=FILE, -o FILE
--prefix=PREFIX
--text
Print parent and child suites of a suite ID
. For example, for a
suite “bar” you may get results like:
[parent] foo
[child1] baz
[child1] qux
[child2] quux
[child3] corge
where “foo” is the parent of “bar”, “baz” and “qux” its first
generation children, “quux” its second generation child and “corge”
its third generation child. Also supports use of the --property
option for producing output. Requires ID
to be specified.
--property=PROPERTY, -p PROPERTY
ARGUMENTS
ID
rosie hello [--prefix=PREIFX]
Set up connection to one or more Rosie web service servers.
OPTIONS
--prefix=PREFIX
rosie id [OPTIONS]
# Print the repository URL of a given suite ID
rosie id --to-origin mo1-abc45
# Print the local location of a given suite ID
rosie id --to-local-copy mo1-abc45
# Print the output directory of a given suite ID
rosie id --to-output mo1-abc45
# Print the web URL of a given suite ID
rosie id --to-web mo1-abc45
# Print suite ID of working copy in $PWD
rosie id
# Print suite ID of working copy in a directory
rosie id /path/to/working/copy
# Print suite ID of a given URL
rosie id svn://fcm1/rose_mo1_svn/a/b/c/4/5
# Print latest suite ID in the default repository
rosie id --latest
# Print latest suite ID in the given repository
rosie id --latest mot
# Print next suite ID in the default repository
rosie id --next
Utility for working with suite IDs.
OPTIONS
--latest
--to-local-copy
--to-origin
--to-output
--to-web
--next
rosie lookup [OPTIONS] LOOKUP-TEXT ...
Find suites in the suite discovery database.
Search for suites using an address, a query or search words and display the information of the matching suites.
Unless an option is used to specify the initial search type the argument is interpreted as follows:
An address URL may contain shell meta characters, so remember to put it in quotes.
The default output format includes a local working copy status field
(%local
) in the first column.
=
means that the suite is checked out at this branch and revision.<
means that the suite is checked out but at an older revision.>
means that the suite is checked out but at a newer revision.S
means that the suite is checked out but on a different branch.M
means that the suite is checked out and modified.X
means that the suite is checked out but is corrupted.Search strings may contain SQL wildcard characters. E.g:
%
(percent) is a substitute for zero or more characters._
(underscore) is a substitute for a single character.OPTIONS
--address-mode, --url, -A, -U
--lookup-mode=address
.--all-revs
--no-headers, -H
--lookup-mode=MODE
MODE
can be address
, query
or
search
.--prefix=PREFIX
--print-format=FORMAT, --format=FORMAT, -f FORMAT
%
.
For example: rosie lookup daisy --format="%idx from %owner"
might give: abc01 from daisy
--query, -Q
--lookup-mode=query
.--quiet, -q
--format="%idx
.--reverse, -r
--search, -S
--lookup-mode=search
.--sort=FIELD, -s FIELD
FIELD
instead of revision.--verbose, -v
rosie ls [OPTIONS]
List the local suites.
Search for locally checked out suites and print their details.
The default format includes a local working copy status field (%local
)
in the first column.
A blank field means there is no related suite checked out.
=
means that the suite is checked out at this branch and revision.<
means that the suite is checked out but at an older revision.>
means that the suite is checked out but at a newer revision.S
means that the suite is checked out but on a different branch.M
means that the suite is checked out and modified.X
means that the suite is checked out but is corrupted.OPTIONS
--prefix=PREFIX
--no-headers, -H
--print-format=FORMAT, --format=FORMAT, -f FORMAT
%
.
For example: rosie ls --format="%idx from %owner"
might give: abc01 from daisy
--quiet, -q
--format="%idx"
.--reverse, -r
--sort=FIELD, -s FIELD
FIELD
instead of revision.--user=~USERNAME, -u ~USERNAME
--user=~bob
--verbose, -v