fix(mcp): pass workspace roots to servers#1625
Conversation
|
Substantial MCP roots work, matches the spec, and the test in Drift
The change flips What to do
Main's moving fast this week (a couple of other contributors hit the same drift today on PRs that opened earlier). If the rebase takes more than a few hours you may need a second one. Push when ready and I'll merge — the fix itself is in great shape. |
6361b11 to
9565fbd
Compare
…moved, persisted usage stats, plan dispatch gate Headline themes: - Desktop: bundle the CLI-hosted React dashboard, retire Tauri+Preact duplicate (#1418) - Config: drop preset abstraction; flash/pro are direct model selections (#1657, #1630) - Stats: persist cumulative usage to session meta + auto-restore on startup (#1667, #1680, #1643, #1628) - Plans: editMode="plan" enforced at the ToolRegistry dispatch gate (#1681); step advance fix (#1629) - Context: fold once at turn start, drop pre-flight + byte-ceiling (#1642, #1646); collapsible compacted card (#1649) - Subagents: per-skill flash/pro override + Settings UI (#1632) - Desktop polish: sidebar drag-resize (#1688), responsive collapse (#1585), copy/edit overlay + msg-history nav (#1645), Esc closes modal not turn (#1685), QQ tab isolation (#1672), DiffCard for edits (#1662), theme-aware highlighting (#1655), system events toggle (#1654/#1650), macOS TCC inheritance (#1614), dashboard.enabled (#1612) - Dashboard polish: persistent session URL (#1586, #1589, #1599), theme-aware highlighting (#1664), IME confirm-enter guard (#1689), code-fence lang fix (#1677), vendor chunk split (#1587), markdown table h-scroll (#1562) - TUI: Alt+S input stash/recall; static history isolated from input rerenders (#1635); legacy mouse drop (#1637, #1648); multi-edit gated in review (#1647) - Diff: SplitDiff column border holds under CJK (#1686) - MCP: workspace roots passed to servers (#1625); codeCommand honors mcpServers (#1603) - Config plumbing: (baseUrl, apiKey) resolved as a tuple (#1658); stale model id self-heal (#1663) See CHANGELOG for the full list.
What
Send workspace root context to MCP servers during initialization and answer roots/list requests, while launching stdio MCP servers from the same workspace directory.
Why
Fixes #1397. Servers that infer project state from rootUri, workspaceFolders, roots/list, or process cwd could not auto-detect the active project and required hardcoded path arguments.
How to verify
npm test -- tests/mcp.test.tsnpm test -- tests/mcp.test.ts tests/mcp-env-config.test.ts tests/acp-mcp.test.ts tests/chat-mcp-startup-summary.test.ts tests/mcp-reconnect.test.ts tests/mcp-runtime-failures.test.tsnpm run typechecknpm run verifyChecklist
npm run verifypasses locally (lint + typecheck + tests + comment-policy gate)Co-Authored-By: Claudetrailer in commitsCHANGELOG.md— release notes are maintainer-written at release time