Initial commit

This commit is contained in:
Zhongwei Li
2025-11-29 18:50:19 +08:00
commit d08086ebc7
41 changed files with 4892 additions and 0 deletions

View File

@@ -0,0 +1,261 @@
---
name: skill-porter
description: Converts Claude Code skills to Gemini CLI extensions and vice versa. Use when the user wants to make a skill cross-platform compatible, port a skill between platforms, or create a universal extension that works on both Claude Code and Gemini CLI.
allowed-tools:
- Read
- Write
- Edit
- Glob
- Grep
- Bash
---
# Skill Porter - Cross-Platform Skill Converter
This skill automates the conversion between Claude Code skills and Gemini CLI extensions, enabling true cross-platform AI tool development.
## Core Capabilities
### Bidirectional Conversion
Convert skills and extensions between platforms while preserving functionality:
**Example requests:**
- "Convert this Claude skill to work with Gemini CLI"
- "Make my Gemini extension compatible with Claude Code"
- "Create a universal version of this skill that works on both platforms"
- "Port the database-helper skill to Gemini"
### Smart Platform Detection
Automatically analyzes directory structure to determine source platform:
**Detection criteria:**
- Claude: Presence of `SKILL.md` with YAML frontmatter or `.claude-plugin/marketplace.json`
- Gemini: Presence of `gemini-extension.json` or `GEMINI.md` context file
- Universal: Has both platform configurations
**Example requests:**
- "What platform is this skill built for?"
- "Analyze this extension and tell me what needs to be converted"
- "Is this a Claude skill or Gemini extension?"
### Metadata Transformation
Intelligently converts between platform-specific formats:
**Conversions handled:**
- YAML frontmatter ↔ JSON manifest
- `allowed-tools` (whitelist) ↔ `excludeTools` (blacklist)
- Environment variables ↔ settings schema
- MCP server configuration paths
- Platform-specific documentation formats
**Example requests:**
- "Convert the metadata from this Claude skill to Gemini format"
- "Transform the allowed-tools list to Gemini's exclude pattern"
- "Generate a settings schema from these environment variables"
### MCP Server Preservation
Maintains Model Context Protocol server configurations across platforms:
**Example requests:**
- "Ensure the MCP server config works on both platforms"
- "Update the MCP server paths for Gemini's ${extensionPath} variable"
- "Validate that the MCP configuration is compatible"
### Validation & Quality Checks
Ensures converted output meets platform requirements:
**Validation checks:**
- Required files present (SKILL.md, gemini-extension.json, etc.)
- Valid YAML/JSON syntax
- Correct frontmatter structure
- MCP server paths resolve correctly
- Tool restrictions are valid
- Settings schema is complete
**Example requests:**
- "Validate this converted skill"
- "Check if this Gemini extension meets all requirements"
- "Is this conversion ready to install?"
## Conversion Process
When you request a conversion, I will:
1. **Analyze** the source directory structure
2. **Detect** which platform it's built for
3. **Extract** metadata, MCP configuration, and documentation
4. **Transform** the data to target platform format
5. **Generate** required files for target platform
6. **Validate** output meets all requirements
7. **Report** what was converted and any manual steps needed
## Platform Differences Handled
### File Structure
- **Claude**: `SKILL.md` + `.claude-plugin/marketplace.json`
- **Gemini**: `GEMINI.md` + `gemini-extension.json`
- **Universal**: Both sets of files + shared documentation
### Metadata Format
- **Claude**: YAML frontmatter in SKILL.md
- **Gemini**: JSON manifest file
- **Conversion**: Bidirectional YAML ↔ JSON transformation
### Tool Restrictions
- **Claude**: `allowed-tools` (whitelist - only listed tools permitted)
- **Gemini**: `excludeTools` (blacklist - listed patterns blocked)
- **Conversion**: Logic inversion with intelligent mapping
### Configuration
- **Claude**: Environment variables (user sets before running)
- **Gemini**: Settings schema (prompted during installation)
- **Conversion**: Infer schema from env vars or generate env var docs
### MCP Server Paths
- **Claude**: Relative paths from skill directory
- **Gemini**: Uses `${extensionPath}` variable substitution
- **Conversion**: Automatic path transformation
## Usage Examples
### Convert Claude Skill to Gemini
```
User: "I have a Claude skill at ./database-helper. Convert it to Gemini."
Claude: I'll analyze the skill and convert it to Gemini format...
- Detected Claude skill (found SKILL.md with frontmatter)
- Extracted metadata and MCP configuration
- Generated gemini-extension.json and GEMINI.md
- Transformed allowed-tools to excludeTools
- Created settings schema from environment variables
✓ Conversion complete! Ready to install with: gemini extensions install ./database-helper
```
### Convert Gemini Extension to Claude
```
User: "Port my Gemini extension to Claude Code"
Claude: I'll convert this Gemini extension to a Claude skill...
- Detected Gemini extension (found gemini-extension.json)
- Extracted manifest and context file
- Generated SKILL.md with YAML frontmatter
- Created .claude-plugin/marketplace.json
- Converted excludeTools to allowed-tools
✓ Conversion complete! Install with: cp -r ./extension ~/.claude/skills/
```
### Create Universal Extension
```
User: "Make this skill work on both platforms"
Claude: I'll create a universal extension structure...
- Analyzing current configuration
- Generating both Claude and Gemini files
- Moving shared content to shared/ directory
- Updating MCP server paths for both platforms
✓ Universal extension created! Works with both Claude Code and Gemini CLI
```
## Advanced Features
### Pull Request Generation
Create a PR to add dual-platform support to the parent repository:
**Example requests:**
- "Convert this skill and create a PR to add Gemini support"
- "Generate a pull request with the universal version"
### Fork and Dual Setup
Create a fork with both platform configurations:
**Example requests:**
- "Fork this repo and set it up for both platforms"
- "Create a dual-platform fork I can use with both CLIs"
### Validation Only
Check compatibility without converting:
**Example requests:**
- "Validate this skill's conversion to Gemini"
- "Check if this extension can be ported to Claude"
- "What needs to change to make this universal?"
## Configuration
This skill operates directly on filesystem directories and doesn't require external configuration. It uses:
- File system access to read and write skill/extension files
- Git operations for PR and fork features
- GitHub CLI (`gh`) for repository operations
## Safety Features
- **Non-destructive**: Creates new files, doesn't modify source unless explicitly requested
- **Validation**: Checks output before completion
- **Reporting**: Clear summary of changes made
- **Rollback friendly**: All changes are standard file operations
## Limitations
Some aspects may require manual review:
- Custom slash commands (platform-specific syntax)
- Complex MCP server configurations with multiple servers
- Platform-specific scripts that don't translate directly
- Edge cases in tool restriction mapping
These will be flagged in the conversion report.
## Technical Details
### Tool Restriction Conversion
**Claude → Gemini (Whitelist → Blacklist)**:
- Analyze allowed-tools list
- Generate exclude patterns for all other tools
- Special handling for wildcard permissions
**Gemini → Claude (Blacklist → Whitelist)**:
- List all available tools
- Remove excluded tools
- Generate allowed-tools list
### Settings Inference
When converting Claude → Gemini, environment variables in MCP config become settings:
```javascript
// MCP env var
"env": { "DB_HOST": "${DB_HOST}" }
// Becomes Gemini setting
"settings": [{
"name": "DB_HOST",
"description": "Database host",
"default": "localhost"
}]
```
### Path Transformation
Claude uses relative paths, Gemini uses variables:
```javascript
// Claude
"args": ["mcp-server/index.js"]
// Gemini
"args": ["${extensionPath}/mcp-server/index.js"]
```
---
*For implementation details, see the repository at https://github.com/jduncan-rva/skill-porter*