Skip to content

Commit

Permalink
Feature #2814 develop - doc single config overrides (#2825)
Browse files Browse the repository at this point in the history
* per #2814, add documentation to describe how to set a single config variable on the command line

* fixed typos and formatting issues

* move new content to top of chapter and reword intro sentence

* change label and add link to user env var section

* per #2814, added info and examples for single config overrides with a list of values
  • Loading branch information
georgemccabe authored Dec 16, 2024
1 parent 6dfa458 commit eec37af
Showing 1 changed file with 94 additions and 3 deletions.
97 changes: 94 additions & 3 deletions docs/Users_Guide/systemconfiguration.rst
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,97 @@
Configuration
*************

This chapter is a guide on configuring METplus Wrappers.
This chapter describes how to configure METplus Wrappers.

.. _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 changed 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 provide 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`
or :ref:`user_env_vars` 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**.

Version 6.1.0 added support for setting a list value in single config overrides.

Example::

config.LEAD_SEQ=6H,12H

This will set the value of **[config] LEAD_SEQ** to
a list containing **6H** and **12H**.

If spaces are present in the value, then quotation marks must be used::

config.LEAD_SEQ="6H, 12H"


.. _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 file named *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**.


Config Best Practices / Recommendations
=======================================
Expand Down Expand Up @@ -50,6 +140,7 @@ Config Best Practices / Recommendations
run_metplus.py. This is done to avoid the need to change the default values
after every update.


.. _default_configuration_file:

Default Configuration File
Expand Down Expand Up @@ -163,7 +254,7 @@ METPLOTPY_BASE (user_env_vars)

This is the path to the location where METplotpy is installed.
The variable is found under the [user_env_vars] section heading, which
will set it as an environment variable. See :ref:`user_defined_config`
will set it as an environment variable. See :ref:`user_env_vars`
for more information on the [user_env_vars] section.
This variable is referenced in some METplotpy functions.
It is not necessary to set this variable if METplotpy will not be used or if
Expand Down Expand Up @@ -2861,7 +2952,7 @@ The values must match the format of the variables in the default MET
configuration file with a semi-colon after single values and arrays and curly
braces around dictionaries.

.. _user_defined_config:
.. _user_env_vars:

User Environment Variables
==========================
Expand Down

0 comments on commit eec37af

Please sign in to comment.