Skip to main content

Reference Python validator for the Lace probe scripting language (parser + semantic checks, no runtime).

Project description

lacelang-validator (python)

Canonical Python validator for Lace — the reference implementation with 100% spec conformance.

This is the validator that the Lace specification is developed and tested against. All error codes, AST schemas, and validation rules are verified against this implementation before each spec release.

This package only parses and validates .lace source text. It has no HTTP client and does not execute probes. The runtime and its network surface live in the separate lacelang-executor package, per lace-spec.md §16.

Why split

Integrators that want syntax / semantic checking in a CI job, IDE extension, or block editor shouldn't have to pull in an HTTP stack, TLS, cookie state, or an extension dispatcher. Installing lacelang-validator alone gives a clean audit surface with zero network exposure.

Install

pip install lacelang-validator

Or from source:

pip install git+https://github.com/tracedown/lacelang-python-validator.git

Usage

# Parse → emit AST, or { errors: [...] } on syntax failure
lacelang-validate parse script.lace

# Validate → emit { errors: [...], warnings: [...] }
lacelang-validate validate script.lace \
    --vars-list vars.json \
    --context context.json

# With an extension's field/function registrations active
lacelang-validate validate script.lace \
    --enable-extension laceNotifications

# Pretty-print any subcommand
lacelang-validate parse script.lace --pretty

Exit code is always 0 on successful processing. Parse and validation errors are reported in the JSON body. Non-zero exit codes are reserved for tool failures (unreadable source file, malformed arguments).

Library usage

from lacelang_validator.parser import parse
from lacelang_validator.validator import validate

ast = parse(open("script.lace").read())
diagnostics = validate(
    ast,
    variables=["url"],
    context={"maxRedirects": 10, "maxTimeoutMs": 300_000},
)
for err in diagnostics.errors:
    print(err.code, err.call_index, err.field)

License

Apache License 2.0

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

lacelang_validator-0.1.0.tar.gz (27.1 kB view details)

Uploaded Source

Built Distribution

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

lacelang_validator-0.1.0-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file lacelang_validator-0.1.0.tar.gz.

File metadata

  • Download URL: lacelang_validator-0.1.0.tar.gz
  • Upload date:
  • Size: 27.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for lacelang_validator-0.1.0.tar.gz
Algorithm Hash digest
SHA256 34edfb053dfe7a9448e25a6db0b02817e9655b57c22bff7fa71b10cca4c1c5f6
MD5 bdaee7ddf28d1796ed20fde15a704c29
BLAKE2b-256 a683ce0517e61ba8797b7a09af04790368f972bf5fb1a913f122b34c94499504

See more details on using hashes here.

Provenance

The following attestation bundles were made for lacelang_validator-0.1.0.tar.gz:

Publisher: release.yml on tracedown/lacelang-python-validator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file lacelang_validator-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for lacelang_validator-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fe3a96f87e2599fcf375cab4563b6f936f46299692f74a35b18b0489e440457c
MD5 34523e29519ddb4548ade791930c99a4
BLAKE2b-256 a351d451cced12376dc39ed5a8ceeb043682757d15da36df941a12a1d9b1640d

See more details on using hashes here.

Provenance

The following attestation bundles were made for lacelang_validator-0.1.0-py3-none-any.whl:

Publisher: release.yml on tracedown/lacelang-python-validator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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