Core library for the Score portable AI knowledge format
Project description
score-core
Core library for the Score portable AI knowledge format.
Score is a human-readable, LLM-agnostic format for encoding organisational
knowledge as portable skill files. score-core provides the schema, parser,
serialiser, validator, library validator, Context API models, and Recording
models that any Score-compatible tool needs.
Full format specification: score_spec.md Writing skills: WRITING_SKILLS.md
Install
pip install score-core
Quickstart
Validate a skill file
score validate path/to/my-skill.md
score validate path/to/skills/ --strict
Validate programmatically
from score import parse_skill_file, validate_skill
skill = parse_skill_file("path/to/my-skill.md")
payload = {
"name": skill.name,
"description": skill.description,
"version": skill.version,
"owner": skill.owner,
"triggers": list(skill.triggers),
"tags": list(skill.tags),
"active": skill.active,
"created": skill.created,
"updated": skill.updated,
"body": skill.body,
}
result = validate_skill(payload)
if not result["valid"]:
for error in result["errors"]:
print(f"error: {error['field']} — {error['message']}")
for warning in result["warnings"]:
print(f"warning: {warning['field']} — {warning['message']}")
Work with the Pydantic model
from score import parse_skill_file_pydantic, validate_skill_file
skill_file = parse_skill_file_pydantic("path/to/my-skill.md")
result = validate_skill_file(skill_file)
print(result) # ValidationResult(valid=True, errors=[], warnings=[...], ...)
Library validation
from score import validate_library
skills = [...] # list of full skill dicts
report = validate_library(skills)
print(report["summary"]["overall_health"]) # "good" | "warning" | "critical"
Migrate existing skills to v0.1.1
score migrate path/to/skills/ --to 0.1.1 # dry run
score migrate path/to/skills/ --to 0.1.1 --apply # write changes
CLI commands
| Command | Purpose |
|---|---|
score validate <path> |
Validate a single file or directory |
score library-check <dir> |
Full library report (overlaps, coverage) |
score governance-init <dir> |
Report skills missing v0.1.1 governance fields |
score verify-recording <file> |
Verify Recording hash chain integrity |
score migrate <dir> --to 0.1.1 |
Add safe defaults for new spec fields |
What's in the package
score.schema— Pydantic models (SkillFile,UITheme,ExecutionHints) and field constantsscore.parser—.md→Skill(runtime dataclass) andSkillFile(Pydantic)score.serialiser—Skill→.mdwith YAML frontmatterscore.validator— three-tier validation (errors, warnings, hints)score.library_validator— cross-skill checks and fix proposalscore.context_api— request/response models for the Score Context APIscore.recording— audit log entry models and hash chain utilitiesscore.cli—scorecommand-line interface
Relationship to Maestro
Maestro is the commercial skill management product built on the Score format.
score-core is the shared library that Maestro and any other Score-compatible
tool import. Maestro uses score-core internally; it is not a Maestro
dependency.
Version
Current: 0.1.0 — supports Score format v0.1.1 with governance metadata fields.
Licence
MIT. See LICENCE.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file score_core-0.1.4.tar.gz.
File metadata
- Download URL: score_core-0.1.4.tar.gz
- Upload date:
- Size: 50.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8a2079637cccc32112c73175688e4740a32baf1d55e8b363c88078f3e1dc6c30
|
|
| MD5 |
8ce413cd8e4a8e888f9c41e3bf514a1e
|
|
| BLAKE2b-256 |
0e69a318c158cb06d7906aead9c6b2ef4f55a67729f850fc0d7e75b2e2030f9f
|
File details
Details for the file score_core-0.1.4-py3-none-any.whl.
File metadata
- Download URL: score_core-0.1.4-py3-none-any.whl
- Upload date:
- Size: 57.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ce537dc8af2b38d39824943eae4da10ba4f58b7b221266a70dacaa6d8f72b28d
|
|
| MD5 |
37c659b9759fea70b17bce983cddb81d
|
|
| BLAKE2b-256 |
8d0cf9932aa318505b25b3fb6584b4ad0ed7278a7097878db644dcab8bff879a
|