Skip to content

fix: /cwd 切换工作目录前校验路径存在#42

Open
1359484419 wants to merge 2 commits into
Wechat-ggGitHub:mainfrom
1359484419:fix/cwd-validate-path
Open

fix: /cwd 切换工作目录前校验路径存在#42
1359484419 wants to merge 2 commits into
Wechat-ggGitHub:mainfrom
1359484419:fix/cwd-validate-path

Conversation

@1359484419

Copy link
Copy Markdown

问题

/cwd 原来直接把用户输入写入 session,不做任何校验。一旦路径输错,下次对话时 claude 会在一个不存在的 cwd 里 spawn,导致失败,且错误信息隐晦、难以排查。(对比之下 /send 已经有 existsSync 校验,/cwd 缺。)

改动

  • 展开 ~、把相对路径解析为绝对路径(基于当前工作目录)
  • 切换前校验目标存在确实是目录,否则提示并拒绝切换
  • 存储解析后的绝对路径,与 /send 的校验风格保持一致

验证

  • npm run build(tsc)通过
  • 独立验证 handleCwd 四种情况:存在目录→切换、不存在→拒绝、是文件→拒绝、空参→显示当前 —— 全部符合预期

xiao added 2 commits June 19, 2026 21:35
/cwd 原来直接把参数写入 session、不做任何校验,输错路径后下次对话
claude 会在不存在的 cwd 里 spawn 失败,错误很隐晦、难排查。

- 展开 ~、把相对路径解析为绝对路径(基于当前工作目录)
- 校验目标存在且确实是目录,否则提示并拒绝切换
- 存储解析后的绝对路径,与 /send 的校验风格保持一致
手机输入法或 markdown 代码格式常给路径自动加上反引号或引号(如
\`/path\`、'/path'),导致路径开头不是 / 被当成相对路径拼接、校验失败。
切换前先剥离首尾的反引号/单双引号/空格。
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant