From 21d613f250324731ffe55988874b3b07df2a996e Mon Sep 17 00:00:00 2001 From: Oliver Sanders Date: Wed, 13 Nov 2024 13:33:05 +0000 Subject: [PATCH] remove empy support * See https://github.com/cylc/cylc-flow/issues/6458 --- .../major-changes/compatibility-mode.rst | 2 +- src/7-to-8/major-changes/config-changes.rst | 2 +- src/7-to-8/major-changes/template-vars.rst | 8 +-- src/dictionaries/proper_nouns | 2 - src/glossary.rst | 3 +- src/hyperlinks.rst.include | 1 - src/installation.rst | 3 - src/plugins/install/index.rst | 4 +- src/reference/changes.rst | 22 +++++++ src/user-guide/troubleshooting.rst | 2 +- .../writing-workflows/configuration.rst | 10 ++-- src/user-guide/writing-workflows/empy.rst | 58 ------------------- src/user-guide/writing-workflows/index.rst | 1 - .../writing-workflows/parameterized-tasks.rst | 4 +- src/user-guide/writing-workflows/runtime.rst | 2 +- src/workflows/empy/cities/flow.cylc | 52 ----------------- 16 files changed, 39 insertions(+), 137 deletions(-) delete mode 100644 src/user-guide/writing-workflows/empy.rst delete mode 100644 src/workflows/empy/cities/flow.cylc diff --git a/src/7-to-8/major-changes/compatibility-mode.rst b/src/7-to-8/major-changes/compatibility-mode.rst index 2d19dea4028..ac83959324c 100644 --- a/src/7-to-8/major-changes/compatibility-mode.rst +++ b/src/7-to-8/major-changes/compatibility-mode.rst @@ -59,7 +59,7 @@ See :ref:`below ` for an example. ``cylc validate`` operates on the processed ``suite.rc``, which means it will not detect any deprecated syntax that is inside a - currently-unused Jinja2/EmPy ``if...else`` branch. + currently-unused Jinja2 ``if...else`` branch. Some workflows may require modifications to either upgrade to Cylc 8 or make interoperable with Cylc 8 backward compatibility mode. Read on for more details. diff --git a/src/7-to-8/major-changes/config-changes.rst b/src/7-to-8/major-changes/config-changes.rst index ea304c2c28a..18bdfdd4b3b 100644 --- a/src/7-to-8/major-changes/config-changes.rst +++ b/src/7-to-8/major-changes/config-changes.rst @@ -9,7 +9,7 @@ The old configurations are now deprecated, but still supported. These will be highlighted upon ``cylc validate`` after renaming ``suite.rc`` to ``flow.cylc``. -Because some workflows use Jinja2 or EmPy branches which may not be switched on at +Because some workflows use Jinja2 branches which may not be switched on at the time of the initial ``cylc validate`` we have also provided a script, :ref:`cylc lint -r 728 ` to check for Cylc 7 syntax which may be deprecated. diff --git a/src/7-to-8/major-changes/template-vars.rst b/src/7-to-8/major-changes/template-vars.rst index a97836badaf..70cedae1cee 100644 --- a/src/7-to-8/major-changes/template-vars.rst +++ b/src/7-to-8/major-changes/template-vars.rst @@ -7,16 +7,16 @@ Template Variables Read this section if you set Cylc template variables on the command line using the ``-s``, ``--set`` or ``-set-file`` options. - This does *not* affect the Rose ``jinja2:suite.rc`` and - ``empy:suite.rc`` variables set using the ``-S`` option to the + This does *not* affect the Rose ``jinja2:suite.rc`` + variables set using the ``-S`` option to the ``rose suite-run`` command. Overview -------- -Template variables are passed to :ref:`Jinja2 ` or -:ref:`EmPy ` for parsing the workflow definition in the +Template variables are passed to :ref:`Jinja2 ` +for parsing the workflow definition in the :cylc:conf:`flow.cylc` file. In Cylc 7 template variables could only be strings, in Cylc 8 they can be any diff --git a/src/dictionaries/proper_nouns b/src/dictionaries/proper_nouns index 51eb2e38618..6fb92533189 100644 --- a/src/dictionaries/proper_nouns +++ b/src/dictionaries/proper_nouns @@ -8,8 +8,6 @@ Conda Cylc cylc Datapoint -Empy -EmPy Exeter Gantt Gedit diff --git a/src/glossary.rst b/src/glossary.rst index bd1aaa8b348..023825673a3 100644 --- a/src/glossary.rst +++ b/src/glossary.rst @@ -1266,8 +1266,7 @@ Glossary tasks. Other ways of consolidating configuration include :term:`runtime - inheritance` and templating with :ref:`Jinja2 ` or :ref:`Empy - `. + inheritance` and templating with :ref:`Jinja2 `. .. code-block:: cylc diff --git a/src/hyperlinks.rst.include b/src/hyperlinks.rst.include index 9a22b11f2ee..e1a6ea728a8 100644 --- a/src/hyperlinks.rst.include +++ b/src/hyperlinks.rst.include @@ -9,7 +9,6 @@ .. _Cylc Discourse Forum (7-to-8 topic): https://cylc.discourse.group/c/cylc/7-to-8/13 .. _DataPoint: https://www.metoffice.gov.uk/services/data/datapoint .. _Discourse: https://cylc.discourse.group/ -.. _EmPy: https://pypi.org/project/empy/ .. _FCM User Guide: http://metomi.github.io/fcm/doc/user_guide/ .. _FCM: https://metomi.github.io/fcm/doc/ .. _INI: https://en.wikipedia.org/wiki/INI_file diff --git a/src/installation.rst b/src/installation.rst index 0b72501bf98..11fb29a9422 100644 --- a/src/installation.rst +++ b/src/installation.rst @@ -69,9 +69,6 @@ install: .. code-block:: sub - # EmPy support - $ pip install 'cylc-flow[empy]' - # Support for running the tutorial workflows $ pip install 'cylc-flow[tutorial]' diff --git a/src/plugins/install/index.rst b/src/plugins/install/index.rst index 335c07b3c4f..ea313e127b1 100644 --- a/src/plugins/install/index.rst +++ b/src/plugins/install/index.rst @@ -99,10 +99,10 @@ following keys: A dictionary of environment variables to be exported to the scheduler environment. ``template_variables`` - A dictionary of template variables to be used by Jinja2 or EmPy when + A dictionary of template variables to be used by Jinja2 when templating the workflow configuration files. ``templating_detected`` - ``jinja2`` | ``empy`` to be used when templating. N.b: This will result in + ``jinja2`` to be used when templating. N.b: This will result in failure if the templating language set does not match the shebang line of the ``flow.cylc`` file. diff --git a/src/reference/changes.rst b/src/reference/changes.rst index 0138bd8c26d..23595584d33 100644 --- a/src/reference/changes.rst +++ b/src/reference/changes.rst @@ -22,6 +22,28 @@ For more detail see the component changelogs: ---------- + +Cylc 8.4 +-------- + +.. TODO - fix before release + + .. admonition:: Cylc Components + :class: hint + + :cylc-flow: `8.3 `__ + :cylc-ui: `2.5 `__ + :cylc-uiserver: `1.5 `__ + :cylc-rose: `1.4 `__ + :rose: `2.3 `__ + +EmPy Support Removed +^^^^^^^^^^^^^^^^^^^^ + +Support for the EmPy template processor (an alternative to Jinja2) has been +removed. + + Cylc 8.3 -------- diff --git a/src/user-guide/troubleshooting.rst b/src/user-guide/troubleshooting.rst index 57897507c2f..7e7f7a0a5a0 100644 --- a/src/user-guide/troubleshooting.rst +++ b/src/user-guide/troubleshooting.rst @@ -494,7 +494,7 @@ workflows: ``cylc view`` Prints workflow configurations before full parsing by Cylc. This can include :ref:`Jinja2 ` (use ``-j``) - or Empy template processing. + processing. Include files can be inlined (use ``-i``). diff --git a/src/user-guide/writing-workflows/configuration.rst b/src/user-guide/writing-workflows/configuration.rst index a02c64ede1d..7733a65790d 100644 --- a/src/user-guide/writing-workflows/configuration.rst +++ b/src/user-guide/writing-workflows/configuration.rst @@ -19,10 +19,8 @@ The configurations you can use are documented in :ref:`workflow-configuration`. .. _template processors: https://en.wikipedia.org/wiki/Template_processor -Cylc also supports two `template processors`_ for use in the ``flow.cylc`` file: - -* `Jinja2`_ -* `EmPy`_ +Cylc also supports the `Jinja2`_ `template processor