altair823
765ffc97c5
feat(kebab-tui): p9-fb-12 follow-up — heuristic 제거, mode-authoritative dispatch
p9-fb-12 partial (PR #84) 의 deferred 부분 finalize. spec contract 의
\"기존 P9-3 ask 의 e/j/k input-empty heuristic 제거 — mode 로 명확히\"
완료. spec status `in_progress` → `completed`.
## 핵심 변경
- **`search::is_typing_mod`** (CTRL/ALT chord filter) 함수 삭제.
search Char dispatch 가 `state.mode` 로 분기:
- Normal + plain `j`/`k` → 선택 이동 (Char 이라도 Normal 이면
navigation)
- Insert + plain `j`/`k`/Char(c) (chord 제외) → input.push
- Insert + CTRL/ALT chord → no-op (예약 — 향후 binding 위해)
- Normal + 그 외 Char → no-op (no typing in Normal)
- **`search::handle_key_search` 의 `i` (chunk inspect) / `g` (editor
jump) pre-pass** 가 `state.mode == Mode::Normal` 일 때만 fire.
Insert 모드면 typed char (input 에 push). 기존 SHIFT-aware
matches!() 가드는 Normal-mode 진입 가드로 흡수.
- **`ask::handle_key_ask`** 의 input-empty heuristic 삭제. e/j/k:
- Normal + `e` → toggle explain
- Normal + `j` → scroll down (saturating_add)
- Normal + `k` → scroll up (saturating_sub)
- Insert + 모든 plain Char (chord 제외) → input.push
- **테스트 fixture** (`tests/search.rs::fresh_app`,
`tests/ask.rs::fresh_app`) 에 `app.mode = Mode::auto_for(focus)`
추가 — run loop 의 auto-flip 동작을 테스트가 mirror.
- **기존 nav 테스트** (`j_k_move_selection_within_bounds`,
`g_key_enqueues_pending_editor_request`, `e_toggles_explain_in_
normal_mode`) 가 `app.mode = Mode::Normal` 명시.
- **신규 4 테스트** mode-authoritative 동작 회귀 방지:
- search: `j_in_insert_types_does_not_move_selection`,
`arbitrary_char_in_normal_mode_is_noop`
- ask: `e_types_in_insert_mode_does_not_toggle_explain`,
`jk_scroll_in_normal_mode_type_in_insert`
## 테스트
- 기존 109 + 신규 4 = 113 TUI 테스트 통과 (38 lib + 20 ask + 12
inspect + 10 library + 6 mode + 25 search + 2 chat — search 23→25,
ask 18→20)
- `cargo test --workspace --no-fail-fast -j 1` exit 0
- `cargo clippy --workspace --all-targets -- -D warnings` clean
## 문서
- README `kebab tui` 행: \"mode-authoritative dispatch — Search 의
j/k/i/g, Ask 의 e/j/k 는 NORMAL 모드에서만 명령으로 동작, INSERT
에서는 입력 문자로 typing\" 명시
- HANDOFF: 2026-05-03 follow-up entry
- spec status `in_progress` → `completed`
## HOTFIXES
p9-fb-12 partial PR (#84) 의 \"Deferred\" 항목이 본 PR 로 finalized
— HOTFIXES 새 entry 불필요 (기존 entry 가 이미 deferral 사유 + 해결
조건 명시).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-03 07:50:04 +00:00
..
2026-05-02 13:26:24 +00:00
2026-05-02 14:38:17 +00:00
2026-05-02 15:24:26 +00:00
2026-05-02 15:41:11 +00:00
2026-05-02 04:01:55 +00:00
2026-05-02 18:02:54 +00:00
2026-05-02 19:57:02 +00:00
2026-05-02 20:27:44 +00:00
2026-05-02 20:47:11 +00:00
2026-05-02 21:40:22 +00:00
2026-05-03 04:23:53 +00:00
2026-05-02 18:47:23 +00:00
2026-05-03 01:27:33 +00:00
2026-05-03 03:55:58 +00:00
2026-05-03 02:36:08 +00:00
2026-05-02 17:54:15 +00:00
2026-05-03 03:37:24 +00:00
2026-05-03 07:50:04 +00:00
2026-05-02 17:54:15 +00:00
2026-05-03 03:13:26 +00:00
2026-05-02 23:15:33 +00:00
2026-05-03 00:04:04 +00:00
2026-05-03 05:41:25 +00:00
2026-05-03 06:26:06 +00:00
2026-05-03 05:08:38 +00:00
2026-05-03 00:41:19 +00:00