Files
kebab/tasks/p9/p9-fb-08-search-debounce.md
altair823 20f5e247f9 chore(tasks): mark p9-fb-08 completed
PR #74 머지 (be0a96e). 머지 후 spec status 갱신.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-03 03:55:58 +00:00

54 lines
1.7 KiB
Markdown

---
phase: P9
component: kebab-tui (search pane)
task_id: p9-fb-08
title: "Search debounce + Enter-immediate trigger"
status: completed
depends_on: []
unblocks: []
contract_source: ../../docs/superpowers/specs/2026-04-27-kebab-final-form-design.md
contract_sections: [§10 UX]
source_feedback: p9-dogfooding-feedback.md item 6
---
# p9-fb-08 — Search debounce
## Goal
TUI search pane 의 keystroke-by-keystroke 검색 제거. debounce 250ms + Enter 즉시 trigger.
## Allowed dependencies
- 기존 kebab-tui deps.
## Public surface
`kebab-tui::search::SearchState``debounce_at: Option<Instant>` 추가. main run-loop tick 에서 check.
## Behavior contract
- 글자 입력 / backspace → `debounce_at = Instant::now() + 250ms`. 기존 in-flight worker 는 cancel 신호 받음 (다음 step 에서 drop, 결과 stale 으로 폐기).
- main loop 가 매 tick 마다 `if Instant::now() >= debounce_at && state.dirty { spawn search worker; debounce_at=None }`.
- Enter 누름 → debounce 무시 즉시 spawn.
- 같은 query 로 재 spawn 방지 (간단 dedupe — 직전 query 와 비교).
- worker 결과 도착 시 generation counter 비교: 사용자가 추가 입력해 query 가 바뀌면 stale 결과 drop.
- generation counter pattern 은 p9-fb-19 cache 와 같은 prerequisite — 코드 공유.
## Test plan
| kind | description |
|------|-------------|
| unit | 글자 5 회 빠르게 입력 → worker spawn 1 회 |
| unit | Enter 즉시 spawn |
| unit | 입력 → 결과 도착 → 추가 입력 → stale drop |
## DoD
- [ ] `cargo test -p kebab-tui` 통과
- [ ] README TUI search 절에 debounce 동작 명시
## Out of scope
- search 결과 캐싱 (p9-fb-19 별도)
- CLI search 동작 변경 (CLI 는 단발)