Skip to content

feat(hud): cost velocity indicator (Wave 2-B)#1483

Closed
JeremyDev87 wants to merge 2 commits into
feat/statusbar-wow-refactorfrom
feat/statusbar-wow-velocity
Closed

feat(hud): cost velocity indicator (Wave 2-B)#1483
JeremyDev87 wants to merge 2 commits into
feat/statusbar-wow-refactorfrom
feat/statusbar-wow-velocity

Conversation

@JeremyDev87
Copy link
Copy Markdown
Owner

Closes the velocity issue. Stacked on #1465. 33 new tests. 162/162 pass. Stateless — no hud_state schema changes.

Shows session spend rate next to absolute cost so users can see
whether they're on a slow planning pass or a hot refactor burn:

  $1.23↗$0.08/m

Trend glyphs:
- 🔥 rate >= $0.20/min (hot burn)
- ↗ $0.01 <= rate < $0.20/min (normal/rising)
- → 0 < rate < $0.01/min (steady, very low)
- 💤 rate <= 0 (idle)

Stateless implementation: rate = cost_usd / (duration_ms / 60k).
Uses Claude Code stdin.cost.total_cost_usd and total_duration_ms
directly, with hud_state.sessionStartTimestamp fallback for the
elapsed-time component. Deliberately does NOT touch hud_state.py
schema (costHistory was deferred per Wave 0 review).

New lib/hud_velocity.py:
- TREND_IDLE_MAX=0.01, TREND_HOT_MIN=0.20 constants
- compute_spend_rate(cost_usd, duration_ms) -> float
- trend_glyph(rate) -> str
- format_velocity_segment(stdin_data, hud_state) -> str
- format_cost_with_velocity(cost_usd, stdin, hud_state, *, is_exact)
- _duration_ms_from_state helper for stdin fallback

33 new tests cover:
- compute_spend_rate: zero/negative/non-numeric/numeric-string,
  known rates ($1/min, $0.50/30s, $6/10min)
- trend_glyph: all 4 tiers + boundary values + non-numeric
- format_velocity_segment: empty, missing cost, missing duration,
  zero rate, normal hot, rising tier, state fallback, no state
- format_cost_with_velocity: exact/estimate prefix, no-velocity
  fallback, non-numeric cost, two decimals
- Constant ordering

162/162 pass.

Part of #1464 (Wave 0 statusbar refactor)
@vercel
Copy link
Copy Markdown

vercel Bot commented Apr 11, 2026

The latest updates on your projects. Learn more about Vercel for GitHub.

Project Deployment Actions Updated (UTC)
codingbuddy-landing Ready Ready Preview, Comment Apr 11, 2026 1:24pm

Combined Wave 0 polish items from the #1465/#1485 review cycle:

1. Narrow `except Exception` to `except ImportError` in the 3 lib
   fallback import blocks (qual-1465 HIGH-1). Real logic bugs
   (SyntaxError, NameError, AttributeError) inside lib modules now
   surface immediately instead of being silently swallowed by a
   catch-all.

2. Drop inline stub functions for format_rate_limits and
   _get_fresh_version (qual-1465 HIGH-2). Eliminates the signature
   drift between canonical lib definitions and in-file fallback stubs
   observed on the integrator branch (Wave 1-A plugin_json_file
   kwarg drift). The outer main() try/except still catches any runtime
   failure and emits the minimal safe output via the BUDDY_FACE
   constant.

3. Hoist hud_velocity and hud_cache_savings imports to module top as
   _format_velocity_segment and _format_cache_savings (perf-1485 H1).
   Eliminates ~0.47us sys.modules lookup per render. Integrator branch
   only - no-op on refactor/wave branches where the inline imports
   don't exist yet.

4. Bump next to 16.2.3 for GHSA-q4gf-8mx6-v5v3 (landing-security-check).
   Aligns eslint-config-next and updates setup.test.ts assertion.

Refs: qual-1465 HIGH-1/2, perf-1485 H1,
GHSA-q4gf-8mx6-v5v3
@JeremyDev87 JeremyDev87 force-pushed the feat/statusbar-wow-velocity branch from 1237087 to 30a1d71 Compare April 11, 2026 13:11
@JeremyDev87 JeremyDev87 added statusbar-wave:2 Statusbar Wow new features (Wave 2-A~2-E) feat review:approved EVAL review 통과 (Critical/High = 0) labels Apr 11, 2026
@JeremyDev87
Copy link
Copy Markdown
Owner Author

Superseded by #1485

This PR was part of a stacked PR structure (feat/statusbar-wow-refactor base) that was incompatible with the repo's rebase & merge policy — each sub-PR targeted an intermediate branch, not master.

All of this PR's commits have been consolidated into #1485 (now with base: master and a linear 12-commit history after rebase). The consolidated PR contains:

  • Wave 0 — de622cc refactor(hud): extract 9 modules
  • Wave 1-A — cdf0772 fix(hud): version resolution fallback
  • Wave 1-B — 0606698 fix(hud): session self-heal
  • Wave 1-C — 87b779a feat(hud): rate limit severity icons
  • Wave 1-D — 894f515 feat(hud): adaptive layout engine
  • Wave 2-A — 5e8389d feat(hud): breathing buddy face states
  • Wave 2-B — 78ec6c5 feat(hud): cost velocity indicator
  • Wave 2-C — a306920 feat(hud): cache savings badge
  • Wave 2-D — 0fb3d5c feat(hud): mode rainbow ANSI coloring
  • Wave 2-E — 8cd78b2 feat(hud): smart context bar
  • Wave 3 — 295f5c4 feat(hud): integrate Wave 2-B/2-C
  • Review iter1 — b330528 fix(hud,landing): narrow fallback imports + next 16.2.3

EVAL review results from this PR (all reviewers, iter1 converged → Critical=0, High=0) already applied in #1485.

Closing as superseded. Use #1485 with GitHub's Rebase and merge button to land all 12 commits linearly on master.

@JeremyDev87 JeremyDev87 deleted the feat/statusbar-wow-velocity branch April 11, 2026 13:40
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

area:hud HUD / statusLine 영역 feat plugin packages/claude-code-plugin review:approved EVAL review 통과 (Critical/High = 0) statusbar-wave:2 Statusbar Wow new features (Wave 2-A~2-E)

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant