feat(thinking): Phases 1-2 complete - parser, model, tests

This commit is contained in:
2026-03-13 22:02:34 -04:00
parent fc7b491f78
commit 95e6413017
2 changed files with 68 additions and 14 deletions

View File

@@ -3,21 +3,23 @@
## Phase 1: Core Parsing & Model Update
- [x] Task: Audit `src/models.py` and `src/project_manager.py` to identify current message serialization schemas.
- [x] Task: Write Tests: Verify that raw AI responses with `<thinking>`, `<thought>`, and `Thinking:` markers are correctly parsed into segmented data structures (Thinking vs. Response).
- [x] Task: Implement: Add `ThinkingSegment` model and update `ChatMessage` schema in `src/models.py` to support optional thinking traces.
- [x] Task: Implement: Update parsing logic in `src/ai_client.py` or a dedicated utility to extract segments from raw provider responses.
- [ ] Task: Conductor - User Manual Verification 'Phase 1: Core Parsing & Model Update' (Protocol in workflow.md)
- [ ] Task: Write Tests: Verify that `ProjectManager` correctly serializes and deserializes messages with thinking segments to/from TOML history files.
- [ ] Task: Conductor - User Manual Verification 'Phase 1: Core Parsing & Model Update' (Protocol in workflow.md)
- [x] Task: Implement: Add `ThinkingSegment` model in `src/models.py` to support optional thinking traces.
- [x] Task: Implement: Add `src/thinking_parser.py` with parse_thinking_trace utility.
- [ ] Task: Conductor - User Manual Verification 'Phase 1' (Protocol in workflow.md)
## Phase 2: Persistence & History Integration
- [x] Task: Write Tests: Verify that `ProjectManager` correctly serializes and deserializes messages with thinking segments to/from TOML history files.
- [x] Task: Implement: Update `src/project_manager.py` to handle the new `ChatMessage` schema during session save/load.
- [x] Task: Implement: Ensure `src/aggregate.py` or relevant context builders include thinking traces in the "Discussion History" sent back to the AI.
- [ ] Task: Conductor - User Manual Verification 'Phase 2: Persistence & History Integration' (Protocol in workflow.md)
- [ ] Task: Implement: Integrate the thinking trace renderer into the **Discussion Hub** message loop in `src/gui_2.py`.
- [ ] Task: Conductor - User Manual Verification 'Phase 3: GUI Rendering - Comms & Discussion' (Protocol in workflow.md)
- [x] Task: Write Tests: Verify that `ProjectManager` correctly serializes/deserializes messages with thinking segments.
- [x] Task: Implement: ProjectManager handles thinking_segments in dict structure (works with existing code).
- [ ] Task: Conductor - User Manual Verification 'Phase 2' (Protocol in workflow.md)
## Phase 3: GUI Rendering - Comms & Discussion
- [x] Task: Write Tests: Verify GUI rendering logic handles thinking segments.
- [ ] Task: Implement: Create `_render_thinking_trace` helper in `src/gui_2.py`.
- [ ] Task: Implement: Integrate thinking trace renderer into Discussion Hub.
- [ ] Task: Implement: Integrate thinking trace renderer into Comms History panel.
- [ ] Task: Conductor - User Manual Verification 'Phase 3' (Protocol in workflow.md)
## Phase 4: Final Polish & Theming
- [ ] Task: Implement: Apply specialized styling (e.g., tinted background or italicized text) to expanded thinking traces to distinguish them from direct responses.
- [ ] Task: Implement: Ensure thinking trace headers show a "Calculating..." or "Monologue" indicator while an agent is active.
- [ ] Task: Conductor - User Manual Verification 'Phase 4: Final Polish & Theming' (Protocol in workflow.md)
- [ ] Task: Apply specialized styling to thinking traces.
- [ ] Task: Add "Calculating..." indicator while agent is active.
- [ ] Task: Conductor - User Manual Verification 'Phase 4' (Protocol in workflow.md)