Skip to main content

Official Python parser for YINI, an INI-inspired, indentation-insensitive configuration format with clear nested sections and explicit structure.

Project description

yini-parser-python

The official Python parser for YINI (by the YINI-lang project) — a human-readable, INI-inspired, indentation-insensitive configuration format with clear nested sections, explicit structure, comments, and predictable parsing.

Status: Beta.
This parser is intended for early testing and integration. The public API and edge-case behavior may still change before 1.0.0.


Installation

Install from PyPI:

pip install yini-parser

The package name on PyPI is:

yini-parser

The Python import name is:

import yini_parser

Copy-paste test

Test the package in under one minute.

Parse a YINI string:

from yini_parser import loads

data = loads("""
^ Application
name = "demo"

^^ Server
port = 8080
""")

print(data)

Expected output:

{'Application': {'name': 'demo', 'Server': {'port': 8080}}}

Quick Start

Example lenient-mode (default) YINI file:

// A small, practical YINI config.

// The App section starts here.
^ App
name = "Demo App"
version = 1.2
features = ["search", "logs"]
debug = false    // off/no would work too.
pageSize = 25

    // Nested under App. Indentation is optional and used for readability.
    ^^ Server
    host = "localhost"
    port = 8080    # YINI also supports # comments.
    useTLS = off

Parse a YINI file:

from yini_parser import load

data = load("sample/basic.yini")

print(data["App"]["name"])  # Demo App
print(data["App"]["Server"]["port"])  # 8080

Parse a YINI string:

from yini_parser import loads

data = loads("""
^ App
name = "Demo App"
version = 1.2
debug = false
""")

print(data["App"]["name"])  # Demo App

Use load(...) to parse a file and loads(...) to parse a string.

See the YINI specification and documentation.


Examples

Runnable example projects are available in the YINI demo apps repository.

The Python examples show how to install yini-parser, load .yini files, and access parsed configuration data in small practical scripts.


Why YINI?

YINI is intended for configuration files where human readability, explicit structure, and predictable parsing are more important than minimal syntax or maximum flexibility.

Compared with common configuration formats:

  • INI: YINI supports clearer nested sections and typed values.
  • JSON: YINI supports comments and is easier to edit by hand.
  • YAML: YINI does not use indentation to define structure.
  • TOML: YINI uses explicit section markers for hierarchy instead of dotted table names.

The same small configuration can be written in several formats:

YINI

^ Application
name = 'demo'
environment = 'dev'

^^ Server
host = 'localhost'
ports = [8080, 8081]

^^^ TLS
enabled = true
mode = 'optional'
  • Application contains the top-level application settings.
  • Server is nested under Application.
  • TLS is nested under Server.
  • The section markers ^ make the nesting explicit. Indentation is optional and not required for structure.
  • Strings can use either ' or ".

JSON

{
  "Application": {
    "name": "demo",
    "environment": "dev",
    "Server": {
      "host": "localhost",
      "ports": [8080, 8081],
      "TLS": {
        "enabled": true,
        "mode": "optional"
      }
    }
  }
}

YAML

Application:
  name: demo
  environment: dev
  Server:
    host: localhost
    ports:
      - 8080
      - 8081
    TLS:
      enabled: true
      mode: optional

TOML

[Application]
name = "demo"
environment = "dev"

[Application.Server]
host = "localhost"
ports = [8080, 8081]

[Application.Server.TLS]
enabled = true
mode = "optional"

YINI may not be the right choice when you need mature ecosystem support, existing schema tooling, or maximum compatibility with infrastructure that already expects JSON, YAML, or TOML. The format and parser are still beta-stage and best suited for testing, experiments, and early integration feedback.


Parser implementation

yini-parser uses Python parser code generated by ANTLR.

The generated Python parser files are included in the package. Users do not need Java or the ANTLR generator tool to install or use yini-parser.

The package depends on antlr4-python3-runtime because the generated lexer and parser use the ANTLR Python runtime while parsing.

The ANTLR generator JAR is only needed by maintainers when regenerating parser sources from the grammar, and it is not included in the published Python package.


Feedback and bug reports

If you find a problem, please open an issue on GitHub:

When reporting parser behavior, it is helpful to include:

  • The YINI input that caused the issue.
  • The expected result.
  • The actual result or error message.
  • The installed yini-parser version.
  • The Python version used.

Development

For local development:

python -m pip install -e ".[dev]"

or, if using the project Taskfile:

task install-dev

Generate the ANTLR parser sources:

task antlr

Run the full project check:

task check

This runs:

  • The test suite with warnings treated as errors,
  • Ruff lint checks,
  • Ruff formatting checks,
  • mypy type checking.

Tests

The tests/ directory contains a focused implementation-local test suite, including tests for:

  • The public loading API.
  • Values, numbers, strings, lists, and inline objects, including lenient = separators and strict : enforcement.
  • Sections, nested sections, section depth, and section marker separators.
  • Strict and lenient parser behavior.
  • @yini strict and @yini lenient mode declarations.
  • Duplicate keys, repeated sections, and key/section collisions.
  • String concatenation.
  • Comments, ignored lines, smoke fixtures, and warning/error behavior.

Run the test suite with:

python -m pytest -v -W error

or, if using the project Taskfile:

task test

Run the full project check with:

task check

🧪 Testing and Stability

This parser is covered by smoke, integration, and regression tests.

It has also been run against yini-test-suite v0.3.0, the external YINI conformance test suite, with all TypeScript parser cases passing.


Links


^YINI ≡

YINI is a human-readable, INI-inspired, indentation-insensitive configuration format with clear nested sections, explicit structure, and predictable parsing.

It has a formal specification and a defined grammar.

yini-lang.org · YINI-lang on GitHub

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

yini_parser-0.2.0b1.tar.gz (40.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

yini_parser-0.2.0b1-py3-none-any.whl (41.5 kB view details)

Uploaded Python 3

File details

Details for the file yini_parser-0.2.0b1.tar.gz.

File metadata

  • Download URL: yini_parser-0.2.0b1.tar.gz
  • Upload date:
  • Size: 40.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.0

File hashes

Hashes for yini_parser-0.2.0b1.tar.gz
Algorithm Hash digest
SHA256 8be317aeba9abd645afa75881328cc707e0a001ae8a410ffccc696ebc19f184f
MD5 36f9a679abbd1084c09f091ee7412c00
BLAKE2b-256 b42c7df659fc986c11fe9bdc65f152ae8fde008c58193f2ac6fbb5367de81797

See more details on using hashes here.

File details

Details for the file yini_parser-0.2.0b1-py3-none-any.whl.

File metadata

  • Download URL: yini_parser-0.2.0b1-py3-none-any.whl
  • Upload date:
  • Size: 41.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.0

File hashes

Hashes for yini_parser-0.2.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 a0785984dadf1f57b86fd398de744f50d915877f7d3ba55af8e54091604cfe27
MD5 03cdca1c4e766f95599f24ce8e55da14
BLAKE2b-256 519716453e0261cd9bf3b4913a0d72a23e9e7842f8b20352e00d1d7be5f77437

See more details on using hashes here.

Supported by

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