| 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.mdwith YAML frontmatter or.claude-plugin/marketplace.json - Gemini: Presence of
gemini-extension.jsonorGEMINI.mdcontext 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:
- Analyze the source directory structure
- Detect which platform it's built for
- Extract metadata, MCP configuration, and documentation
- Transform the data to target platform format
- Generate required files for target platform
- Validate output meets all requirements
- 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:
// 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:
// 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