skill-manager (skm)
A CLI tool for managing AI coding assistant skills across Claude, OpenCode, and Cursor.
What This Does
AI coding assistants like Claude Code, OpenCode, and Cursor support custom "skills" - markdown files containing prompts, instructions, or agent definitions that extend their capabilities. The problem: each tool expects these files in different locations with different formats.
skill-manager lets you maintain a single collection of skills and install them to any supported tool. It handles the path conventions and file transformations automatically.
How It Works
┌─────────────────┐ ┌─────────────────┐ ┌─────────────────┐
│ Sources │ │ Bundles │ │ Targets │
│ │ │ │ │ │
│ ~/.claude-skills│ ───► │ my-bundle/ │ ───► │ .claude/ │
│ ~/my-skills │ │ skills/ │ │ .opencode/ │
│ github.com/... │ │ agents/ │ │ .cursor/ │
└─────────────────┘ │ commands/ │ └─────────────────┘
└─────────────────┘
- Sources are directories (local or git repos) containing skill bundles
- Bundles are folders with
skills/,agents/, and/orcommands/subdirectories - Targets are the tool-specific directories where skills get installed
When you run skm my-bundle, it copies the bundle's files to the appropriate locations for your chosen tool, applying any necessary transformations.
Installation
This installs the skm binary. Requires Rust to be installed.
Quick Start
# Browse available bundles interactively
# Install a bundle to Claude (default)
# or just:
# Install to OpenCode or Cursor instead
# Manage sources interactively
# See what's installed in current directory
# Remove installed skills interactively
Commands
skm list
Interactive browser with fuzzy search for exploring available bundles. Type to filter by bundle name, author, description, or skill names. Press Esc to quit, Enter to view bundle details.
Available Bundles (type to search)
> xlsx by Anthropic 1s 0a 0c (anthropics/skills)
pdf by Anthropic 1s 0a 0c (anthropics/skills)
my-skill by username 2s 1a 0c (~/.claude-skills)
skm add <bundle> or skm <bundle>
Install a bundle to the current directory. Bundles are searched in priority order across all configured sources.
skm sources
Interactive menu to view, add, remove, and reorder sources by priority. Sources are checked in order when searching for bundles.
skm here
Show and manage skills installed in the current directory.
skm update
Pull latest changes from all git sources.
Supported Skill Formats
skm supports multiple skill repository formats, making it compatible with popular community skill repos.
Flat Bundle Format
The original format - a directory with subdirectories for each type:
my-bundle/
├── skills/ # Reusable skill definitions
│ └── helper.md
├── agents/ # Agent definitions
│ └── reviewer.md
├── commands/ # Slash commands (e.g., /commit)
│ └── commit.md
└── rules/ # Rules/guidelines
└── style.md
Anthropic/Marketplace Format
Compatible with anthropics/skills and huggingface/skills:
skills/
├── xlsx/
│ └── SKILL.md # With YAML frontmatter (name, description)
├── pdf/
│ └── SKILL.md
└── docx/
└── SKILL.md
Each skill folder becomes a separate installable bundle. The skill name is extracted from YAML frontmatter if present.
# Add the official Anthropic skills repo
# Install individual skills
Community Resources Format
For community repos with resources/ directory structure:
resources/
├── skills/
│ └── my-skill/
│ ├── meta.yaml # name, author, description
│ └── skill.md
└── commands/
└── my-command/
├── meta.yaml
└── command.md
Each resource folder becomes a separate bundle, named from meta.yaml.
Where Files Get Installed
| Source | Claude | OpenCode | Cursor |
|---|---|---|---|
skills/foo.md |
.claude/skills/bundle/foo.md |
.opencode/skill/bundle-foo/SKILL.md |
.cursor/skills/bundle-foo/SKILL.md |
agents/foo.md |
.claude/agents/bundle/foo.md |
.opencode/agent/bundle-foo.md |
.cursor/rules/bundle-foo/RULE.md |
commands/foo.md |
.claude/commands/bundle/foo.md |
.opencode/command/bundle-foo.md |
.cursor/rules/bundle-foo/RULE.md |
rules/foo.md |
.claude/rules/bundle/foo.md |
.opencode/rule/bundle-foo/RULE.md |
.cursor/rules/bundle-foo/RULE.md |
OpenCode and Cursor skills/rules require YAML frontmatter with a name field - skm adds this automatically if missing.
Configuration
Config file: ~/.config/skm/config.toml
= "claude"
[[]]
= "local"
= "~/.claude-skills"
[[]]
= "git"
= "https://github.com/user/skills"
Sources are searched in order (first match wins). Use skm sources to manage priority.
Shell Completions
License
MIT