Goose vs Kilo CodeComparisonUpdated 2026-03-18
SUMMARY
Goose (CLI) uses text configuration while Kilo Code (IDE) uses markdown. They differ on 4 of 11 compared features. Both tools provide AI-assisted development but take different approaches to project configuration.
FEATURE COMPARISON
| Feature | Goose | Kilo Code |
|---|---|---|
| Config format | text | markdown |
| Hierarchy support | ✓ | ✗ |
| Global config | ✓ | ✗ |
| Project config | ✓ | ✓ |
| Subdirectory scoping | ✗ | ✗ |
| File inclusion / imports | ✗ | ✗ |
| Ignore file | ✗ | ✗ |
| IDE integration | CLI | ✓ |
| Schema / structure | Free-form (Markdown) | Free-form (Markdown) |
| Git committed | ✓ | ✓ |
| Encoding | UTF-8 | UTF-8 |
FILE MAPPING
| Purpose | Goose | Kilo Code |
|---|---|---|
| Settings / configuration | config.yaml | .kilocodemodes |
SIDE-BY-SIDE CODE SAMPLES
Goose
.goosehints
text
This is a Ruby on Rails 7.2 application with Hotwire/Turbo.
Database: PostgreSQL 16
Ruby version: 3.3.x
Node: 22.x (for asset pipeline)
Key commands:
- bin/rails server — start dev server
- bin/rails test — run test suite
- bin/rails db:migrate — run migrations
Conventions:
- Use ViewComponents for reusable UI
- Stimulus controllers for JS behavior
- System tests with Capybara + Playwright
- RuboCop for linting (run: bundle exec rubocop)
Kilo Code
.kilorules
markdown
# Project Rules
## Stack
- TypeScript 5.x with strict mode
- React 19 + Next.js 15 (App Router)
- Tailwind CSS v4 for styling
- Drizzle ORM for database access
## Code Standards
- Named exports only (no default exports)
- Prefer `const` assertions and satisfies operator
- Use Result<T, E> pattern for error handling
- Maximum 30 lines per function
## File Organization
- Colocate tests: `foo.ts` → `foo.test.ts`
- One component per file
- Barrel exports (index.ts) for public module APIs
## Git
- Conventional commits: feat|fix|chore|docs|test
- Squash merge feature branches
- Branch naming: type/description
KEY DIFFERENCES
Goose: text. Kilo Code: markdown.
Goose: Supported. Kilo Code: Not supported.
Goose: Supported. Kilo Code: Not supported.
Goose: CLI. Kilo Code: Supported.
WHICH SHOULD I USE?
Choose based on your IDE/CLI preference. If you use Goose, configure config.yaml. If you use Kilo Code, configure .kilocodemodes. Many projects include config files for multiple tools so each team member can use their preferred editor.
PORTABILITY TIP
sync-instructions.sh
bash
# Maintain a single source of truth:
cp AI-INSTRUCTIONS.md CLAUDE.md
cp AI-INSTRUCTIONS.md .cursorrules
cp AI-INSTRUCTIONS.md AGENTS.md
SEE ALSO
File references:
agentconfig.ing2026-03-18COMPARE(1)