Skip to content

Commit

Permalink
per #2814, add documentation to describe how to set a single config v…
Browse files Browse the repository at this point in the history
…ariable on the command line
  • Loading branch information
georgemccabe committed Dec 11, 2024
1 parent 75476cd commit add0379
Showing 1 changed file with 73 additions and 0 deletions.
73 changes: 73 additions & 0 deletions docs/Users_Guide/systemconfiguration.rst
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,79 @@ Config Best Practices / Recommendations
run_metplus.py. This is done to avoid the need to change the default values
after every update.

.. _how_to_configure:

How to Configure
================

The settings of a METplus wrappers run are controlled by METplus
configuration variables.

All variables in the :ref:`default_configuration_file` are read first.
Variables in the :ref:`default_configuration_file` can be changes from the
default values to be applied to every run.

Additional configuration variables are set using command line arguments to the
**run_metplus.py** script.
Arguments to the script can be the path to a METplus configuration file that
defines multiple configuration variables or a key/value pair that sets a single
configuration variable.

One or more :ref:`use_case_configuration_files` define settings for a given
METplus run.
Users often create a :ref:`user_configuration_file` to store settings specific
to the system on which they are running and their personal preferences.
It is recommended to provided a user configuration file *after* any use case
specific configuration files in the command line argument list
(see :ref:`order_matters`).

.. _single_config:

How to Set a Single Config
--------------------------

Single configuration variable overrides should match the format
**<SECTION>.<VARIABLE>=<VALUE>** where:
* **<SECTION>** is the section within the METplus configuration.
This is typically *config* unless :ref:`process_list_instance_names` are used
* **<VARIABLE>** is the name of the configuration variable to set
* **<VALUE>** is the value to set

Example::

config.OUTPUT_BASE = /my/output/dir

This will set the value of the variable **OUTPUT_BASE** of the **[config]**
section to **/my/output/dir**.

.. _order_matters:

Order Matters
-------------

The order in which the arguments are provided matters. If a configuration
variable is defined multiple times, each subsequent instance of that variable
will override the previous value. This means that the last value will be used.

Example:

If a .conf file called *my_lead.conf* contains::

[config]
LEAD_SEQ = 12H

and the conf file is provided before the single config override::

run_metplus.py my_lead.conf config.LEAD_SEQ=6H

then the value of **[config] LEAD_SEQ** will be 6H.

However, if the conf file is provided after the single config override::

run_metplus.py config.LEAD_SEQ=6H my_lead.conf

then the value of **[config] LEAD_SEQ** will be 12H.

.. _default_configuration_file:

Default Configuration File
Expand Down

0 comments on commit add0379

Please sign in to comment.