packages/kilo-docs/pages/getting-started/migrating.md
Quickly migrate your custom rules from Cursor or Windsurf to Kilo Code. The process typically takes just a few minutes per project.
{% callout type="info" title="Two Workflow Approaches"%}
Kilo Code supports two complementary workflows—choose the one that fits your style, or use both:
Many developers combine both approaches: autocomplete for quick completions while typing, and chat for larger refactors or multi-file changes. See Choosing Your Workflow for details.
{% /callout %}
Kilo Code simplifies AI configuration while adding powerful new capabilities:
Choose your current tool:
| Cursor | Kilo Code | Key Difference |
|---|---|---|
.cursor/rules/*.mdc with YAML frontmatter | .kilocode/rules/*.md plain Markdown | No YAML metadata required |
alwaysApply: true/false metadata | File location determines scope | Scope controlled by directory structure |
globs: ["*.ts"] for file patterns | Mode-specific directories or custom modes | File patterns handled via custom modes |
description for AI activation | Clear file names and organization | Relies on explicit file organization |
| Global rules in UI settings | ~/.kilocode/rules/*.md files | Global rules stored as files in home folder |
1. Identify your rules:
ls -la .cursor/rules/ # Project rules
ls -la .cursorrules # Legacy file (if present)
2. Create Kilo Code directory:
mkdir -p .kilocode/rules
3. Convert .mdc files to .md:
For each file in .cursor/rules/, remove the YAML frontmatter and keep just the Markdown content.
Cursor format:
---
description: TypeScript coding standards
globs: ["*.ts", "*.tsx"]
alwaysApply: false
---
# TypeScript Standards
- Always use TypeScript for new files
- Prefer functional components in React
Kilo Code format:
# TypeScript Standards
- Always use TypeScript for new files
- Prefer functional components in React
4. Migrate in one command:
# Copy all files
for file in .cursor/rules/*.mdc; do
basename="${file##*/}"
cp "$file" ".kilocode/rules/${basename%.mdc}.md"
done
# Then manually edit each file to remove YAML frontmatter (the --- section at the top)
5. Migrate global rules:
Cursor Settings → General → Rules for AI~/.kilocode/rules/cursor-global.md6. Handle legacy .cursorrules:
cp .cursorrules .kilocode/rules/legacy-rules.md
globs PatternsCursor's globs field specifies which files a rule applies to. Kilo Code handles this through mode-specific directories instead.
Cursor approach:
---
globs: ["*.ts", "*.tsx"]
---
Rules for TypeScript files...
Kilo Code approach (Option 1 - Mode-specific directory):
mkdir -p .kilocode/rules-code
# Save TypeScript-specific rules here
Kilo Code approach (Option 2 - Custom mode):
# .kilocodemodes (at project root)
- slug: typescript
name: TypeScript
roleDefinition: You work on TypeScript files
groups:
- read
- [edit, { fileRegex: '\\.tsx?$' }]
- ask
Then place rules in .kilocode/rules-typescript/
Cursor supports nested .cursor/rules/ directories. Kilo Code uses flat structure with descriptive names:
# Cursor: .cursor/rules/backend/server/api-rules.mdc
# Kilo Code: .kilocode/rules/backend-server-api-rules.md
| Windsurf | Kilo Code | Key Difference |
|---|---|---|
.windsurf/rules/*.md | .kilocode/rules/*.md | Same Markdown format |
| GUI configuration for activation modes | File location determines scope | Scope controlled by directory structure |
| "Always On" mode (GUI) | Place in .kilocode/rules/ | Rules stored as files, not GUI settings |
| "Glob" mode (GUI) | Mode-specific directories | File patterns handled via mode directories |
| 12,000 character limit per rule | No hard limit | No character limit on rule files |
Global rules in ~/.codeium/windsurf/memories/global_rules.md | ~/.kilocode/rules/*.md | Global rules in home folder, multiple files |
1. Identify your rules:
ls -la .windsurf/rules/ # Project rules
ls -la .windsurfrules # Legacy file (if present)
2. Create Kilo Code directory:
mkdir -p .kilocode/rules
3. Copy files directly (already Markdown):
cp .windsurf/rules/*.md .kilocode/rules/
4. Migrate global rules:
cp ~/.codeium/windsurf/memories/global_rules.md ~/.kilocode/rules/global-rules.md
5. Handle legacy .windsurfrules:
cp .windsurfrules .kilocode/rules/legacy-rules.md
6. Split large rules if needed:
If you had rules approaching the 12,000 character limit, split them:
# Instead of one large file:
# .windsurf/rules/all-conventions.md (11,500 chars)
# Split into focused files:
# .kilocode/rules/api-conventions.md
# .kilocode/rules/testing-standards.md
# .kilocode/rules/code-style.md
Windsurf configures activation through the GUI. In Kilo Code, file organization replaces GUI configuration:
| Windsurf GUI Mode | Kilo Code Equivalent |
|---|---|
| Always On | Place in .kilocode/rules/ (default) |
| Glob (file patterns) | Mode-specific directory or custom mode |
| Model Decision | Clear file names by concern (e.g., testing-guidelines.md) |
| Manual | Organize with descriptive names |
Example - Converting a Glob rule:
If you had a rule in Windsurf with Glob mode set to *.test.ts, create a custom test mode:
# .kilocodemodes (at project root)
- slug: test
name: Testing
roleDefinition: You write and maintain tests
groups:
- read
- [edit, { fileRegex: '\\.(test|spec)\\.(ts|js)$' }]
- ask
Then place the rule in .kilocode/rules-test/
All three tools support the AGENTS.md standard. If you have one, it works in Kilo Code automatically:
# Verify it exists
ls -la AGENTS.md
# That's it - Kilo Code loads it automatically (enabled by default)
Important: Use uppercase AGENTS.md (not agents.md). Kilo Code also accepts AGENT.md (singular) as a fallback.
Note: Both AGENTS.md and AGENT.md are write-protected files in Kilo Code and require user approval to modify.
This is Kilo Code's unique feature that replaces both Cursor's globs and Windsurf's activation modes.
.kilocode/rules/ # Apply to ALL modes
.kilocode/rules-code/ # Only in Code mode
.kilocode/rules-debug/ # Only in Debug mode
.kilocode/rules-ask/ # Only in Ask mode
.kilocode/rules-{custom}/ # Only in your custom mode
From Cursor:
---
description: Testing best practices
globs: ["**/*.test.ts", "**/*.spec.ts"]
---
# Testing Rules
- Write tests for all features
- Maintain >80% coverage
To Kilo Code:
# 1. Create test mode directory
mkdir -p .kilocode/rules-test
# 2. Save rule as plain Markdown
cat > .kilocode/rules-test/testing-standards.md << 'EOF'
# Testing Rules
- Write tests for all features
- Maintain >80% coverage
EOF
# 3. Define the mode (optional - creates a custom mode)
# Add to .kilocode/config.yaml:
# modes:
# - slug: test
# name: Test Mode
# groups: [read, edit, ask]
After migration:
.kilocode/rules/ locationgit add .kilocode/.cursor/ or .windsurf/ folders once verifiedCheck file location:
ls -la .kilocode/rules/ # Project rules
ls -la ~/.kilocode/rules/ # Global rules
Verify file format:
.md, .txt, etc.) - binary files are automatically filtered out.cache, .tmp, .log, .bak, etc.)Reload VS Code:
Cmd+R (Mac) or Ctrl+R (Windows/Linux)Cursor's globs, alwaysApply, and description don't transfer automatically. Solutions:
.kilocode/rules/Windsurf's GUI activation modes (Always On/Glob/Model Decision/Manual) aren't stored in files. Solutions:
Cursor's nested directories don't map to Kilo Code. Flatten with descriptive names:
# Bad: .cursor/rules/backend/api/rules.mdc
# Good: .kilocode/rules/backend-api-rules.md
AGENTS.md or AGENT.md (uppercase)Kilo Code supports both autocomplete and chat-driven workflows. Choose the approach that fits your coding style, or combine them:
Autocomplete (Ghost) — Tab-to-accept inline suggestions:
This works the same way as Cursor and Windsurf's autocomplete. Ghost provides context-aware suggestions as you type.
Chat-driven — describe what you want:
Combining both workflows:
Many developers use both approaches together:
There's no "right" workflow—use whatever helps you code faster
For complex workflows, define custom modes with their own rules and permissions:
# .kilocodemodes (at project root)
- slug: review
name: Code Review
roleDefinition: You review code and suggest improvements
groups:
- read
- ask
# Note: No edit permission - review mode is read-only
- slug: docs
name: Documentation
roleDefinition: You write and maintain documentation
groups:
- read
- [edit, { fileRegex: '\\.md$', description: "Markdown files only" }]
- ask
Then create corresponding rule directories:
mkdir -p .kilocode/rules-review
mkdir -p .kilocode/rules-docs
Note: .kilocodemodes can be in YAML (preferred) or JSON format. For global modes, edit the custom_modes.yaml file via Settings > Edit Global Modes.
Cursor users:
Windsurf users:
Cross-tool: