import asyncio
from termcolor import colored

from utils import parse_args, load_txt_raw, load_json, save_json, extract_json, save_json_incre_list
from prompts.theme_w_parts import parts_prompt_lists
from frontierbench.agent import MCPAgent
from collections import defaultdict
import random
from copy import deepcopy
import json
import os

async def cli_main():
    """
    Main entry point for the CLI script.
    """
    init_args = parse_args()

    center_tool_dict = load_json('configs/mcp_center.json')
    center_tools = {}
    for tool_meta, tool_classes in center_tool_dict.items():
        for tool_class, tool_info in tool_classes.items():
            center_tools.update(tool_info)

    save_dict = defaultdict(list)
    source_tools = load_json(init_args.mcp_server_config_path)

    # 对不同的 prompt 测试问题分类
    for gen_iter, parts_prompt_list in enumerate(parts_prompt_lists.values()):
        for theme_iter, theme_prompt_list in enumerate(parts_prompt_list):
            if theme_iter == 0:
                continue
            theme_base_prompt = theme_prompt_list[theme_iter] + '\n\nNow, please focus on the following topics:\n'
            cold_start_results = load_json(f'core_results/gen{gen_iter}_{theme_iter}.json')

            for i_cold_start in cold_start_results:
                i_tool_meta_class, i_tool_sub_class = i_cold_start['tool_meta_class'], i_cold_start['tool_sub_class']
                cur_tools = source_tools.get(i_tool_meta_class, {}).get(i_tool_sub_class, {})

                cur_direction_prompt = i_cold_start['direction_prompt']

                args = deepcopy(init_args)
                args.mcp_server_config = {**cur_tools, **center_tools}
                args.mcp_server_config_class = None
                args.mcp_server_config_path = None
                agent = await MCPAgent.create(args)

                for r_iter in range(1, 4):
                    temperature = random.choice([0.8, 0.9, 1.0, 1.1, 1.2, 1.3, 1.4, 1.5])
                    agent.log_messages_path = f'logs/{init_args.time_str}_coreplan_gen{gen_iter}_{theme_iter}_temp{temperature}_{r_iter}.json'

                    print(colored(f'Current: {agent.log_messages_path}', 'cyan'))

                    conversation = await agent.run_tool(
                        system_prompt=load_txt_raw('prompts/0_planner_system.txt'),
                        cold_start_prompt=load_txt_raw('prompts/0_gathering_planner.txt'),
                        act_system_prompt=load_txt_raw('prompts/1_act_system.txt'),
                        act_prompt=load_txt_raw('prompts/1_act.txt'),
                        replan_prompt=load_txt_raw('prompts/2_replan.txt'),
                        task_prefix="gathering",
                        theme_prompt=theme_base_prompt + 'Direction:' + cur_direction_prompt['direction'],
                        cold_start_model_cfg={'temperature': temperature}
                    )

                await agent.cleanup()

def main():
    """
    Entry point for the script.
    """
    asyncio.run(cli_main())

if __name__ == "__main__":
    main()

