Awesome-omni-skill migrate-to-skills
Convert 'Applied intelligently' Cursor rules (.cursor/rules/*.mdc) and slash commands (.cursor/commands/*.md) to Agent Skills format (.cursor/skills/). Use when you want to migrate rules or commands to skills, convert .mdc rules to SKILL.md format, or consolidate commands into the skills directory.
git clone https://github.com/diegosouzapw/awesome-omni-skill
T=$(mktemp -d) && git clone --depth=1 https://github.com/diegosouzapw/awesome-omni-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/backend/migrate-to-skills" ~/.claude/skills/diegosouzapw-awesome-omni-skill-migrate-to-skills-b647ba && rm -rf "$T"
skills/backend/migrate-to-skills/SKILL.mdMigrate Rules and Slash Commands to Skills
Convert Cursor rules ("Applied intelligently") and slash commands to Agent Skills format.
CRITICAL: Preserve the exact body content. Do not modify, reformat, or "improve" it - copy verbatim.
Locations
| Level | Source | Destination |
|---|---|---|
| Project | , | |
| User | |
Notes:
- Cursor rules inside the project can live in nested directories. Be thorough in your search and use glob patterns to find them.
- Ignore anything in ~/.cursor/worktrees
- Ignore anything in ~/.cursor/skills-cursor. This is reserved for Cursor's internal built-in skills and is managed automatically by the system.
Finding Files to Migrate
Rules: Migrate if rule has a
description but NO globs and NO alwaysApply: true.
Commands: Migrate all - they're plain markdown without frontmatter.
Conversion Format
Rules: .mdc → SKILL.md
# Before: .cursor/rules/my-rule.mdc --- description: What this rule does globs: alwaysApply: false --- # Title Body content...
# After: .cursor/skills/my-rule/SKILL.md --- name: my-rule description: What this rule does --- # Title Body content...
Changes: Add
name field, remove globs/alwaysApply, keep body exactly.
Commands: .md → SKILL.md
# Before: .cursor/commands/commit.md # Commit current work Instructions here...
# After: .cursor/skills/commit/SKILL.md --- name: commit description: Commit current work with standardized message format disable-model-invocation: true --- # Commit current work Instructions here...
Changes: Add frontmatter with
name (from filename), description (infer from content), and disable-model-invocation: true, keep body exactly.
Note: The
disable-model-invocation: true field prevents the model from automatically invoking this skill. Slash commands are designed to be explicitly triggered by the user via the / menu, not automatically suggested by the model.
Notes
must be lowercase with hyphens onlyname
is critical for skill discoverydescription- Optionally delete originals after verifying migration works
Migrate a Rule (.mdc → SKILL.md)
- Read the rule file
- Extract the
from the frontmatterdescription - Extract the body content (everything after the closing
of the frontmatter)--- - Create the skill directory:
(skill name = filename without .mdc).cursor/skills/{skill-name}/ - Write
with new frontmatter (SKILL.md
andname
) + the EXACT original body content (preserve all whitespace, formatting, code blocks verbatim)description - Delete the original rule file
Migrate a Command (.md → SKILL.md)
- Read the command file
- Extract description from the first heading (remove
prefix)# - Create the skill directory:
(skill name = filename without .md).cursor/skills/{skill-name}/ - Write
with new frontmatter (SKILL.md
,name
, anddescription
) + blank line + the EXACT original file content (preserve all whitespace, formatting, code blocks verbatim)disable-model-invocation: true - Delete the original command file
CRITICAL: Copy the body content character-for-character. Do not reformat, fix typos, or "improve" anything.
Workflow
If you have the Task tool available: DO NOT start to read all of the files yourself. That function should be delegated to the subagents. Your job is to dispatch the subagents for each category of files and wait for the results.
- Create the skills directories if they don't exist (
for project,.cursor/skills/
for user)~/.cursor/skills/ - Dispatch three fast general purpose subagents (NOT explore) in parallel to do the following steps for project rules (pattern:
), user commands (pattern:{workspaceFolder}/**/.cursor/rules/*.mdc
), and project commands (pattern:~/.cursor/commands/*.md
): I. [ ] Find files to migrate in the given pattern II. [ ] For rules, check if it's an "applied intelligently" rule (has{workspaceFolder}/**/.cursor/commands/*.md
, nodescription
, noglobs
). Commands are always migrated. DO NOT use the terminal to read files. Use the read tool. III. [ ] Make a list of files to migrate. If empty, done. IV. [ ] For each file, read it, then write the new skill file preserving the body content EXACTLY. DO NOT use the terminal to write these files. Use the edit tool. V. [ ] Delete the original file. DO NOT use the terminal to delete these files. Use the delete tool. VI. [ ] Return a list of all the skill files that were migrated along with the original file paths.alwaysApply: true - Wait for all subagents to complete and summarize the results to the user. IMPORTANT: Make sure to let them know if they want to undo the migration, to ask you to.
- If the user asks you to undo the migration, do the opposite of the above steps to restore the original files.
If you don't have the Task tool available:
- Create the skills directories if they don't exist (
for project,.cursor/skills/
for user)~/.cursor/skills/ - Find files to migrate in both project (
) and user (.cursor/
) directories~/.cursor/ - For rules, check if it's an "applied intelligently" rule (has
, nodescription
, noglobs
). Commands are always migrated. DO NOT use the terminal to read files. Use the read tool.alwaysApply: true - Make a list of files to migrate. If empty, done.
- For each file, read it, then write the new skill file preserving the body content EXACTLY. DO NOT use the terminal to write these files. Use the edit tool.
- Delete the original file. DO NOT use the terminal to delete these files. Use the delete tool.
- Summarize the results to the user. IMPORTANT: Make sure to let them know if they want to undo the migration, to ask you to.
- If the user asks you to undo the migration, do the opposite of the above steps to restore the original files.