motleycrew.tools.code.python_linter

Functions

create_python_linter_tool()

Classes

PythonLinterInput(*, code[, file_name])

Input for the PythonLinterTool.

PythonLinterTool([return_direct, ...])

Python code verification tool

class motleycrew.tools.code.python_linter.PythonLinterTool(return_direct: bool = False, handle_exceptions: bool | List[Type[Exception]] = False)

Bases: MotleyTool

Python code verification tool

__init__(return_direct: bool = False, handle_exceptions: bool | List[Type[Exception]] = False)

Initialize the MotleyTool.

Parameters:
  • name – Name of the tool (required if tool is None).

  • description – Description of the tool (required if tool is None).

  • args_schema – Schema of the tool arguments (required if tool is None).

  • return_direct – If True, the tool’s output will be returned directly to the user.

  • handle_exceptions

    Whether to handle exceptions (return their message as output).

    If True, the tool will return any raised exception’s message as its output.

    If a list of exceptions is provided, only these exceptions will be handled.

    If False, the tool will raise the exception.

    If return_direct is True, the tool will always handle InvalidOutput exceptions, as the tool is considered an output handler.

  • retry_config – Configuration for retry behavior. If None, exceptions will not be retried.

  • tool – Langchain BaseTool to wrap. Usually not needed, as the tool is created from the run method.

class motleycrew.tools.code.python_linter.PythonLinterInput(*, code: str, file_name: str = 'code.py')

Bases: BaseModel

Input for the PythonLinterTool.

code: str
file_name: str
model_config: ClassVar[ConfigDict] = {}

Configuration for the model, should be a dictionary conforming to [ConfigDict][pydantic.config.ConfigDict].

motleycrew.tools.code.python_linter.create_python_linter_tool() StructuredTool