Skip to main content

Extract the version of a structured file's format specification.

Project description

typed-format-version: load format.version.{major,minor} from a structured file.

This module tries to parse a format.version "section" in some raw data that may have been loaded from a configuration file, and determines whether that section contains valid "major" and "minor" integer values. The caller can then choose the correct schema to validate the loaded data against, e.g. by using the typedload library with the correct top-level dataclass definition.

The most commonly used function will probably be get_version(): it takes a raw data dictionary and returns a Version object with a major and minor integer attributes, if the data contained a valid "format" dictionary with a "version" dictionary within it. Optionally the get_version() function can remove the top-level "format" member, if a true value is passed for the pop argument.

Python examples

Load some data from a file, make sure it is in the correct format:

try:
    raw = json.load(pathlib.Path(cfgfile).open())
    ver = typed_format_version.get_version(raw)
except (OSError, ValueError) as err:
    sys.exit(f"Invalid data format for {cfgfile}: {err}")
if ver.as_version_tuple() != (0, 2):
    sys.exit("Only config format 0.2 supported right now")
cfg = typedload.load(raw, ConfigData)

Determine the best version to validate against, allowing more fields to be added in minor versions that we do not know about yet:

SCHEMAS = {
    (0, 1): ConfigTop_0_1,
    (0, 2): ConfigTop_0_2,
    (1, 0): ConfigTop_1_0,
}
try:
    raw = json.load(pathlib.Path(cfgfile).open())
    exact_ver = typed_format_version.get_version(raw)
    mver = typed_format_version.determine_version_match(exact_ver, SCHEMAS)
except (OSError, ValueError) as err:
    sys.exit(f"Invalid data format for {cfgfile}: {err}")

# Either load the data directly...
cfg = typedload.load(raw, SCHEMAS[mver.version], failonextra=mver.failonextra)

# ...or do something with mver.version, possibly examining ver further and
# "upgrading" the loaded configuration from earlier versions by e.g.
# adding default values for fields or reshaping the data.

Rust examples

Load some data from a file, make sure it is in the correct format:

use std::fs;

use expect_exit::ExpectedWithError;

let contents = fs::read_to_string(&infile).or_exit_e(|| format!("Could not read {}", infile.display()));
let fver = typed_format_version::get_version_from_str(&contents, serde_json::from_str)
    .or_exit_e(|| format!("Could not parse format.version from {}", infile.display()));
if (fver.major(), fver.minor()) != (0, 2) {
    expect_exit::exit("Only config format 0.2 supported right now");
}
let cfg: ConfigData = serde_json::from_str(&contents)
    .or_exit_e(|| format!("Could not parse {}", infile.display()));

Upgrade from an earlier versions of the data format:

let cfg = match fver.major() {
    0 => {
        let cfg_0: ConfigData_0 = serde_json::from_str(&contents)
            .or_exit_e(|| format!("Could not parse {}", infile.display()));
        upgrade_from_version_0(cfg_0)
    },
    1 => serde_json::from_str::<ConfigData>(&contents)
        .or_exit_e(|| format!("Could not parse {}", infile.display())),
    _ => expect_exit::exit(&format!("Unexpected major format version {}", fver.major()),
};

Contact

The typed-format-version library is developed in a GitLab repository. It was written by Peter Pentchev.

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

typed-format-version-0.2.1.tar.gz (15.4 kB view details)

Uploaded Source

Built Distribution

typed_format_version-0.2.1-py3-none-any.whl (4.9 kB view details)

Uploaded Python 3

File details

Details for the file typed-format-version-0.2.1.tar.gz.

File metadata

  • Download URL: typed-format-version-0.2.1.tar.gz
  • Upload date:
  • Size: 15.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for typed-format-version-0.2.1.tar.gz
Algorithm Hash digest
SHA256 ee5da17c9101c6d80d2a9dd84f8121c7efbd0798638fed3082a31a611c993c8f
MD5 76bf9d17beebb0203cab6e2cd582e63d
BLAKE2b-256 bff9f3915f73a3dcfb02dedfc7f0bfaa251ebcdff21fa5ede532d36716a3c7ff

See more details on using hashes here.

File details

Details for the file typed_format_version-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for typed_format_version-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 87fe20f825866e579b739492fe67ba86270df749cc119a14621d91d06d6e48bc
MD5 8293658eb8a70766a37fbd100bdedce3
BLAKE2b-256 8496407ce1385afb23ae50acc9fd66267c5975e3a5eb23e440d413c9c988d85c

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