Skip to main content

I/O facility for Idefix/Pluto configuration files

Project description

inifix

PyPI PyPI codecov pre-commit.ci status Code style: black Imports: isort

inifix in a small Python library with I/O methods to read and write Pluto/Idefix inifiles as Python dictionaries.

Its primary goal is to support Idefix's model (which is intended as identical to Pluto's), but it has enough flexibility to support other (section-free) configuration files.

File format specifications

  • parameter names are strings
  • parameter names and values are separated by white spaces
  • values can be an integers, floats, booleans, or strings
  • a parameter can be associated to a single value or a set of space-separated value
  • optionally, the file can be separated into sections, whose names match this regexp "$[\.+]"
  • comments start with # and are ignored

Using the following Python's typing notations

from typing import Union, Mapping
Scalar = Union[str, float, bool, int]
InifixConf = Mapping[str, Union[Scalar, Mapping[str, Scalar]]

A configuration file is considered valid if it can be parsed as an InifixConf object.

Examples

The following content is considered valid

# My awesome experiment
[Grid]
x   1 2 "u" 10    # a comment
y   4 5 "l" 100
[Time Integrator]
CFL  1e-3
tstop 1E3

and maps to

{
    "Grid": {
        "x": [1, 2, "u", 10],
        "y": [4, 5, "l", 100]
    },
    "Time Integrator": {
        "CFL": 0.001,
        "tstop": 1000
    }
}

The following is also considered valid

mode   fargo

# Time integrator
CFL    1e-3
tstop  1e3

and maps to

{
    "mode": "fargo",
    "CFL": 0.001,
    "tstop": 1000
}

Note that strings using e-notation (e.g. 1e-3 or 1E3 here) are decoded as numbers. They are cast to int if no precision loss ensues, and float otherwise. Reversly, when writing files, numbers are re-encoded using e-notation if it leads to a more compact representation. For instance, 100000 is encoded as 1e5, but 10 is left unchanged because 1e1 also uses one more character. In case where both reprensations are equally compact (e.g. 100 VS 1e2), e-notation is prefered in encoding.

While decoding, e can be lower or upper case, but they are also encoded as lower case.

Installation

$ pip install inifix

Usage

The API is similar to that of toml and stdlib json, though intentionally simplified, and consists in two main user-facing functions: inifix.load and inifix.dump.

import inifix

# read
conf = inifix.load("pluto.ini")

# patch
conf["Time"]["CFL"] = 0.1

# write back
inifix.dump(conf, "pluto-mod.ini")

inifix.load supports loading a from an open file

with open("pluto.ini") as fh:
    conf = inifix.load(fh)

or from a str/os.PathLike object representing a file.

Schema Validation

inifix.validate_inifile_schema can be used to validate an aribitrary dictionnary as writable to an inifile, following Pluto/Idefix's format. This will raise an exception (ValueError) if the dictionnary data is invalid.

inifix.validate_inifile_schema(data)

File formatter

A small command line tool is shipped with the package to format compatible inifiles.

This will print a formatted verison of the input file to stdout

$ inifix-format pluto.ini

In can be redirected as

$ inifix-format pluto.ini > pluto-formatted.ini

Use the -i/--inplace flag to write back to the source file. Note that comments are preserved in all cases.

Contribution guidelines

We use the pre-commit framework to automatically lint for code style and common pitfals.

Before you commit to your local copy of the repo, please run this from the top level

$ python3 -m pip install -u -e .[dev]
$ pre-commit install

Testing

We use the pytest framework to test inifix. The test suite can be run from the top level with a simple pytest invocation.

$ pytest

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

inifix-0.4.0.tar.gz (22.8 kB view details)

Uploaded Source

Built Distribution

inifix-0.4.0-py3-none-any.whl (21.6 kB view details)

Uploaded Python 3

File details

Details for the file inifix-0.4.0.tar.gz.

File metadata

  • Download URL: inifix-0.4.0.tar.gz
  • Upload date:
  • Size: 22.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.1

File hashes

Hashes for inifix-0.4.0.tar.gz
Algorithm Hash digest
SHA256 b581e27fd570a8fee53a8e80fe919df6993e28834ab1f8fe16f1b95e3dba377e
MD5 61b056ebc346e28e6636c28d1abb2ece
BLAKE2b-256 08d3ecda42437eef4b2cd4921c4d955426308c8cc7e27d23952f8f426240664a

See more details on using hashes here.

File details

Details for the file inifix-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: inifix-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 21.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.1

File hashes

Hashes for inifix-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2911753492a580064f12fbdb12d0e95df476c6334db210b629e7804ca6d70d9a
MD5 cbe65c5769fbdbbbce3d095b5e0be501
BLAKE2b-256 a6384d03baec2c3ae5015ca0afdf3c563af6a97ee8ea96df91c170b03f781e8c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page