exceptions.py — langchain Source File
Architecture documentation for exceptions.py, a python file in the langchain codebase. 2 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR 92d38058_ca26_5e72_9148_0a0e01b62771["exceptions.py"] b188e880_71c6_b93e_127d_c22666293d37["enum"] 92d38058_ca26_5e72_9148_0a0e01b62771 --> b188e880_71c6_b93e_127d_c22666293d37 8e2034b7_ceb8_963f_29fc_2ea6b50ef9b3["typing"] 92d38058_ca26_5e72_9148_0a0e01b62771 --> 8e2034b7_ceb8_963f_29fc_2ea6b50ef9b3 style 92d38058_ca26_5e72_9148_0a0e01b62771 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
"""Custom **exceptions** for LangChain."""
from enum import Enum
from typing import Any
class LangChainException(Exception): # noqa: N818
"""General LangChain exception."""
class TracerException(LangChainException):
"""Base class for exceptions in tracers module."""
class OutputParserException(ValueError, LangChainException): # noqa: N818
"""Exception that output parsers should raise to signify a parsing error.
This exists to differentiate parsing errors from other code or execution errors
that also may arise inside the output parser.
`OutputParserException` will be available to catch and handle in ways to fix the
parsing error, while other errors will be raised.
"""
def __init__(
self,
error: Any,
observation: str | None = None,
llm_output: str | None = None,
send_to_llm: bool = False, # noqa: FBT001,FBT002
):
"""Create an `OutputParserException`.
Args:
error: The error that's being re-raised or an error message.
observation: String explanation of error which can be passed to a model to
try and remediate the issue.
llm_output: String model output which is error-ing.
send_to_llm: Whether to send the observation and llm_output back to an Agent
after an `OutputParserException` has been raised.
This gives the underlying model driving the agent the context that the
previous output was improperly structured, in the hopes that it will
update the output to the correct format.
Raises:
ValueError: If `send_to_llm` is `True` but either observation or
`llm_output` are not provided.
"""
if isinstance(error, str):
error = create_message(
message=error, error_code=ErrorCode.OUTPUT_PARSING_FAILURE
)
super().__init__(error)
if send_to_llm and (observation is None or llm_output is None):
msg = (
"Arguments 'observation' & 'llm_output'"
" are required if 'send_to_llm' is True"
)
raise ValueError(msg)
self.observation = observation
self.llm_output = llm_output
self.send_to_llm = send_to_llm
class ContextOverflowError(LangChainException):
"""Exception raised when input exceeds the model's context limit.
This exception is raised by chat models when the input tokens exceed
the maximum context window supported by the model.
"""
class ErrorCode(Enum):
"""Error codes."""
INVALID_PROMPT_INPUT = "INVALID_PROMPT_INPUT"
INVALID_TOOL_RESULTS = "INVALID_TOOL_RESULTS" # Used in JS; not Py (yet)
MESSAGE_COERCION_FAILURE = "MESSAGE_COERCION_FAILURE"
MODEL_AUTHENTICATION = "MODEL_AUTHENTICATION" # Used in JS; not Py (yet)
MODEL_NOT_FOUND = "MODEL_NOT_FOUND" # Used in JS; not Py (yet)
MODEL_RATE_LIMIT = "MODEL_RATE_LIMIT" # Used in JS; not Py (yet)
OUTPUT_PARSING_FAILURE = "OUTPUT_PARSING_FAILURE"
def create_message(*, message: str, error_code: ErrorCode) -> str:
"""Create a message with a link to the LangChain troubleshooting guide.
Args:
message: The message to display.
error_code: The error code to display.
Returns:
The full message with the troubleshooting link.
Example:
```python
create_message(
message="Failed to parse output",
error_code=ErrorCode.OUTPUT_PARSING_FAILURE,
)
"Failed to parse output. For troubleshooting, visit: ..."
```
"""
return (
f"{message}\n"
"For troubleshooting, visit: https://docs.langchain.com/oss/python/langchain"
f"/errors/{error_code.value} "
)
Domain
Subdomains
Functions
Dependencies
- enum
- typing
Source
Frequently Asked Questions
What does exceptions.py do?
exceptions.py is a source file in the langchain codebase, written in python. It belongs to the CoreAbstractions domain, MessageSchema subdomain.
What functions are defined in exceptions.py?
exceptions.py defines 1 function(s): create_message.
What does exceptions.py depend on?
exceptions.py imports 2 module(s): enum, typing.
Where is exceptions.py in the architecture?
exceptions.py is located at libs/core/langchain_core/exceptions.py (domain: CoreAbstractions, subdomain: MessageSchema, directory: libs/core/langchain_core).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free