Skip to main content

Reference implementation of the OVOS formal specifications

Project description

ovos-spec-tools

Reference implementation of the OVOS formal specifications — the low-level, dependency-light primitives those specifications describe.

OVOS components reimplement template expansion, resource loading, and language matching in several places, and the copies drift. This package is the single conformant implementation those components — and any third-party tool — can depend on.

Status

Tool Spec Code
Sentence template expander OVOS-INTENT-1 v2 expansion.py
Locale resource loader OVOS-INTENT-2 resources.py
Dialog renderer OVOS-INTENT-2 §4.2 dialog.py
Prompt renderer OVOS-INTENT-2 §4.4 prompt.py
Language-tag matching OVOS-INTENT-2 §2.2 language.py
ovos-spec-lint locale linter OVOS-INTENT-1 / -2 lint.py

Install

pip install ovos-spec-tools            # core — no dependencies
pip install ovos-spec-tools[langcodes] # adds the smart language fallback

Requires Python 3.8+.

Quick taste

from ovos_spec_tools import (expand, LocaleResources, render, render_prompt,
                             closest_lang)

expand("(turn|switch) [the] light")          # all 4 sentences it denotes
res = LocaleResources("my-skill/locale")
res.load_intent("play", "en-US")             # a skill's intent samples
render(res.load_dialog("weather", "en-US"),  # a spoken response
       slots={"temperature": 21})
render_prompt(res.load_prompt("system", "en-US"),  # a language-model prompt
              slots={"query": "what time is it"})
closest_lang("en-AU", ["pt-BR", "en-US"])    # 'en-US'
ovos-spec-lint my-skill/locale               # validate a locale folder

Documentation

A zero-to-hero guide lives in docs/:

  1. Getting started — install, and a first taste of every tool.
  2. Sentence templates — the grammar: alternatives, optionals, slots, vocabulary references, malformed forms.
  3. Locale resources — the locale/ folder, the six file roles, loading across languages, override precedence.
  4. Dialog — choosing and filling a spoken response, and rendering language-model prompts.
  5. Language matching — tag standardization, distance, and closest-match resolution.
  6. Linting — validating a locale folder, on the CLI or in CI.
  7. API reference — every public name, in brief.

Runnable example scripts are in examples/.

Credits

This package was produced as part of a documentation and interoperability effort for OpenVoiceOS, funded by NLnet's NGI0 Commons Fund under grant agreement No 101135429.

NGI0 / NLnet

License

Apache 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

ovos_spec_tools-0.3.0a1.tar.gz (40.2 kB view details)

Uploaded Source

Built Distribution

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

ovos_spec_tools-0.3.0a1-py3-none-any.whl (30.0 kB view details)

Uploaded Python 3

File details

Details for the file ovos_spec_tools-0.3.0a1.tar.gz.

File metadata

  • Download URL: ovos_spec_tools-0.3.0a1.tar.gz
  • Upload date:
  • Size: 40.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ovos_spec_tools-0.3.0a1.tar.gz
Algorithm Hash digest
SHA256 49c5520a5d26e4fc5c155bbacdb3b00ca0951ccd9bb110cb9bd7b94a42ddace0
MD5 9bf672dd1463a410fc2373e6ab2397bd
BLAKE2b-256 a1370128430eae82bb6538a31bca651e3858d7d966bd5315383c2d78cbf337f9

See more details on using hashes here.

File details

Details for the file ovos_spec_tools-0.3.0a1-py3-none-any.whl.

File metadata

File hashes

Hashes for ovos_spec_tools-0.3.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 98bcc18e5f782283cd7ef6e8c1d364d2bb796dcaffafbef6e8ff8416a9bf47c5
MD5 962ed3208f4b226cdbb93287ebf655cc
BLAKE2b-256 e5e41b12e4f4c60604a51f9528d2210b1efd5552f891c0efd4f458c5c8d667a3

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