v0.8.0: Information Radiator, Command Palette, TrueColor Themes, Setup Wizard
- Sidebar: permanent 42-col panel with 7 data panels (Gate Trace, Focus, Rules, Context gauge, Files, Cost, Protection); 4-window Croatoan layout at >=120 cols, toggle via Ctrl+X+B - Command palette: Ctrl+P overlay with fuzzy-filtered categorized items, keyboard navigation, Enter to execute; view-palette rendering - TrueColor themes: 4 new presets (nord, tokyonight, catppuccin, monokai) with 27 hex keys via theme-hex-to-rgb - Setup wizard: Ctrl+\ /setup 4-step overlay (provider, key, memory, save) writing .env with in-TUI rendering - Daemon enrichment: dispatcher block counts, cost session summary, modified files tracking, context usage percentage - Daemon fixes: fboundp guards for count-tokens/provider-token-cost, tool registry save/restore in safety tests, SELF_BUILD_MODE cleanup - 139 tests pass across all suites (0 failures)
This commit is contained in:
@@ -14,6 +14,18 @@ The tracking is minimal and accurate to within ~10-15% (using the token
|
||||
heuristic from tokenizer.lisp). It persists across daemon restarts via
|
||||
~*session-cost*~ in the memory store.
|
||||
|
||||
** v0.8.0 — Session Summary for Sidebar
|
||||
|
||||
The sidebar's Cost panel needs an at-a-glance cost summary: total spent,
|
||||
call count, per-provider breakdown. ~cost-session-summary~ packages the
|
||||
three existing accessors (~cost-session-total~, ~cost-session-calls~,
|
||||
~cost-by-provider~) into a single plist ~(:total <float> :calls <int>
|
||||
:by-provider <alist>)~. This is a thin wrapper (~5 lines) — the data
|
||||
already exists; the function exposes it in the shape the TUI expects.
|
||||
|
||||
Called from ~core-act.org~'s ~:tui~ actuator via ~fboundp~ guard.
|
||||
Degrades gracefully to nil when cost-tracker is not loaded.
|
||||
|
||||
** Contract
|
||||
|
||||
1. (cost-track-call provider prompt-text response-text): compute and
|
||||
@@ -21,7 +33,11 @@ heuristic from tokenizer.lisp). It persists across daemon restarts via
|
||||
2. (cost-session-total): returns the current session's total cost.
|
||||
3. (cost-session-reset): zeroes the session cost accumulator.
|
||||
4. (cost-format-budget-status total budget): returns a human-readable
|
||||
budget status string for the TUI status bar.
|
||||
budget status string for the TUI status bar.
|
||||
5. (cost-session-summary): returns plist
|
||||
~(:total <float> :calls <int> :by-provider <alist>)~ aggregating
|
||||
all three session cost accessors. Consumed by the TUI actuator
|
||||
for the sidebar Cost panel (v0.8.0).
|
||||
|
||||
* Implementation
|
||||
|
||||
@@ -44,8 +60,12 @@ heuristic from tokenizer.lisp). It persists across daemon restarts via
|
||||
(defun cost-track-call (provider prompt-text &optional response-text)
|
||||
"Compute and accumulate the cost of a single LLM call.
|
||||
Returns the cost of this call in USD."
|
||||
(let* ((input-tokens (funcall (symbol-function 'count-tokens) (or prompt-text "")))
|
||||
(output-tokens (if response-text (funcall (symbol-function 'count-tokens) response-text) 0))
|
||||
(let* ((input-tokens (if (fboundp 'count-tokens)
|
||||
(funcall (symbol-function 'count-tokens) (or prompt-text ""))
|
||||
(ceiling (length (or prompt-text "")) 4)))
|
||||
(output-tokens (if (and response-text (fboundp 'count-tokens))
|
||||
(funcall (symbol-function 'count-tokens) response-text)
|
||||
0))
|
||||
(total-tokens (+ input-tokens output-tokens))
|
||||
(cost (provider-token-cost provider total-tokens)))
|
||||
(bordeaux-threads:with-lock-held (*session-cost-lock*)
|
||||
@@ -80,6 +100,16 @@ Returns the cost of this call in USD."
|
||||
(getf *session-cost* :by-provider)))
|
||||
#+end_src
|
||||
|
||||
** Session summary (v0.8.0)
|
||||
#+begin_src lisp
|
||||
(defun cost-session-summary ()
|
||||
"Returns plist (:total <float> :calls <int> :by-provider <alist>)."
|
||||
(bordeaux-threads:with-lock-held (*session-cost-lock*)
|
||||
(list :total (getf *session-cost* :total)
|
||||
:calls (getf *session-cost* :calls)
|
||||
:by-provider (getf *session-cost* :by-provider))))
|
||||
#+end_src
|
||||
|
||||
** Session reset
|
||||
#+begin_src lisp
|
||||
(defun cost-session-reset ()
|
||||
@@ -87,8 +117,7 @@ Returns the cost of this call in USD."
|
||||
(bordeaux-threads:with-lock-held (*session-cost-lock*)
|
||||
(setf (getf *session-cost* :total) 0.0)
|
||||
(setf (getf *session-cost* :calls) 0)
|
||||
(setf (getf *session-cost* :by-provider) nil)
|
||||
(log-message "COST TRACKER: Session cost reset.")))
|
||||
(setf (getf *session-cost* :by-provider) nil)))
|
||||
#+end_src
|
||||
|
||||
** Budget status formatting
|
||||
@@ -186,4 +215,16 @@ LLM invocation to record the cost.
|
||||
(cost-session-reset)
|
||||
(let ((cost (cost-track-call :deepseek "test")))
|
||||
(is (> cost 0.0))))
|
||||
|
||||
(test test-cost-session-summary
|
||||
"Contract 5: cost-session-summary returns plist with total, calls, by-provider."
|
||||
(cost-session-reset)
|
||||
(cost-track-call :deepseek "hello")
|
||||
(cost-track-call :groq "world")
|
||||
(let ((s (cost-session-summary)))
|
||||
(is (> (getf s :total) 0.0))
|
||||
(is (= 2 (getf s :calls)))
|
||||
(let ((by (getf s :by-provider)))
|
||||
(is (assoc :deepseek by))
|
||||
(is (assoc :groq by)))))
|
||||
#+end_src
|
||||
|
||||
Reference in New Issue
Block a user