Skip to content

feat: worktree 削除アクション(dirty ガード・確認付き)#23

Merged
sasagar merged 1 commit into
devfrom
feature/session-cleanup
Jul 1, 2026
Merged

feat: worktree 削除アクション(dirty ガード・確認付き)#23
sasagar merged 1 commit into
devfrom
feature/session-cleanup

Conversation

@sasagar

@sasagar sasagar commented Jul 1, 2026

Copy link
Copy Markdown
Contributor

Closes #13

概要

「閉じる」(一覧から外すだけ・worktree は残す)とは分離した、worktree を削除する破壊的アクションを追加。

内容

  • セッション行の右クリックに 「worktree を削除…」role: .destructive)。
  • 削除前に isWorktreeDirty で判定し、dirty なら確認文言を「強制削除(変更を破棄)」に切替。clean は通常削除。
  • 実削除は git worktree removerm -rf は不使用)。dirty は --force でのみ削除。
  • main worktree や git エラーは alert で stderr を表示

確認

  • xcodebuild 成功、再起動して安定動作。
  • git レベルのガードを CLI で確認: dirty は git worktree remove が拒否(use --force)、--force で削除成功。

補足(後続で追加可能)

  • 「実行中(エージェント稼働中)」ガードは未実装(agent status を store に橋渡しする必要があるため)。当面は dirty ガード+確認で保護。
  • UI の右クリック→ダイアログの自動クリック検証は、同時起動の Supacode とフォーカスが競合するため未実施(git 挙動とビルドは確認済み)。

セッション行の右クリックに「worktree を削除…」を追加。閉じる(一覧から外す)
とは分離した破壊的アクション。削除前に dirty を判定し、変更があれば確認文言を
「強制削除(変更を破棄)」に切替えて --force で削除。clean は通常削除。rm -rf は
使わず git worktree remove のみ。main worktree や git エラーは alert で表示。
- SessionStore.isWorktreeDirty / removeWorktree(force:) を追加
Closes #13
@sasagar sasagar marked this pull request as ready for review July 1, 2026 08:21
@sasagar sasagar merged commit 22aaf68 into dev Jul 1, 2026
1 check passed
@sasagar sasagar deleted the feature/session-cleanup branch July 1, 2026 08:23
sasagar added a commit that referenced this pull request Jul 1, 2026
セッション行の右クリックに「worktree を削除…」を追加。閉じる(一覧から外す)
とは分離した破壊的アクション。削除前に dirty を判定し、変更があれば確認文言を
「強制削除(変更を破棄)」に切替えて --force で削除。clean は通常削除。rm -rf は
使わず git worktree remove のみ。main worktree や git エラーは alert で表示。
- SessionStore.isWorktreeDirty / removeWorktree(force:) を追加
Closes #13
@github-actions github-actions Bot mentioned this pull request Jul 1, 2026
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