Skill Define
About
The Skill Define tool validates and registers new Claude Code Skill manifests by checking their YAML structure, inputs/outputs, and dependencies. It acts as a quality gate to ensure all skills conform to schema and governance rules before being added to the Betty Framework. Developers use it to verify their `.skill.yaml` files are correct during the skill creation process.
Documentation
skill.define
Overview
skill.define is the compiler and registrar for Betty Framework skills. It ensures each skill.yaml conforms to schema and governance rules before registration.
Purpose
Acts as the quality gate for all skills in the Betty ecosystem:
- Schema Validation: Ensures all required fields are present
- Manifest Parsing: Validates YAML structure and syntax
- Registry Integration: Delegates to
registry.updatefor registration - Error Reporting: Provides detailed validation errors for troubleshooting
Usage
Basic Usage
python skills/skill.define/skill_define.py <path_to_skill.yaml>
Arguments
| Argument | Type | Required | Description |
|---|---|---|---|
| manifest_path | string | Yes | Path to the skill manifest file (skill.yaml) |
Required Skill Manifest Fields
A valid skill manifest must include:
| Field | Type | Description | Example |
|---|---|---|---|
name | string | Unique skill identifier | api.validate |
version | string | Semantic version | 0.1.0 |
description | string | What the skill does | Validates API specifications |
inputs | array | Input parameters | ["spec_path", "guideline_set"] |
outputs | array | Output artifacts | ["validation_report"] |
dependencies | array | Required skills/deps | ["context.schema"] |
status | string | Skill status | active or draft |
Optional Fields
- entrypoints: CLI command definitions
- tags: Categorization tags
- permissions: Required filesystem/network permissions
Behavior
- Load Manifest: Reads and parses the YAML file
- Validate Structure: Checks for all required fields
- Validate Format: Ensures field types and values are correct
- Delegate Registration: Calls
registry.updateto add skill to registry - Return Results: Provides JSON response with validation status
Outputs
Success Response
{
"ok": true,
"status": "registered",
"errors": [],
"path": "skills/workflow.validate/skill.yaml",
"details": {
"valid": true,
"missing": [],
"path": "skills/workflow.validate/skill.yaml",
"manifest": {
"name": "workflow.validate",
"version": "0.1.0",
"description": "Validates workflow YAML definitions",
"inputs": ["workflow.yaml"],
"outputs": ["validation_result.json"],
"dependencies": ["context.schema"],
"status": "active"
},
"status": "registered",
"registry_updated": true
}
}
Failure Response (Missing Fields)
{
"ok": false,
"status": "failed",
"errors": [
"Missing required fields: version, outputs"
],
"path": "skills/my-skill/skill.yaml",
"details": {
"valid": false,
"missing": ["version", "outputs"],
"path": "skills/my-skill/skill.yaml"
}
}
Failure Response (Invalid YAML)
{
"ok": false,
"status": "failed",
"errors": [
"Failed to parse YAML: mapping values are not allowed here"
],
"path": "skills/broken/skill.yaml",
"details": {
"valid": false,
"error": "Failed to parse YAML: mapping values are not allowed here",
"path": "skills/broken/skill.yaml"
}
}
Examples
Example 1: Validate a Complete Skill
Skill Manifest (skills/api.validate/skill.yaml):
name: api.validate
version: 0.1.0
description: "Validate OpenAPI and AsyncAPI specifications against enterprise guidelines"
inputs:
- name: spec_path
type: string
required: true
description: "Path to the API specification file"
- name: guideline_set
type: string
required: false
default: zalando
description: "Which API guidelines to validate against"
outputs:
- name: validation_report
type: object
description: "Detailed validation results"
- name: valid
type: boolean
description: "Whether the spec is valid"
dependencies:
- context.schema
status: active
tags: [api, validation, openapi]
Validation Command:
$ python skills/skill.define/skill_define.py skills/api.validate/skill.yaml
{
"ok": true,
"status": "registered",
"errors": [],
"path": "skills/api.validate/skill.yaml",
"details": {
"valid": true,
"status": "registered",
"registry_updated": true
}
}
Example 2: Detect Missing Fields
Incomplete Manifest (skills/incomplete/skill.yaml):
name: incomplete.skill
description: "This skill is missing required fields"
inputs: []
Validation Result:
$ python skills/skill.define/skill_define.py skills/incomplete/skill.yaml
{
"ok": false,
"status": "failed",
"errors": [
"Missing required fields: version, outputs, dependencies, status"
],
"path": "skills/incomplete/skill.yaml",
"details": {
"valid": false,
"missing": ["version", "outputs", "dependencies", "status"],
"path": "skills/incomplete/skill.yaml"
}
}
Integration
With skill.create
The skill.create skill automatically generates a valid manifest and runs skill.define to validate it:
python skills/skill.create/skill_create.py \
my.skill \
"Does something useful" \
--inputs input1,input2 \
--outputs output1
# Internally runs skill.define on the generated manifest
With Workflows
Skills can be validated as part of a workflow:
# workflows/create_and_register.yaml
steps:
- skill: skill.create
args: ["workflow.validate", "Validates workflow definitions"]
- skill: skill.define
args: ["skills/workflow.validate/skill.yaml"]
required: true
- skill: registry.update
args: ["skills/workflow.validate/skill.yaml"]
With Hooks
Automatically validate skill manifests when they're edited:
# Create a hook to validate on save
python skills/hook.define/hook_define.py \
--event on_file_save \
--pattern "skills/*/skill.yaml" \
--command "python skills/skill.define/skill_define.py {file_path}" \
--blocking true
Common Errors
| Error | Cause | Solution |
|---|---|---|
| "Manifest file not found" | File path is incorrect | Check the path and ensure file exists |
| "Failed to parse YAML" | Invalid YAML syntax | Fix YAML syntax errors (indentation, quotes, etc.) |
| "Missing required fields: X" | Manifest missing required field(s) | Add the missing field(s) to the manifest |
| "registry.update skill not found" | Registry updater not available | Ensure registry.update skill exists in skills/ directory |
Relationship with registry.update
skill.define validates manifests but delegates registration to registry.update:
- skill.define: Validates the manifest structure
- registry.update: Updates
/registry/skills.jsonwith the validated skill
This separation of concerns follows Betty's single-responsibility principle.
Files Read
- Input: Skill manifest at specified path (e.g.,
skills/my.skill/skill.yaml) - Registry: May read existing
/registry/skills.jsonvia delegation toregistry.update
Files Modified
- None directly β Registry updates are delegated to
registry.updateskill - Indirectly:
/registry/skills.jsonupdated viaregistry.update
Exit Codes
- 0: Success (manifest valid, registration attempted)
- 1: Failure (validation errors or file not found)
Logging
Logs validation steps using Betty's logging infrastructure:
INFO: Validating manifest: skills/api.validate/skill.yaml
INFO: β
Manifest validation passed
INFO: π Delegating registry update to registry.update skill...
INFO: Registry update succeeded
Best Practices
- Run Before Commit: Validate skill manifests before committing changes
- Use with skill.create: Let
skill.creategenerate manifests to ensure correct structure - Check Dependencies: Ensure any skills listed in
dependenciesexist in the registry - Version Properly: Follow semantic versioning for skill versions
- Complete Descriptions: Write clear descriptions for inputs, outputs, and the skill itself
- Set Status Appropriately: Use
draftfor development,activefor production-ready skills
See Also
- skill.create β Generate new skill scaffolding with valid manifest (skill.create SKILL.md)
- registry.update β Update the skill registry (registry.update SKILL.md)
- Betty Architecture β Understanding the skill layer (Five-Layer Model)
- Skill Framework β Overview of skill categories and design (Skill Framework)
Dependencies
- registry.update: For updating the skill registry (delegated call)
- betty.validation: Validation utility functions
- betty.config: Configuration constants
Status
Active β This skill is production-ready and core to Betty's skill infrastructure.
Version History
- 0.1.0 (Oct 2025) β Initial implementation with manifest validation and registry delegation
Quick Install
/plugin add https://github.com/epieczko/betty/tree/main/skill.defineCopy and paste this command in Claude Code to install this skill
GitHub δ»εΊ
Related Skills
sglang
MetaSGLang is a high-performance LLM serving framework that specializes in fast, structured generation for JSON, regex, and agentic workflows using its RadixAttention prefix caching. It delivers significantly faster inference, especially for tasks with repeated prefixes, making it ideal for complex, structured outputs and multi-turn conversations. Choose SGLang over alternatives like vLLM when you need constrained decoding or are building applications with extensive prefix sharing.
evaluating-llms-harness
TestingThis Claude Skill runs the lm-evaluation-harness to benchmark LLMs across 60+ standardized academic tasks like MMLU and GSM8K. It's designed for developers to compare model quality, track training progress, or report academic results. The tool supports various backends including HuggingFace and vLLM models.
llamaguard
OtherLlamaGuard is Meta's 7-8B parameter model for moderating LLM inputs and outputs across six safety categories like violence and hate speech. It offers 94-95% accuracy and can be deployed using vLLM, Hugging Face, or Amazon SageMaker. Use this skill to easily integrate content filtering and safety guardrails into your AI applications.
langchain
MetaLangChain is a framework for building LLM applications using agents, chains, and RAG pipelines. It supports multiple LLM providers, offers 500+ integrations, and includes features like tool calling and memory management. Use it for rapid prototyping and deploying production systems like chatbots, autonomous agents, and question-answering services.
