Skip to main content
terrylica

plugin-dev

by terrylicav11.54.1

Plugin and skill development: structure validation, silent failure auditing, skill architecture meta-skill with TodoWrite templates

Installation guide →
3 skillsdevelopment GitHub

Documentation

# plugin-dev

[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](LICENSE)
[![Skills](https://img.shields.io/badge/Skills-2-blue.svg)]()
[![Commands](https://img.shields.io/badge/Commands-1-green.svg)]()
[![Claude Code](https://img.shields.io/badge/Claude%20Code-Plugin-purple.svg)]()

Plugin and skill development tools for Claude Code marketplace.

## Installation

```bash
/plugin marketplace add terrylica/cc-skills
/plugin install plugin-dev@cc-skills
```

## Commands

| Command              | Description                                                       |
| -------------------- | ----------------------------------------------------------------- |
| `/plugin-dev:create` | Create a new plugin with full workflow (ADR, validation, release) |

## Skills

| Skill                | Description                                                         |
| -------------------- | ------------------------------------------------------------------- |
| `plugin-validator`   | Validate plugin structure, manifests, and silent failure patterns   |
| `skill-architecture` | Meta-skill for creating Claude Code skills with TodoWrite templates |

**Trigger phrases:**

- "plugin validation", "check plugin", "hook audit" → plugin-validator
- "create skill", "YAML frontmatter", "skill templates" → skill-architecture

## Usage

```bash
# Create a new plugin
/plugin-dev:create my-plugin

# Validate a plugin for silent failures
/plugin-dev:plugin-validator plugins/my-plugin/

# Create a new skill (invoke the skill-architecture meta-skill)
/plugin-dev:skill-architecture
```

## Plugin Validator

### Validation Checks

- **Structure**: Plugin directory exists, plugin.json valid, required fields present
- **Silent Failures**: Hook entry points must emit to stderr on failure
- **Shellcheck**: Shell scripts checked for common issues
- **Python Exceptions**: `except: pass` must emit to stderr

### Integration

Invoked by `/plugin-dev:create` during Phase 3 validation.

## Skill Architecture

The `skill-architecture` skill provides:

- **5 TodoWrite Templates** (A-E) for different skill creation scenarios
- **YAML Frontmatter** standards (name, description, allowed-tools)
- **Progressive Disclosure** patterns (SKILL.md + references/)
- **Security Practices** (tool restrictions, input validation)
- **Bash Compatibility** patterns (heredoc wrappers for zsh)

### Validator Scripts (TypeScript/Bun)

| Script               | Purpose                                            |
| -------------------- | -------------------------------------------------- |
| `validate-skill.ts`  | Comprehensive skill validation (11+ checks)        |
| `validate-links.ts`  | Markdown link portability (strict `/docs/` policy) |
| `fix-bash-blocks.ts` | Auto-fix bash blocks for zsh compatibility         |

Run scripts with:

```bash
# Marketplace plugins (strict validation)
bun run plugins/plugin-dev/scripts/validate-skill.ts <skill-path>

# Project-local skills (auto-detected, relaxed link rules)
bun run plugins/plugin-dev/scripts/validate-skill.ts .claude/skills/<skill>/

# Skip bash checks for documentation-only skills
bun run plugins/plugin-dev/scripts/validate-skill.ts <path> --skip-bash

# Other validators
bun run plugins/plugin-dev/scripts/validate-links.ts <skill-path>
bun run plugins/plugin-dev/scripts/fix-bash-blocks.ts <path> [--dry]
```

## Dependencies

| Component  | Required | Installation               |
| ---------- | -------- | -------------------------- |
| Bun        | Yes      | `brew install oven-sh/bun` |
| ShellCheck | Optional | `brew install shellcheck`  |

## Troubleshooting

| Issue                  | Cause                    | Solution                                        |
| ---------------------- | ------------------------ | ----------------------------------------------- |
| Plugin not found       | Not in marketplace.json  | Add entry to `.claude-plugin/marketplace.json`  |
| Validation fails       | Missing plugin.json      | Create plugin.json with required fields         |
| Skill validation error | Invalid YAML frontmatter | Check SKILL.md format and required fields       |
| Link validation fails  | Absolute paths in skill  | Use relative paths (`./`, `../`) in skill files |
| Bash block warning     | Missing heredoc wrapper  | Run `fix-bash-blocks.ts` to auto-fix            |
| Bun not found          | Runtime not installed    | `brew install oven-sh/bun`                      |

## License

MIT