From 37c59b068770b17787ddd6b86ff24d91973ef0e9 Mon Sep 17 00:00:00 2001 From: mcflugen Date: Tue, 5 Nov 2024 10:55:09 +0000 Subject: [PATCH] add sidl/python language tabs to control functions --- docs/source/bmi.control_funcs.rst | 70 +++++++++++++++++++++++++------ 1 file changed, 58 insertions(+), 12 deletions(-) diff --git a/docs/source/bmi.control_funcs.rst b/docs/source/bmi.control_funcs.rst index d715e6d..24749d0 100644 --- a/docs/source/bmi.control_funcs.rst +++ b/docs/source/bmi.control_funcs.rst @@ -15,11 +15,22 @@ updating. *initialize* ^^^^^^^^^^^^ -.. code-block:: java +.. tab-set:: + :sync-group: lang - /* SIDL */ - int initialize(in string config_file); + .. tab-item:: SIDL + :sync: sidl + .. code-block:: java + + int initialize(in string config_file); + + .. tab-item:: Python + :sync: python + + .. code-block:: python + + def initialize(self, config_file: str) -> None: The `initialize` function accepts a string argument that gives the path to its :term:`configuration file`. @@ -48,10 +59,22 @@ formatted. *update* ^^^^^^^^ -.. code-block:: java +.. tab-set:: + :sync-group: lang + + .. tab-item:: SIDL + :sync: sidl + + .. code-block:: java + + int update(); + + .. tab-item:: Python + :sync: python + + .. code-block:: python - /* SIDL */ - int update(); + def update(self) -> None: The `update` function advances the model by a single time step. This is the model's own internal time step (as returned by the BMI @@ -75,10 +98,22 @@ function can just return without doing anything. *update_until* ^^^^^^^^^^^^^^ -.. code-block:: java +.. tab-set:: + :sync-group: lang - /* SIDL */ - int update_until(in double time); + .. tab-item:: SIDL + :sync: sidl + + .. code-block:: java + + int update_until(in double time); + + .. tab-item:: Python + :sync: python + + .. code-block:: python + + def update_until(self, time: float) -> None: The `update_until` function updates the model to a particular time, as provided by its *time* argument. @@ -101,11 +136,22 @@ to reflect that the model was updated to the requested time. *finalize* ^^^^^^^^^^ -.. code-block:: java +.. tab-set:: + :sync-group: lang + + .. tab-item:: SIDL + :sync: sidl + + .. code-block:: java + + int finalize(); + + .. tab-item:: Python + :sync: python - /* SIDL */ - int finalize(); + .. code-block:: python + def finalize(self) -> None: The `finalize` function should perform all tasks that take place after exiting the model's time loop. This typically includes