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
Bus message envelope OVOS-MSG-1 message.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.10+.

Quick taste

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

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-MSG-1 envelope: a bus message and its 'send back to the asker' reply
m = Message("ovos.intent.list", {}, {"source": "skill.id"})
res = m.response({"intents": ["..."]})       # 'ovos.intent.list.response'
res.serialize()                              # single UTF-8 JSON object
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. Bus messages — the on-the-wire envelope, the forward / reply / response derivations, and the session carrier.
  7. Linting — validating a locale folder, on the CLI or in CI.
  8. API reference — every public name, in brief.

Runnable example scripts are in examples/.


Credits

Developed by TigreGótico for OpenVoiceOS.

NGI0 Commons Fund

This project was funded through the NGI0 Commons Fund, a fund established by NLnet with financial support from the European Commission's Next Generation Internet programme, under the aegis of DG Communications Networks, Content and Technology under grant agreement No 101135429.


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.8.0a2.tar.gz (52.4 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.8.0a2-py3-none-any.whl (36.8 kB view details)

Uploaded Python 3

File details

Details for the file ovos_spec_tools-0.8.0a2.tar.gz.

File metadata

  • Download URL: ovos_spec_tools-0.8.0a2.tar.gz
  • Upload date:
  • Size: 52.4 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.8.0a2.tar.gz
Algorithm Hash digest
SHA256 0d1b8a086b7d8c410490a29b723e499661c0b285b25432173e4d9f417c1caa46
MD5 f40194bac22c0944a29778e31d3d1693
BLAKE2b-256 81c1a7c8e797717320f2bc04e74dadca16a65260711473f748a09a2674cd5edf

See more details on using hashes here.

File details

Details for the file ovos_spec_tools-0.8.0a2-py3-none-any.whl.

File metadata

File hashes

Hashes for ovos_spec_tools-0.8.0a2-py3-none-any.whl
Algorithm Hash digest
SHA256 0cc653d3fd5a601ca6a5bb3950c12efa15117bad5fbbe3fbec384455d716e900
MD5 7b7396a4c28063704781ceb83e0c0301
BLAKE2b-256 a44b56e59049f878c04d43398694e160476d1e746abccaf67aeaeff0bf29ea99

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