"""Callback Handler streams to stdout on new llm token.""" from __future__ import annotations import sys from typing import TYPE_CHECKING, Any, Dict, List from langchain_core.callbacks.base import BaseCallbackHandler if TYPE_CHECKING: from langchain_core.agents import AgentAction, AgentFinish from langchain_core.messages import BaseMessage from langchain_core.outputs import LLMResult class StreamingStdOutCallbackHandler(BaseCallbackHandler): """Callback handler for streaming. Only works with LLMs that support streaming.""" def on_llm_start( self, serialized: Dict[str, Any], prompts: List[str], **kwargs: Any ) -> None: """Run when LLM starts running.""" def on_chat_model_start( self, serialized: Dict[str, Any], messages: List[List[BaseMessage]], **kwargs: Any, ) -> None: """Run when LLM starts running.""" def on_llm_new_token(self, token: str, **kwargs: Any) -> None: """Run on new LLM token. Only available when streaming is enabled.""" sys.stdout.write(token) sys.stdout.flush() def on_llm_end(self, response: LLMResult, **kwargs: Any) -> None: """Run when LLM ends running.""" def on_llm_error(self, error: BaseException, **kwargs: Any) -> None: """Run when LLM errors.""" def on_chain_start( self, serialized: Dict[str, Any], inputs: Dict[str, Any], **kwargs: Any ) -> None: """Run when chain starts running.""" def on_chain_end(self, outputs: Dict[str, Any], **kwargs: Any) -> None: """Run when chain ends running.""" def on_chain_error(self, error: BaseException, **kwargs: Any) -> None: """Run when chain errors.""" def on_tool_start( self, serialized: Dict[str, Any], input_str: str, **kwargs: Any ) -> None: """Run when tool starts running.""" def on_agent_action(self, action: AgentAction, **kwargs: Any) -> Any: """Run on agent action.""" pass def on_tool_end(self, output: str, **kwargs: Any) -> None: """Run when tool ends running.""" def on_tool_error(self, error: BaseException, **kwargs: Any) -> None: """Run when tool errors.""" def on_text(self, text: str, **kwargs: Any) -> None: """Run on arbitrary text.""" def on_agent_finish(self, finish: AgentFinish, **kwargs: Any) -> None: """Run on agent end."""