技能 编程开发 Windsurf核心工作流:多文件代理编码

Windsurf核心工作流:多文件代理编码

v20260423
windsurf-core-workflow-a
这是一套强大的代理式工作流,用于复杂的软件开发任务。Cascade写入模式充当自主编码代理,用户只需通过自然语言提示,即可完成构建新功能、跨文件重构代码、运行终端命令和调试错误等全栈开发任务。适用于大型系统构建和复杂代码维护。
获取技能
116 次下载
概览

Windsurf Core Workflow A — Cascade Write Mode

Overview

Cascade Write mode is Windsurf's primary productivity tool. It acts as an autonomous agent that can create files, modify code across multiple files, run terminal commands, install dependencies, and debug errors -- all from a single natural language prompt. This is the "money-path" workflow for Windsurf users.

Prerequisites

  • Windsurf IDE with Cascade enabled
  • .windsurfrules configured (see windsurf-sdk-patterns)
  • Git initialized with clean working tree

Instructions

Step 1: Create a Git Checkpoint

Always commit or stash before a Cascade session. Cascade writes directly to your files.

git add -A && git commit -m "checkpoint: before cascade session"
# Or for uncommitted work:
git stash push -m "pre-cascade stash"

Step 2: Open Cascade in Write Mode

Press Cmd/Ctrl+L to open the Cascade panel. Ensure "Write" mode is selected (not "Chat"). Write mode allows Cascade to:

  • Create and modify files
  • Run terminal commands (with Turbo or per-command approval)
  • Install dependencies
  • Read terminal output for debugging
  • Open browser previews

Step 3: Write an Effective Prompt

Structure your prompt with scope, specifics, and constraints:

"In src/services/, create a NotificationService that:
1. Sends email via Resend API (already in package.json)
2. Sends Slack messages via webhook URL from env
3. Uses the Result<T,E> pattern from src/types/result.ts
4. Includes retry logic with exponential backoff (max 3 retries)
5. Add unit tests in tests/services/notification.test.ts
Don't modify any existing files except to add exports."

Step 4: Review Cascade's Plan and Execution

Cascade shows its reasoning and plan before executing:

Cascade output flow:
1. "I'll create the notification service with email and Slack support..."
2. Creates src/services/notification.ts (shows diff)
3. Creates tests/services/notification.test.ts (shows diff)
4. Runs: npm install resend (if needed)
5. Runs: npx vitest run tests/services/notification.test.ts
6. Reports results

Review each file diff in the Cascade output. You can:

  • Revert individual steps by hovering over a step and clicking the revert arrow
  • Revert all to return to the state before the Cascade session
  • Create named checkpoints for complex multi-step sessions

Step 5: Iterate on Errors

If tests fail, Cascade retains context about what it just did:

"The test for sendSlack is failing with 'fetch is not defined'.
Fix it by using the node:test built-in fetch mock."

Cascade reads the error, understands its own recent changes, and applies targeted fixes.

Step 6: Use @ Mentions for Precision

@src/types/result.ts — force Cascade to read this file for the Result pattern
@src/services/       — reference the entire services directory for consistency
@web resend API docs  — search the web for current Resend documentation

Output

  • Multi-file code changes applied by Cascade
  • Terminal commands executed (installs, tests, builds)
  • Test results confirming implementation correctness
  • Reviewable diffs for every file change

Error Handling

Issue Cause Solution
Cascade modifies wrong files Vague prompt Specify exact file paths and constraints
Changes break existing tests No constraint on existing code Add "don't modify existing files" to prompt
Cascade loops on error Insufficient context Paste the full error message, reference relevant files
Write mode not available On Free plan with no credits Check credit balance at windsurf.com/account
Cascade ignores .windsurfrules Rules file > 6,000 chars Trim rules or split into workspace rules

Examples

Full-Stack Feature

"Add a user profile page:
1. Create app/profile/page.tsx as a Server Component
2. Create app/profile/edit/page.tsx as a Client Component with form
3. Add GET /api/profile and PUT /api/profile route handlers
4. Use the existing UserSchema from lib/types/user.ts for validation
5. Style with Tailwind matching the existing design system
6. Add tests for both API routes"

Refactoring Task

"Extract the authentication logic from src/middleware/auth.ts into:
- src/services/auth.ts (JWT validation, token refresh)
- src/services/session.ts (session management)
Update all imports across the codebase. Run tests after."

Resources

Next Steps

For configuration management workflow, see windsurf-core-workflow-b.

信息
Category 编程开发
Name windsurf-core-workflow-a
版本 v20260423
大小 5.19KB
更新时间 2026-04-28
语言