fix: Chroma connection errors and remove dead last_user_message code (#525)

* fix: distinguish connection errors from collection-not-found in ChromaSync

Previously, ensureCollection() caught ALL errors from chroma_get_collection_info
and assumed they meant "collection doesn't exist". This caused connection errors
like "Not connected" to trigger unnecessary collection creation attempts.

Now connection-related errors are re-thrown immediately instead of being
misinterpreted as missing collections.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>

* fix: improve error handling for Chroma connection and collection creation

* fix: remove dead last_user_message from summarize flow

The last_user_message field was extracted from transcripts but never used.
In Claude Code transcripts, "user" type messages are mostly tool_results,
not actual user input. The user's original request is already stored in
user_prompts table.

This removes the false warning "Missing last_user_message when queueing
summary" which was complaining about missing data that didn't exist and
wasn't needed.

Changes:
- summary-hook: Only extract last_assistant_message
- SessionRoutes: Remove last_user_message from request body handling
- SessionManager.queueSummarize: Remove lastUserMessage parameter
- PendingMessage interface: Remove last_user_message field
- SDKSession interface: Remove last_user_message field
- All agents: Remove last_user_message from buildSummaryPrompt calls

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>

* build artifacts for plugin

* Enhance error handling across multiple services

- Improved logging in `BranchManager.ts` to capture recovery checkout failures.
- Updated `PaginationHelper.ts` to log when file paths are plain strings instead of valid JSON.
- Enhanced error logging in `SDKAgent.ts` for Claude executable detection failures.
- Added logging for plain string handling in `SearchManager.ts` for files read and edited.
- Improved logging in `paths.ts` for git root detection failures.
- Enhanced JSON parsing error handling in `timeline-formatting.ts` with previews of failed inputs.
- Updated `transcript-parser.ts` to log summary of parse errors after processing transcript lines.
- Established a baseline for error handling practices in `error-handling-baseline.txt`.
- Documented error handling anti-pattern rules in `CLAUDE.md` to prevent silent failures and improve code quality.

* Add error handling anti-pattern detection script and guidelines

- Introduced `detect-error-handling-antipatterns.ts` to identify common error handling issues in TypeScript code.
- Created comprehensive documentation in `CLAUDE.md` outlining forbidden patterns, allowed patterns, and critical path protection rules.
- Implemented checks for empty catch blocks, logging practices, and try-catch block sizes to prevent silent failures and improve debugging.
- Established a reporting mechanism to summarize detected anti-patterns with severity levels.

* feat: add console filter bar and log line parsing with filtering capabilities

- Introduced a console filter bar with options to filter logs by level and component.
- Implemented parsing of log lines to extract structured data including timestamp, level, component, and correlation ID.
- Added functionality to toggle individual and all levels/components for filtering.
- Enhanced log line rendering with color coding based on log level and special message types.
- Improved responsiveness of the filter bar for smaller screens.

---------

Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
Alex Newman
2026-01-02 14:45:50 -05:00
committed by GitHub
parent 65d1b52400
commit ad8ac7970d
29 changed files with 1842 additions and 449 deletions
+155
View File
@@ -2643,6 +2643,161 @@
font-family: 'SF Mono', 'Monaco', 'Menlo', 'Consolas', 'Courier New', monospace;
}
/* Console Filter Bar */
.console-filters {
display: flex;
flex-wrap: wrap;
gap: 12px;
padding: 8px 12px;
background: var(--color-bg-secondary);
border-bottom: 1px solid var(--color-border-primary);
}
.console-filter-section {
display: flex;
align-items: center;
gap: 8px;
flex-wrap: wrap;
}
.console-filter-label {
font-size: 10px;
font-weight: 600;
color: var(--color-text-muted);
text-transform: uppercase;
letter-spacing: 0.5px;
white-space: nowrap;
}
.console-filter-chips {
display: flex;
flex-wrap: wrap;
gap: 4px;
align-items: center;
}
.console-filter-chip {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 3px 8px;
font-size: 11px;
font-weight: 500;
background: var(--color-bg-card);
border: 1px solid var(--color-border-primary);
border-radius: 4px;
color: var(--color-text-secondary);
cursor: pointer;
transition: all 0.15s ease;
white-space: nowrap;
}
.console-filter-chip:hover {
background: var(--color-bg-card-hover);
border-color: var(--chip-color, var(--color-border-hover));
color: var(--color-text-primary);
}
.console-filter-chip.active {
background: var(--chip-color, var(--color-accent-primary));
border-color: var(--chip-color, var(--color-accent-primary));
color: white;
text-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
}
.console-filter-chip.active:hover {
opacity: 0.9;
}
.console-filter-action {
display: inline-flex;
align-items: center;
justify-content: center;
width: 24px;
height: 24px;
font-size: 12px;
background: transparent;
border: 1px solid var(--color-border-primary);
border-radius: 4px;
color: var(--color-text-muted);
cursor: pointer;
transition: all 0.15s ease;
}
.console-filter-action:hover {
background: var(--color-bg-card-hover);
border-color: var(--color-border-hover);
color: var(--color-text-primary);
}
/* Log Line Styles */
.log-line {
display: block;
padding: 2px 0;
font-family: 'SF Mono', 'Monaco', 'Menlo', 'Consolas', 'Courier New', monospace;
font-size: 11px;
line-height: 1.5;
white-space: pre-wrap;
word-wrap: break-word;
}
.log-line-raw {
color: var(--color-text-secondary);
opacity: 0.8;
}
.log-line-empty {
color: var(--color-text-muted);
font-style: italic;
padding: 20px 0;
text-align: center;
}
.log-timestamp {
color: var(--color-text-muted);
opacity: 0.7;
}
.log-level {
font-weight: 500;
}
.log-component {
font-weight: 500;
}
.log-correlation {
color: var(--color-accent-primary);
opacity: 0.9;
}
.log-message {
color: inherit;
}
/* Log Level Colors in Dark Mode */
[data-theme="dark"] .log-line-raw {
color: #8b949e;
}
/* Responsive adjustments for filter bar */
@media (max-width: 600px) {
.console-filters {
flex-direction: column;
gap: 8px;
padding: 6px 10px;
}
.console-filter-section {
flex-wrap: wrap;
}
.console-filter-chip {
padding: 2px 6px;
font-size: 10px;
}
}
/* Responsive Modal */
@media (max-width: 900px) {
.modal-body {