from tool.execute_nb_code import ExecuteNbCode
import utils
import time
import os
import dotenv
from schema import Memory, Message, Role

result_dir = "output/results"



def load_params():
    """
    加载参数
    """
    utils.load_module_config()
    utils.load_api_config()
    
    dotenv.load_dotenv()

    date_str = time.strftime("%Y-%m-%d", time.localtime())
    # solution_path = os.path.join(solution_dir, f"solution_{date_str}.json")

    os.makedirs(result_dir, exist_ok=True)
    # os.makedirs(os.path.dirname(solution_path), exist_ok=True)


load_params()
execute_nb_code = ExecuteNbCode(timeout=14400)

# 全局会话记忆（限制长度，避免无限膨胀）
GLOBAL_MEMORY = Memory(max_messages=20)

def record_tool_call(name: str, arguments: dict):
    """记录一次工具调用请求到全局记忆。"""
    try:
        content = f"CALL {name} ARGS={json_slim(arguments)}"
        GLOBAL_MEMORY.add_message(Message(role=Role.TOOL, content=content, name=name))
    except Exception:
        pass

def record_tool_result(name: str, result: dict):
    """记录一次工具执行结果到全局记忆。自动截断内容。"""
    try:
        content = f"RESULT {name} => {json_slim(result)}"
        GLOBAL_MEMORY.add_message(Message(role=Role.TOOL, content=content, name=name))
    except Exception:
        pass

def json_slim(obj: dict, limit: int = 800) -> str:
    import json
    try:
        s = json.dumps(obj, ensure_ascii=False)
    except Exception:
        s = str(obj)
    if len(s) > limit:
        return s[:limit-20] + "…(trunc)"
    return s

