Skip to content

MILC config subcommand

This document explains how the available config subcommand works.

Introduction

Configuration for MILC applications is a key/value system. Each key consists of a subcommand and an argument name separated by a period. This allows for a straightforward and direct translation between config keys and the arguments they set. You can provide your users with a subcommand for managing this configuration by importing the config subcommand:

import milc.subcommand.config

Warning

This must be imported after cli.milc_options() is used.

Read on to see how users can utilize this subcommand.

Simple Example

As an example let's look at the command my_cli foo --arg1 bar --arg2 bat.

There are two command line arguments that could be read from configuration instead:

  • foo.arg1
  • foo.arg2

Let's set these now:

$ my_cli config foo.arg1=bar foo.arg2=bat foo.arg1 None -> bar foo.arg2 None -> bat i Wrote configuration to '/Users/example/Library/Application Support/my_cli/my_cli.ini'

Now I can run my_cli foo without specifying --arg1 and --arg2 each time.

Nested Subcommand Example

For a command like my_cli remote add --url https://example.com, the config key uses the full dotted path to the subcommand:

  • remote.add.url
  • remote.add.fetch

$ my_cli config remote.add.url=https://example.com remote.add.url: None -> https://example.com ℹ Wrote configuration to '/Users/example/Library/Application Support/my_cli/my_cli.ini'

Now my_cli remote add will use that URL without needing --url each time.

Setting User Defaults

Sometimes you want to share a setting between multiple subcommands. For example, multiple commands take the argument --arg1. Rather than setting this value for every command you can set a user value which will be used by any command that takes that argument.

Example:

$ my_cli config user.arg1=baz user.arg1: None -> baz ℹ Wrote configuration to '/Users/example/Library/Application Support/my_cli/my_cli.ini'

Subcommand reference (config)

The config subcommand is used to interact with the underlying configuration. When run with no argument it shows the current configuration. When arguments are supplied they are assumed to be configuration tokens, which are strings containing no spaces with the following form:

<section>[.<key>][=<value>]

where <section> is general, user, a top-level subcommand name, or a dotted path for nested subcommands (e.g. remote.add).

Setting Configuration Values

You can set configuration values by putting an equal sign (=) into your config key. The key must always be the full <section>.<key> form.

Example:

$ my_cli config user.arg1=default user.arg1: None -> default ℹ Wrote configuration to '/Users/example/Library/Application Support/my_cli/my_cli.ini'

Reading Configuration Values

You can read configuration values for all set options, the entire configuration, a single key, or for an entire section. You can also specify multiple keys to display more than one value.

All Set Options Example

my_cli config

Entire Configuration Example

my_cli config -a

Whole Section Example

my_cli config general

Single Key Example

my_cli config general.verbose

Multiple Keys Example

my_cli config user general.verbose general.log_format

Deleting Configuration Values

You can delete a configuration value by setting it to the special string None.

Example:

$ my_cli config general.log_format None general.log_format: %H:%M:%S -> None ℹ Wrote configuration to '/Users/example/Library/Application Support/my_cli/my_cli.ini'

Output Colors

The config subcommand uses color to indicate where each value came from:

Color Suffix Meaning
Blue = sign (config) Value was read from the config file
Yellow = sign (env) Value was set by an environment variable (see Environment Variables)
Cyan key=value Varies Value is the argument default or was passed on the CLI

Multiple Operations

You can combine multiple read and write operations into a single command. They will be executed and displayed in order:

$ my_cli config foo user.arg1=default foo.arg2=None foo.arg3=peep user.arg1: None -> default foo.arg2: bar -> None ℹ Wrote configuration to '/Users/example/Library/Application Support/my_cli/my_cli.ini'