- protocol: InvokeKind enum、Event::InvokeStart / LlmCallStart / LlmCallEnd 追加
- llm-worker: Worker.llm_call_count と on_llm_call_start/end callback、turn_count を AgentTurn 数として doc 更新
- session-store: LogEntry::Invoke { ts, trigger } 追加 (replay は marker のみで state 不変)
- pod: run/run_for_notification 開始時に Invoke marker commit、PendingRun::RunForNotification(InvokeKind) で kind を伝搬
- pod ipc: sink + server で Invoke エントリーを Event::InvokeStart として broadcast
- tui: 新 Event 3種を no-op で受理 (UI 設計はチケット範囲外)
|
||
|---|---|---|
| .. | ||
| docs | ||
| examples | ||
| src | ||
| tests | ||
| Cargo.toml | ||
| README.md | ||
llm-worker
LLM との対話を管理する低レベル基盤クレート。会話履歴、ツール実行、イベントストリーミング、ライフサイクルフックを統合した Worker 抽象を提供する。
公開型
コア
Worker<C, S>— LLM 対話の中央管理(ターン実行、ツール呼び出し、キャンセル)WorkerConfig/WorkerResult/WorkerError— 設定・実行結果・エラーItem/ContentPart/Role— 会話履歴の構成要素
モジュール
llm_client— プロバイダ抽象(LlmClientトレイト、Request,RequestConfig, Anthropic/OpenAI/Gemini/Ollama 実装)tool— ツール定義・実行(Toolトレイト、ToolDefinition,ToolOutput, サイズ判定による Inline/Stored 切替)tool_server— ツール登録・ルックアップ(ToolServer,ToolServerHandle)hook— 実行フローへの介入ポイント(Hookトレイト、PreToolCall,PostToolCall,OnTurnEndなど)- クロージャベースイベント購読(
Worker::on_text_block(),on_tool_use_block(),on_usage()等) timeline— イベントストリームのディスパッチ(Handlerトレイト、各ブロックコレクター)。パワーユーザー向けにtimeline_mut()も提供event— ストリーミングイベント型(Event,BlockStart,BlockDeltaなど)state— 型状態パターンによるキャッシュ保護(Mutable/CacheLocked) cratesの整理Add READMEsRE to all crates@@