Goose vs WindsurfUpdated 2026-03-16

SUMMARY

Goose (CLI) uses text configuration while Windsurf (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

FeatureGooseWindsurf
Config formattextmarkdown
Hierarchy support
Global config
Project config
Subdirectory scoping
File inclusion / imports
Ignore file.codeiumignore
IDE integrationCLI
Schema / structureFree-form (Markdown)Free-form (Markdown)
Git committed
EncodingUTF-8UTF-8

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)

Windsurf
.windsurf/rules/*.md
markdown
---
trigger: glob
globs: "**/*.test.ts"
---

# Testing Conventions

- Use Vitest as the test runner
- Colocate test files next to source files
- Use describe blocks organized by function/component name
- Prefer userEvent over fireEvent in component tests
- Mock external services; never hit real APIs in unit tests

KEY DIFFERENCES

1. Config format

Goose: text. Windsurf: markdown.

2. Subdirectory scoping

Goose: Not supported. Windsurf: Supported.

3. Ignore file

Goose: Not supported. Windsurf: .codeiumignore.

4. IDE integration

Goose: CLI. Windsurf: Supported.

WHICH SHOULD I USE?

Recommendation

Choose based on your IDE/CLI preference. If you use Goose, configure config.yaml. If you use Windsurf, configure .windsurfrules. 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

agentconfig.ing2026-03-16COMPARE(1)