Workflow Configuration
The flow.cylc File
Cylc workflows are defined in flow.cylc files that specify the
tasks to be managed by the Cylc scheduler, the dependencies between them,
and the schedules to run time on.
General file syntax is described in the File Format Reference.
Legal configuration settings are documented in Workflow Configuration.
Cylc also supports two template processors for use in the flow.cylc file:
Workflow Configuration Directories
A Cylc source directory contains:
flow.cylcThe file which configures the workflow.
bin/(optional)A directory for scripts and executables used by workflow tasks. It is added to
$PATHin job environments.Jobs can also run scripting defined in the
flow.cylcfile, executables installed to user-defined locations of the workflow run directory, and external executables.lib/python/(optional)A directory for Python modules. It is added to
$PYTHONPATHin the scheduler and job execution environments. It can be used by:Tasks
Custom job submission modules
Custom Jinja2 Filters
Other files and folders may be placed in the source directory too: documentation, configuration files, etc. When the workflow is installed these will be copied over to the run directory.
Note
If your workflow needs to create or install scripts or executables at runtime and you don’t want Cylc to delete them on re-installation, you can use equivalent directories in the Workflow Share Directories.
Syntax Highlighting For Workflow Configuration
Cylc provides syntax plugins for the following editors:
- Atom
install the language-cylc extension.
- Emacs
The syntax file can be obtained from the Cylc library by running the following command
cylc get-resources syntax/cylc-mode.el .installation instructions are at the top of the file.- Gedit
The syntax file can be obtained from the Cylc library by running the following command
cylc get-resources syntax/cylc.lang .installation instructions are at the top of the file.- Kate
The syntax file can be obtained from the Cylc library by running the following command
cylc get-resources syntax/cylc.xml .installation instructions are at the top of the file.- PyCharm
Install the Cylc.tmbundle.
- Vim
The syntax file can be obtained from the Cylc library by running the following command
cylc get-resources syntax/cylc.vim .installation instructions are at the top of the file.- Visual Studio Code
Install the vscode-cylc extension.
- Sublime Text 3
Install the Cylc.tmbundle.
- TextMate
Install the Cylc.tmbundle.
- WebStorm
Install the Cylc.tmbundle.
Gross File Structure
Cylc flow.cylc files consist of configuration items grouped under
several top level section headings:
[meta]Information about the workflow e.g. title and description.
[scheduler]Non task-specific workflow configuration.
[scheduling]Determines when tasks are ready to run.
special scheduling constraints e.g. external triggers.
the dependency graph, which defines the relationships between tasks
[runtime]Determines how, where, and what to execute when tasks are ready
script, environment, job submission, remote hosting, etc.
workflow-wide defaults in the root family
a nested family hierarchy with common properties inherited by related tasks
Validation
The cylc validate command evaluates the flow.cylc file
against a specification that defines all legal entries, values and options.
It also performs some integrity checks designed to catch certain configuration
issues and impossible scheduling constraints.
These checks are also performed by cylc play before starting a workflow.
All legal entries are documented in the flow.cylc reference.
If a flow.cylc file uses include-files cylc view will
show an inlined copy of the workflow with correct line numbers.
cylc lint
Cylc configuration linter.
Checks code style, deprecated syntax and other issues.
Style
S001
Use multiple spaces, not tabs
S002
Item not indented.
S003
Top level sections should not be indented.
S004
Second level sections should be indented exactly 4 spaces.
S005
Third level sections should be indented exactly 8 spaces.
S006
trailing whitespace.
S007
Family name contains lowercase characters.
S008
jinja2 found: no shebang (#!jinja2)
S009
Host Selection Script may be redundant with platform
S010
Using backticks to invoke subshell is deprecated
S011
Cylc will process commented Jinja2!
S012
line > <max_line_len> characters. Max line length set in pyproject.toml (default 130)
S013
Items should be indented in 4 space blocks.
7 to 8 upgrades
U001
[scheduling][dependencies][<recurrence>]graph = -> [scheduling][graph]<recurrence> = ([dependencies] detected)
U002
[scheduling][dependencies][<recurrence>]graph = -> [scheduling][graph]<recurrence> = (graph = detected)
U003
settings in [runtime][<namespace>][remote] have been moved to [runtime][<namespace>] and global.cylc[platforms][<platforms name>]
U004
settings in [runtime][<namespace>][job] have been moved to [runtime][<namespace>] and global.cylc[platforms][<platforms name>]
U005
flow.cylc[runtime][<namespace>][job]batch system -> global.cylc[platforms][<platform name>]job runner
U006
Using backticks to invoke subshell will fail at Cylc 8.
U007
Use built in platform selection instead of rose host-select.
U008
Suicide triggers are not required at Cylc 8.
U009
This line contains an obsolete Cylc CLI command.
U010
rose suite-hook is deprecated at Rose 2,
U011
Leading zeros are no longer valid for Jinja2 integers.
U012
The following environment variables are deprecated:
Deprecated Variable |
New Variable |
|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
U013
The following environment variables are obsolete:
CYLC_SUITE_DEF_PATH_ON_SUITE_HOST
CYLC_SUITE_DEF_PATH
U014
For datetime operations in task scripts:
Use
isodatetimeinstead ofrose dateUse
isodatetime refinstead ofrose date -cfor the current cycle point
Auto Generated 7 to 8 upgrades
Note
U998 and U999 represent automatically generated sets of deprecations and upgrades.
[cylc]force run modeis not available at Cylc 8[cylc][authentication]is not available at Cylc 8[cylc]include at start-upis not available at Cylc 8[cylc]exclude at start-upis not available at Cylc 8[cylc]log resolved dependenciesis not available at Cylc 8[cylc]required run modeis not available at Cylc 8[cylc]health check intervalis not available at Cylc 8[runtime][__MANY__][events]mail retry delaysis not available at Cylc 8[runtime][__MANY__]extra log filesis not available at Cylc 8[runtime][__MANY__][job]shellis not available at Cylc 8[runtime][__MANY__][remote]suite definition directoryis not available at Cylc 8[cylc]abort if any task failsis not available at Cylc 8[cylc]disable automatic shutdownis not available at Cylc 8[cylc][environment]is not available at Cylc 8[cylc][reference test]is not available at Cylc 8[cylc][simulation]disable suite event handlersis not available at Cylc 8[cylc][simulation]is not available at Cylc 8[visualization]is not available at Cylc 8[scheduling]spawn to max active cycle pointsis not available at Cylc 8[cylc]task event mail intervalis now[cylc][mail]task event batch interval[cylc][parameters]is now[task parameters][cylc][parameter templates]is now[task parameters][templates][cylc][events]mail tois now[cylc][mail]to[cylc][events]mail fromis now[cylc][mail]from[cylc][events]mail footeris now[cylc][mail]footer[runtime][__MANY__][events]mail tois now[runtime][__MANY__][mail]to[runtime][__MANY__][events]mail fromis now[runtime][__MANY__][mail]from[cylc][events]mail smtpis not available at Cylc 8[runtime][__MANY__][events]mail smtpis not available at Cylc 8[scheduling]max active cycle pointsis now[scheduling]runahead limit[scheduling]hold after pointis now[scheduling]hold after cycle point[runtime][__MANY__][suite state polling]is now[runtime][__MANY__][workflow state polling][cylc][events]timeoutis now[cylc][events]stall timeout[cylc][events]abort on timeoutis now[cylc][events]abort on stall timeout[cylc][events]inactivityis now[cylc][events]inactivity timeout[cylc][events]abort on inactivityis now[cylc][events]abort on inactivity timeout[cylc][events]startup handleris now[cylc][events]startup handlers[cylc][events]shutdown handleris now[cylc][events]shutdown handlers[cylc][events]timeout handleris now[cylc][events]stall timeout handlers[cylc][events]stalled handleris now[cylc][events]stall handlers[cylc][events]aborted handleris now[cylc][events]abort handlers[cylc][events]inactivity handleris now[cylc][events]inactivity timeout handlers[runtime][__MANY__][events]expired handleris now[runtime][__MANY__][events]expired handlers[runtime][__MANY__][events]late handleris now[runtime][__MANY__][events]late handlers[runtime][__MANY__][events]submitted handleris now[runtime][__MANY__][events]submitted handlers[runtime][__MANY__][events]started handleris now[runtime][__MANY__][events]started handlers[runtime][__MANY__][events]succeeded handleris now[runtime][__MANY__][events]succeeded handlers[runtime][__MANY__][events]failed handleris now[runtime][__MANY__][events]failed handlers[runtime][__MANY__][events]submission failed handleris now[runtime][__MANY__][events]submission failed handlers[runtime][__MANY__][events]warning handleris now[runtime][__MANY__][events]warning handlers[runtime][__MANY__][events]critical handleris now[runtime][__MANY__][events]critical handlers[runtime][__MANY__][events]retry handleris now[runtime][__MANY__][events]retry handlers[runtime][__MANY__][events]submission retry handleris now[runtime][__MANY__][events]submission retry handlers[runtime][__MANY__][events]execution timeout handleris now[runtime][__MANY__][events]execution timeout handlers[runtime][__MANY__][events]submission timeout handleris now[runtime][__MANY__][events]submission timeout handlers[runtime][__MANY__][events]custom handleris now[runtime][__MANY__][events]custom handlers[cylc][events]abort on stalledis not available at Cylc 8[cylc][events]abort if startup handler failsis not available at Cylc 8[cylc][events]abort if shutdown handler failsis not available at Cylc 8[cylc][events]abort if timeout handler failsis not available at Cylc 8[cylc][events]abort if inactivity handler failsis not available at Cylc 8[cylc][events]abort if stalled handler failsis not available at Cylc 8[cylc]is now[scheduler]
Configure cylc lint at project level
You can configure cylc lint for each workflow using a
pyproject.toml file.
To define settings for cylc lint use a [cylc-lint] section.
Within the [cylc-lint] section you may define the following:
- rulesets
A list of rulesets to use. If you run cylc lint without setting rulesets on the command line this value will override the default (
['728', 'style']).Allowed Values: ‘728’, ‘style’
- ignore
Individual rules to ignore: A list of rule codes, such as
S007.- exclude
A list of files or glob patterns for files which will not be checked.
- max-line-length
Set longest line length to permit in Cylc Configs for this project. If unset, line length is not checked.
An example pyproject.toml might look like this:
[cylc-lint]
# Enforce a line limit of 99 chars
max-line-length = 99
# Ignore style [S] rule 007 (It's good practice comment with a reason)
ignore = ['S007'] # Family names start with lowercase in this workflow
# Don't check files matching these globs
exclude = ['history/*.old.cylc', 'someother.cylc']
# By default check for style
rulesets = ['style']
[some-other-section]
# Cylc lint won't pay any attention to this.