Skip to content

chore: bump version to 0.4.0#5

Merged
royosherove merged 1 commit into
mainfrom
chore/release-0.4.0
May 7, 2026
Merged

chore: bump version to 0.4.0#5
royosherove merged 1 commit into
mainfrom
chore/release-0.4.0

Conversation

@royosherove
Copy link
Copy Markdown
Member

Version bump for bundle release

@royosherove royosherove merged commit 8a17580 into main May 7, 2026
@royosherove royosherove deleted the chore/release-0.4.0 branch May 7, 2026 19:10
royosherove added a commit that referenced this pull request May 8, 2026
#5 — Suppress npm deprecation spam:
  - Set NODE_NO_WARNINGS=1 when spawning gateway subprocess
  - All install commands already use stdio:'pipe' (hide npm stderr)

#6 — Whisper/STT setup improvements:
  - Default voice=false on macOS (whisper pip install is heavy)
  - Add whisper check in postflight with install hint
  - Linux keeps voice=true (auto-install on first message)

#8 — Simplify getting started:
  - 'roundhouse install' now deprecated with redirect to setup
  - Removed 60+ lines of redundant install logic from cli.ts
  - README Quick Start: 3 lines (npm install, setup, start)
  - Cleaned up unused imports (mkdir, writeFile, envQuote, etc.)

Co-authored-by: Loki FastStart <loki@faststart.internal>
royosherove added a commit that referenced this pull request May 14, 2026
…31) (#133)

* refactor(session-repair): beautify per code review (7 findings)

Addresses all 7 findings from the post-v0.5.30 maintainability review.
Pure refactor \u2014 zero behavior change. 536 tests passing (+2 new for the
divergent-change fix).

#1 + #7 \u2014 DRY: extract matchesErrorPatterns + fix divergent change
  isContextOverflowError and isToolPairingError shared ~80% of structure
  (top-level .message, cause-chain walk, stringify-gate, circular try/catch)
  but with subtle drift: only one walked the cause chain. Extracted
  matchesErrorPatterns(err, patterns, { stringifyGate }) shared helper.
  Both classifiers now ~7 lines and BOTH walk cause chains. Added 2 tests
  proving isToolPairingError now classifies wrapped/Bedrock-nested
  tool-pairing errors (regression guard for the divergent-change fix).
  Also extracted looksLikeValidationError() shared gate so the two
  classifiers don't repeat the 4xx/ValidationException check.

#2 \u2014 long method: extracted buildTrimmedEntries(entries, cutIdx) from
  softResetSessionFile. The orchestration is now linear: validate \u2192 cut
  \u2192 build \u2192 repair \u2192 write \u2192 report. Each step at the same abstraction
  level.

#3 \u2014 long catch with nested try: extracted attemptSoftResetRecovery()
  in lifecycle.ts. flushMemoryThenCompact catch block went from ~60
  lines with nested try/catch to ~25 lines, linear: classify \u2192 recover
  \u2192 log \u2192 persist.

#4 \u2014 magic number: MAX_CAUSE_CHAIN_DEPTH = 5 named constant.

#5 \u2014 file >400 lines: split src/agents/shared/session-repair.ts (574
  lines, two domains) into:
    - session-repair.ts (81 lines) \u2014 public surface, tool-pair repair,
      re-exports for backward compat
    - session-soft-reset.ts (120 lines) \u2014 softResetSessionFile + types
    - error-classifiers.ts (75 lines) \u2014 matchesErrorPatterns +
      isContextOverflowError + isToolPairingError + MAX_CAUSE_CHAIN_DEPTH
    - session-repair-internal.ts (239 lines) \u2014 shared filesystem +
      in-memory repair primitives
  All public exports preserved via re-exports (Feathers seam pattern).
  Existing callers compile unchanged.

#6 \u2014 naming: introduced RepairResult { entries, report } named type for
  the previously-anonymous repairEntriesInMemory return shape. Better
  IDE hover/autocomplete; no inline destructuring noise at call sites.

Verification:
  npm test \u2014 536 passing (was 534, +2 for cause-chain regression tests)
  wc -l src/agents/shared/session-repair.ts \u2014 81 (was 574)
  All public API surfaces preserved.

* chore: bump to v0.5.31 + CHANGELOG

---------

Co-authored-by: Roy Osherove <575051+royosherove@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant