"""
Simple main script for MTR demonstration
This demonstrates the core Model-as-Tool reasoning capabilities with ToolMaker, ToolActor, and AutoAgent
"""

import os
import sys
from pathlib import Path

# Add src to path for imports
src_path = Path(__file__).parent / "src"
sys.path.insert(0, str(src_path))

from src.agent.toolmaker import ToolMaker
from src.agent.toolactor import ToolActor
from src.agent.autoagent import AutoAgent
from src.llm import LLM


def main():
    """
    Main demonstration of the MTR (Model-as-Tool Reasoning) system with three core components:
    1. ToolMaker - Generates custom tools based on task requirements
    2. ToolActor - Executes tools and performs reasoning
    3. AutoAgent - Coordinates the entire workflow
    """
    print("MTR - Model-as-Tool Reasoning Framework")
    print("=" * 60)

    # Example reasoning problem
    problem = """
    Analyze the relationship between climate change and renewable energy adoption
    in the context of global policy decisions. Consider economic, environmental,
    and technological factors in your multi-hop reasoning.
    """

    try:
        print("Initializing MTR core components:")
        print("1. ToolMaker - Dynamic tool generation")
        print("2. ToolActor - Tool execution and reasoning")
        print("3. AutoAgent - Workflow coordination")
        print()

        # Initialize components (requires LLM configuration)
        # Note: Configure your LLM settings in config/config.example.toml

        toolmaker = ToolMaker()
        toolactor = ToolActor()
        autoagent = AutoAgent()

        print(f"✅ ToolMaker: {toolmaker.name}")
        print(f"✅ ToolActor: {toolactor.name}")
        print(f"✅ AutoAgent: {autoagent.name}")

        print(f"\nAvailable tools: {len(autoagent.tools) if autoagent.tools else 0}")

        # Process the problem
        print("\nExample reasoning problem:")
        print(problem)
        print("\n" + "=" * 60)

        # Demonstrate the MTR workflow
        print("MTR Model-as-Tool Reasoning Workflow:")
        print("1. Task analysis and tool requirement identification")
        print("2. Dynamic tool generation via ToolMaker")
        print("3. Multi-hop reasoning execution via ToolActor")
        print("4. Result synthesis and validation via AutoAgent")
        print()
        print("To run with actual LLM, configure your API settings in config/config.example.toml")

    except Exception as e:
        print(f"Error: {e}")
        print("\nSetup requirements:")
        print("1. Configure config/config.example.toml with your LLM settings")
        print("2. Install dependencies: pip install -r requirements.txt")
        print("3. Ensure proper API access for the reasoning components")


if __name__ == "__main__":
    main()