squeez 1.14.0 → 1.15.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. package/CHANGELOG.md +209 -1
  2. package/README.md +29 -23
  3. package/package.json +1 -1
package/CHANGELOG.md CHANGED
@@ -9,6 +9,212 @@ conventional commit messages on `main`.
9
9
 
10
10
  ## [Unreleased]
11
11
 
12
+ ## [1.15.0] - 2026-05-05
13
+
14
+ ### Added
15
+ - feat(hooks): PreCompact + PostCompact lifecycle hooks (#102)
16
+ - feat(hooks): SubagentStop hook feeds sub-agent output into SessionContext (#101)
17
+ - feat(monitor): add Monitor tool to PostToolUse compress-output dispatch (#100)
18
+ - PostToolUse updatedToolOutput for Read/Grep/Glob (Claude Code v2.1.119+)
19
+ - session-analysis improvements — az JSON, vite noise, prisma generate, hook health check (#90)
20
+ - feat(fs): auto-compress cat'd markdown via compress_md pipeline (#88)
21
+ - feat(economy): compress Agent/Task prompt at PreToolUse time (#87)
22
+ - feat(handlers): xcodebuild noise filter + log-file tail detection (#84)
23
+ - feat(bench): efficiency-proof benchmark suite — quantitative savings for US-001/003/004 (#74)
24
+ - token-compression power-up — sig-mode, memory-file warn, structured summaries, hypothesis benchmark (#70)
25
+ - feat(setup): adapter-driven setup/uninstall across all hosts (#58)
26
+ - feat(hosts): Codex CLI adapter (hooks + AGENTS.md soft-budget) (#55)
27
+ - feat(hosts): Gemini CLI adapter (BeforeTool/AfterTool hooks) (#52)
28
+ - feat(hosts): full-parity OpenCode adapter + plugin rewrite (#48)
29
+ - wrangler, playwright, next build handlers + bun/drizzle routing (#34)
30
+ - feat(opus47): adapt squeez for Opus 4.7 tokenizer and xhigh effort
31
+ - feat(setup): auto-detect lang from CLAUDE.md/locale + stderr update notification (#29)
32
+ - v0.3.0 — token economy, pt-BR caveman, aggressive defaults, full hook install
33
+ - structured session memory, cross-session search, error snippets, configurable tunables
34
+ - feat(setup): create config.ini on first install
35
+ - feat(i18n): locale-aware compress-md with pt-BR support (#25)
36
+ - fuzzy dedup, adaptive intensity, benign summarize, MCP server, temporal memory, protocol payload
37
+ - Windows setup via cargo/npm + squeez update fix
38
+ - feat(benchmark): add squeez benchmark command with 19-scenario test suite
39
+ - feat(ci): re-add promote-develop workflow with correct registration
40
+ - feat(init): inject persona into ~/.claude/CLAUDE.md on every session start
41
+ - feat(npm+crates): add npm package and publish jobs to release workflow
42
+ - feat(statusline): add statusline.sh to repo; install via install.sh; show all-time stats
43
+ - compress-md, caveman persona, squeez update, track-result hook
44
+ - feat(context): adaptive intensity always picks Ultra
45
+ - feat(context): aggressive token-engine — adaptive intensity, redundancy cache, summarize fallback
46
+ - add Windows support to install.sh and release.yml
47
+ - add home_dir() helper with USERPROFILE fallback for Windows
48
+ - cross-platform wrap — shell_command() helper, cfg(unix) signal gates, libc unix-only
49
+ - add GitHub Copilot CLI support
50
+ - add OpenCode plugin for automatic Bash compression
51
+ - add universal installer support for macOS and Linux
52
+ - expand benchmarks, edge-case tests, and README polish
53
+ - add SessionStart + PostToolUse hooks, update install.sh and README
54
+ - wrap.rs — artifact capture (files/errors/git/tests) + compact warning header
55
+ - squeez init — session start, prior memory banner, session finalization (TDD)
56
+ - squeez track — token accumulation + session event log (TDD)
57
+ - memory.rs — Summary, read_last_n, write_summary, prune_old (TDD)
58
+ - session.rs — CurrentSession, append_event, date math (TDD)
59
+ - json_util helpers + compact_threshold_tokens, memory_retention_days config
60
+ - benchmark system — all fixtures passing
61
+ - build.sh compiles + installs squeez, registers hook
62
+ - PreToolUse hook script
63
+ - fs and runtime handlers — all handler tests passing
64
+ - cloud, database, network handlers (TDD)
65
+ - typescript and build handlers (TDD)
66
+ - package_mgr and test_runner handlers (TDD)
67
+ - git and docker handlers (TDD)
68
+ - wrap subcommand — sh -c, 120s timeout, signal forwarding, bypass check
69
+ - Handler trait with cmd+config, generic handler, command router, filter_stdin
70
+ - truncation strategy (TDD) — all strategy tests passing
71
+ - grouping strategy (TDD)
72
+ - dedup strategy (TDD)
73
+ - smart_filter strategy with node_modules frame removal (TDD)
74
+ - implement config.ini parser (TDD)
75
+
76
+ ### Changed
77
+ - chore(release): bump version to 1.15.0 [squeez-release-bot]
78
+ - docs: update changelog and benchmarks for v1.13.0
79
+ - chore(release): bump version to 1.14.0 [squeez-release-bot]
80
+ - chore(release): bump version to 1.13.0 [squeez-release-bot]
81
+ - docs: update changelog and benchmarks for v1.12.0
82
+ - chore(release): bump version to 1.12.0 [squeez-release-bot]
83
+ - docs(codex): update adapter comments and README for 0.123.0 hook surface
84
+ - docs: update changelog and benchmarks for v1.11.2
85
+ - chore(release): bump version to 1.11.2 [squeez-release-bot]
86
+ - docs: update changelog and benchmarks for v1.11.1
87
+ - chore(release): bump version to 1.11.1 [squeez-release-bot]
88
+ - docs: update changelog and benchmarks for v1.11.0
89
+ - chore(release): bump version to 1.11.0 [squeez-release-bot]
90
+ - docs: update changelog and benchmarks for v1.10.0
91
+ - docs: update changelog and benchmarks for v1.9.0
92
+ - chore(release): bump version to 1.10.0 [squeez-release-bot]
93
+ - docs(readme): document squeez's compression scope and architectural limits (#85)
94
+ - chore(release): bump version to 1.9.0 [squeez-release-bot]
95
+ - chore(release): bump version to 1.8.0 [squeez-release-bot]
96
+ - docs: update changelog and benchmarks for v1.7.7
97
+ - chore(release): bump version to 1.7.7 [squeez-release-bot]
98
+ - docs: update changelog and benchmarks for v1.7.6
99
+ - chore(release): bump version to 1.7.6 [squeez-release-bot]
100
+ - docs: update changelog and benchmarks for v1.7.5
101
+ - chore(release): bump version to 1.7.5 [squeez-release-bot]
102
+ - docs: update changelog and benchmarks for v1.7.4
103
+ - chore(release): bump version to 1.7.4 [squeez-release-bot]
104
+ - perf: O(log n) refactor — tail read, offset index, single-pass parser
105
+ - docs: update changelog and benchmarks for v1.7.3
106
+ - chore(release): bump version to 1.7.3 [squeez-release-bot]
107
+ - chore(release): bump version to 1.7.2 [squeez-release-bot]
108
+ - restore: revert accidental deletion of auto-release.yml workflow
109
+ - docs: update changelog and benchmarks for v1.7.1
110
+ - chore(release): bump version to 1.7.1 [squeez-release-bot]
111
+ - chore: relicense to Apache 2.0 + add DCO policy + banner (#76)
112
+ - docs: update changelog and benchmarks for v1.7.0
113
+ - chore(release): bump version to 1.7.0 [squeez-release-bot]
114
+ - docs: update changelog and benchmarks for v1.6.1
115
+ - chore(release): bump version to 1.6.1 [squeez-release-bot]
116
+ - docs: update changelog and benchmarks for v1.6.0
117
+ - chore(release): bump version to 1.6.0 [squeez-release-bot]
118
+ - docs: update changelog and benchmarks for v1.5.2
119
+ - chore(release): bump version to 1.5.2 [squeez-release-bot]
120
+ - chore(release): bump version to 1.5.1 [squeez-release-bot]
121
+ - docs: five-host matrix + squeez setup/uninstall flow (#63)
122
+ - refactor(install): delegate host registration to 'squeez setup' (#60)
123
+ - chore(release): bump version to 1.5.0 [squeez-release-bot]
124
+ - chore(release): bump version to 1.4.0 [squeez-release-bot]
125
+ - chore(release): bump version to 1.3.0 [squeez-release-bot]
126
+ - chore(release): bump version to 1.2.0 [squeez-release-bot]
127
+ - chore(release): bump version to 1.1.0 [squeez-release-bot]
128
+ - chore(release): bump version to 1.0.0 [skip release]
129
+ - refactor(hosts): extract HostAdapter trait + migrate Claude Code and Copilot (#42)
130
+ - ci: conventional-commit-driven auto-release (#40)
131
+ - chore(gov): issue-form templates + refined PR template (#39)
132
+ - docs: update changelog and benchmarks for v0.4.1 [skip release] (#33)
133
+ - chore(release): bump version to 0.4.1
134
+ - chore(release): bump version to 0.4.0
135
+ - docs: update changelog and benchmarks for v0.3.2 [skip release] (#30)
136
+ - chore: bump version to 0.3.2
137
+ - docs: add shields.io badge for changelog link
138
+ - chore: bump version to 0.3.1
139
+ - chore: bump version to 0.2.3
140
+ - docs: update README with 11 MCP tools, structured memory, and advanced tunables
141
+ - chore: bump version to 0.2.2
142
+ - docs: rewrite README with full install instructions (curl/npm/cargo) and all commands
143
+ - chore: refresh bench/report.md from latest run [skip release]
144
+ - chore(ci): remove promote-develop workflow (re-adding to fix broken registration)
145
+ - chore: bump version to 0.2.1 + auto-release on merge to main [skip release]
146
+ - chore: bump version to 0.2.0; add Cargo.toml metadata
147
+ - ci: PR template, linked-issue enforcement, no-claude-trailer check
148
+ - docs: update README with PR1+PR2 features, fresh benchmarks, changelog
149
+ - ci: auto-delete branches after PR merge
150
+ - docs: update Windows installation instructions and prerequisites in README
151
+ - docs: add Windows support and Rust install instructions to README
152
+ - refactor: use session::home_dir() in config and init (Windows compat)
153
+ - ci: trigger promote workflow (test)
154
+ - ci(workflow): avoid failing promote job when PR creation is not permitted; add PR_CREATION_TOKEN guidance
155
+ - docs(readme): add changelog, contribution workflow, and benchmark notes
156
+ - ci(workflow): create/update PR from develop to main on push
157
+ - chore: add .worktrees/ to gitignore
158
+ - chore: add docs/ to gitignore (local design specs)
159
+ - docs: update README for GitHub Copilot CLI support
160
+ - security: fix remaining LOW findings in wrap.rs
161
+ - security: fix 2 follow-up findings from second audit
162
+ - security: fix all 8 findings from security audit
163
+ - ci: build and install binary before running benchmarks
164
+ - chore: add GitHub sponsor button
165
+ - chore: ignore .omc/ directory, remove from tracking
166
+ - chore: update benchmark report (7/7 passing)
167
+ - docs: update README — real benchmarks, Phase 2 config, how it works
168
+ - style: cargo fmt on session.rs and test_session.rs
169
+ - chore: open source files — README, LICENSE, CI/release workflows, install.sh
170
+ - chore: scaffold squeez Rust project
171
+
172
+ ### Fixed
173
+ - plan-mode passthrough + release description body (#95)
174
+ - fix(session-start): health check missed top-level event keys (#92)
175
+ - fix(hosts): expand PreToolUse matcher to cover Read, Grep, Glob, Agent, Task (#86)
176
+ - fix(json_util,statusline): whitespace-tolerant JSON parser + UTF-8 statusline on Windows (#81)
177
+ - fix(hosts): preserve user settings.json when existing JSON fails to parse (#83)
178
+ - prevent OOM from unbounded file reads + data integrity fixes
179
+ - fix(ci): use native ubuntu-24.04-arm runner for aarch64 build
180
+ - eliminate memory leaks causing 16 GB RAM on MCP server startup (#79)
181
+ - fix(hooks): add hookEventName to PreToolUse hookSpecificOutput (#78)
182
+ - fix(opencode): align plugin with PluginModule SDK shape (default export + server map) (#72)
183
+ - fix(ci): push release docs directly to main (loop-safe) (#68)
184
+ - back Copilot BUDGET_HARD with Read/Grep hook + update upstream refs (#65)
185
+ - fix(ci): startsWith guard for auto-release recursion (#46)
186
+ - fix(ci): tighten auto-release bump detection + fix tag push (#44)
187
+ - fix(ci): add --allow-dirty to cargo publish for Cargo.lock changes
188
+ - fix(ci): skip publish gracefully when version already exists on crates.io/npm
189
+ - fix(ci): run update-docs even if publish jobs fail (already published)
190
+ - fix(ci): continue-on-error for publish jobs so update-docs always runs
191
+ - fix(ci): add pull-requests write permission to update-docs job
192
+ - fix(update): cargo-managed self-update + Windows deferred install + session update check (#27)
193
+ - fix(ci): update-docs creates PR instead of pushing directly to protected main
194
+ - fix(npm): copy README.md into npm package before publish; add readme field
195
+ - fix(ci): add toolchain: stable to all dtolnay/rust-toolchain steps
196
+ - fix(ci): handle no previous tags in generate-changelog.sh (pipefail + grep -v)
197
+ - fix(ci): dispatch release.yml from auto-release to bypass GITHUB_TOKEN chain limit [skip release]
198
+ - fix(ci): fix flaky test tmp dir collision + simplify auto-release
199
+ - fix(bench): exclude synthetic fixtures from filter-mode bench/run.sh
200
+ - fix(ci): remove secrets in step if-conditions — check token inside script instead
201
+ - fix(ci): rename promote-develop → promote-to-main to fix broken workflow registration
202
+ - fix(ci): bump github-script to v7 in promote-develop to force workflow re-registration
203
+ - fix(compress_md): use byte slice comparison to avoid UTF-8 char boundary panic
204
+ - fix(statusline): remove Ctx% — show only squeez compression metrics
205
+ - fix(statusline): green ✓, proper capitalization, real-time context %, all metrics
206
+ - resolve gap analysis — new handlers, wider redundancy window, token budget
207
+ - install.sh — clarify PostToolUse no-matcher intent, guard version echo
208
+ - wrap.rs — safe git hex check, O(n) dedup, full cmd in event log
209
+ - use ends_with for files_committed check in init finalize
210
+ - json_util — guard extract_u64 empty digit, add json_util test coverage
211
+ - add pre-flight binary check to bench/run.sh
212
+ - atomic settings.json write + uninstall safety guards
213
+ - harden pretooluse hook (shlex.quote, error handling, single path source)
214
+ - wrap — process_group(0) for correct signal forwarding, tighten is_streaming
215
+
216
+ ## [1.13.0] - 2026-05-05
217
+
12
218
  ## [1.12.0] - 2026-05-05
13
219
 
14
220
  ### Added
@@ -894,7 +1100,7 @@ conventional commit messages on `main`.
894
1100
  ## [1.5.1] and earlier
895
1101
  See the [git tag history](https://github.com/claudioemmanuel/squeez/tags) for pre-1.5.2 details. release-please takes over changelog generation from 1.7.1 onwards.
896
1102
 
897
- [Unreleased]: https://github.com/claudioemmanuel/squeez/compare/v1.12.0...HEAD
1103
+ [Unreleased]: https://github.com/claudioemmanuel/squeez/compare/v1.15.0...HEAD
898
1104
  [1.7.0]: https://github.com/claudioemmanuel/squeez/compare/v1.6.1...v1.7.0
899
1105
  [1.6.1]: https://github.com/claudioemmanuel/squeez/compare/v1.6.0...v1.6.1
900
1106
  [1.6.0]: https://github.com/claudioemmanuel/squeez/compare/v1.5.2...v1.6.0
@@ -910,3 +1116,5 @@ See the [git tag history](https://github.com/claudioemmanuel/squeez/tags) for pr
910
1116
  [1.11.1]: https://github.com/claudioemmanuel/squeez/releases/tag/v1.11.1
911
1117
  [1.11.2]: https://github.com/claudioemmanuel/squeez/releases/tag/v1.11.2
912
1118
  [1.12.0]: https://github.com/claudioemmanuel/squeez/releases/tag/v1.12.0
1119
+ [1.13.0]: https://github.com/claudioemmanuel/squeez/compare/v1.14.0...v1.13.0
1120
+ [1.15.0]: https://github.com/claudioemmanuel/squeez/releases/tag/v1.15.0
package/README.md CHANGED
@@ -104,7 +104,7 @@ squeez update --insecure # skip checksum (not recommended)
104
104
  | **Caveman persona** | Injects an ultra-terse prompt at session start so the model responds with fewer tokens. |
105
105
  | **Memory-file compression** | `squeez compress-md` compresses CLAUDE.md / AGENTS.md / copilot-instructions.md in-place — pure Rust, zero LLM. i18n-aware: set `lang = pt` (or `--lang pt`) for pt-BR article/filler/phrase dropping and Unicode-correct matching. |
106
106
  | **Session memory** | On `SessionStart`, injects a structured summary of the previous session: files investigated, learned facts (errors + git events), completed work (builds, test passes), and next steps (unresolved errors, failing tests). Summaries carry temporal validity (`valid_from`/`valid_to`). |
107
- | **Token tracking** | Every `PostToolUse` result (Bash, Read, Grep, Glob) feeds a `SessionContext` so squeez knows what the agent has already seen. |
107
+ | **Token tracking** | Every `PostToolUse` result (Bash, Read, Grep, Glob, Monitor, SubagentStop) feeds a `SessionContext` so squeez knows what the agent has already seen. Read/Grep/Glob/Monitor outputs are also rewritten via `updatedToolOutput` (Claude Code v2.1.119+) when content is redundant or oversized. |
108
108
  | **Token economy** | Sub-agent cost tracking (~200K tokens/spawn), burn rate prediction (`[budget: ~N calls left]`), session efficiency scoring, tool result size budgets. |
109
109
  | **Auto-calibration** | `squeez calibrate` runs benchmarks on install and generates an optimized `config.ini` (aggressive / balanced / conservative profiles). |
110
110
 
@@ -120,13 +120,16 @@ squeez optimizes what it can reach — the surfaces exposed by each host's hook
120
120
  |---|---|---|---|
121
121
  | **Bash stdout/stderr** | `PreToolUse` wraps command w/ 4-stage pipeline (smart-filter → dedup → grouping → truncation) | Every Bash invocation | all 5 |
122
122
  | **Read / Grep / Glob limits** | `PreToolUse` injects `limit` / `head_limit` per `read_max_lines` / `grep_max_results` | Every Read/Grep/Glob call | Claude Code, Copilot, OpenCode (hard); Gemini + Codex soft via GEMINI.md / AGENTS.md |
123
+ | **Read / Grep / Glob / Monitor output rewrite** | `PostToolUse` runs `squeez compress-output` and returns `updatedToolOutput` when content is redundant or oversized | Claude Code v2.1.119+ | Claude Code |
123
124
  | **Agent / Task prompt** | `PreToolUse` compresses `tool_input.prompt` (markdown-aware, via `compress-prompt`) | When prompt > `agent_prompt_max_tokens` | Claude Code (post–v1.8.0) |
125
+ | **Sub-agent output** | `SubagentStop` hook feeds `last_assistant_message` into SessionContext for cross-call dedup | On every sub-agent completion | Claude Code |
126
+ | **Compaction lifecycle** | `PreCompact` logs the event; `PostCompact` emits a re-arm reminder so the model knows compression is still active | On context compaction | Claude Code |
124
127
  | **Session memory** | `SessionStart` injects prior session summary + file-access cache | Once per session start | all 5 |
125
128
  | **Markdown viewing** | Bash handler routes `.md` reads through `compress-md` when `auto_compress_md=true` | Viewer commands on .md paths | all 5 |
126
129
 
127
130
  ### What squeez CANNOT compress
128
131
 
129
- **Agent/Task returned output.** `PostToolUse` hooks are observation-only squeez sees the result *after* the model has received it. No hook API surface exists to rewrite an Agent's return value. Workaround: keep agent prompts compact (squeez compresses at dispatch time), and use `squeez_agent_costs` MCP tool to monitor spawn overhead.
132
+ **Agent/Task returned output.** No hook API surface exists to rewrite an Agent's return value. `PostToolUse updatedToolOutput` (Claude Code v2.1.119+) covers built-in tools (Read, Grep, Glob, Monitor) but not the Agent/Task result. Workaround: keep agent prompts compact (squeez compresses at dispatch time via PreToolUse), and use `squeez_agent_costs` MCP tool to monitor spawn overhead.
130
133
 
131
134
  **Skills & slash-command files.** Claude Code loads these into the system prompt before any hook fires. squeez has no visibility into session-start system prompt construction.
132
135
 
@@ -158,29 +161,29 @@ Measured on macOS (Apple Silicon). Token count = `chars / 4` (matches Claude's ~
158
161
 
159
162
  | Scenario | Before | After | Reduction | Latency |
160
163
  |----------|--------|-------|-----------|---------|
161
- | `summarize_huge` | 82,257 tk | 420 tk | **-99%** | 55.9 ms |
162
- | `repetitive_output` | 4,692 tk | 37 tk | **-99%** | 212 µs |
163
- | `high_context_adaptive` | 4,418 tk | 52 tk | **-99%** | 848 µs |
164
+ | `summarize_huge` | 82,257 tk | 420 tk | **-99%** | 55.7 ms |
165
+ | `repetitive_output` | 4,692 tk | 37 tk | **-99%** | 220 µs |
166
+ | `high_context_adaptive` | 4,418 tk | 52 tk | **-99%** | 818 µs |
164
167
  | `ps_aux` | 40,373 tk | 2,352 tk | **-94%** | 2.9 ms |
165
- | `git_log_200` | 2,692 tk | 289 tk | **-89%** | 231 µs |
166
- | `tsc_errors` | 731 tk | 101 tk | **-86%** | 48 µs |
167
- | `cargo_build_noisy` | 2,106 tk | 452 tk | **-79%** | 432 µs |
168
- | `docker_logs` | 665 tk | 186 tk | **-72%** | 45 µs |
169
- | `find_deep` | 424 tk | 134 tk | **-68%** | 85 µs |
168
+ | `git_log_200` | 2,692 tk | 289 tk | **-89%** | 233 µs |
169
+ | `tsc_errors` | 731 tk | 101 tk | **-86%** | 28 µs |
170
+ | `cargo_build_noisy` | 2,106 tk | 452 tk | **-79%** | 270 µs |
171
+ | `docker_logs` | 665 tk | 186 tk | **-72%** | 48 µs |
172
+ | `find_deep` | 424 tk | 134 tk | **-68%** | 82 µs |
170
173
  | `git_status` | 50 tk | 16 tk | **-68%** | 12 µs |
171
- | `verbose_app_log` | 4,957 tk | 1,991 tk | **-60%** | 302 µs |
174
+ | `verbose_app_log` | 4,957 tk | 1,991 tk | **-60%** | 312 µs |
172
175
  | `npm_install` | 524 tk | 232 tk | **-56%** | 48 µs |
173
- | `crosscall_redundancy_3x` | 486 tk | 241 tk | **-50%** | 51.6 ms |
174
- | `ls_la` | 1,782 tk | 886 tk | **-50%** | 325 µs |
175
- | `env_dump` | 441 tk | 287 tk | **-35%** | 40 µs |
176
- | `git_copilot` | 640 tk | 421 tk | **-34%** | 167 µs |
177
- | `agent_heavy` | 2,306 tk | 1,564 tk | **-32%** | 410 µs |
178
- | `md_prose` | 187 tk | 138 tk | **-26%** | 666 µs |
176
+ | `crosscall_redundancy_3x` | 486 tk | 241 tk | **-50%** | 51.5 ms |
177
+ | `ls_la` | 1,782 tk | 886 tk | **-50%** | 222 µs |
178
+ | `env_dump` | 441 tk | 287 tk | **-35%** | 25 µs |
179
+ | `git_copilot` | 640 tk | 421 tk | **-34%** | 103 µs |
180
+ | `agent_heavy` | 2,306 tk | 1,564 tk | **-32%** | 411 µs |
181
+ | `md_prose` | 187 tk | 138 tk | **-26%** | 660 µs |
179
182
  | `md_claude_md` | 316 tk | 247 tk | **-22%** | 1.2 ms |
180
- | `claude_md_overhead` | 717 tk | 649 tk | **-9%** | 21 µs |
183
+ | `claude_md_overhead` | 717 tk | 649 tk | **-9%** | 23 µs |
181
184
  | `git_diff` | 502 tk | 497 tk | **-1%** | 44 µs |
182
- | `state_first_simulation` | 182 tk | 181 tk | **-1%** | 5 µs |
183
- | `kubectl_pods` | 1,513 tk | 1,513 tk | **-0%** | 27 µs |
185
+ | `state_first_simulation` | 182 tk | 181 tk | **-1%** | 8 µs |
186
+ | `kubectl_pods` | 1,513 tk | 1,513 tk | **-0%** | 31 µs |
184
187
 
185
188
  ### Aggregate
186
189
 
@@ -420,11 +423,14 @@ Each bash command passes through four strategies in order:
420
423
 
421
424
  ### Hooks (Claude Code & Copilot CLI)
422
425
 
423
- Three hooks work together automatically after install:
426
+ Six hooks work together automatically after install on Claude Code (three on Copilot CLI):
424
427
 
425
- - **`PreToolUse`** — rewrites every Bash call: `git status` → `squeez wrap git status`
428
+ - **`PreToolUse`** — rewrites every Bash call: `git status` → `squeez wrap git status`; injects Read/Grep/Glob limits; compresses Agent/Task prompts
426
429
  - **`SessionStart`** — runs `squeez init`: finalizes previous session into a memory summary, injects the persona prompt
427
- - **`PostToolUse`** — runs `squeez track-result`: scans every tool result (Bash, Read, Grep, Glob) for file paths and errors, feeding `SessionContext`
430
+ - **`PostToolUse`** — tracks every tool result; rewrites Read/Grep/Glob/Monitor output via `updatedToolOutput` when content is redundant or oversized (Claude Code v2.1.119+)
431
+ - **`SubagentStop`** *(Claude Code only)* — feeds `last_assistant_message` into SessionContext so the parent agent can dedup against what the sub-agent saw
432
+ - **`PreCompact`** *(Claude Code only)* — logs compaction events for session efficiency metrics; allows compaction to proceed
433
+ - **`PostCompact`** *(Claude Code only)* — emits a re-arm reminder after compaction so the model knows compression is still active
428
434
 
429
435
  ### Cross-call redundancy
430
436
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "squeez",
3
- "version": "1.14.0",
3
+ "version": "1.15.1",
4
4
  "description": "Hook-based token compressor for Claude Code, Copilot CLI, and OpenCode. Compresses bash output up to 95%, collapses redundant calls, injects caveman persona.",
5
5
  "keywords": [
6
6
  "claude-code",