from inspect import stack
import logging
import os
from typing import Any, Optional, Tuple
from uuid import uuid4
import json
from verl.utils.reward_score import gsm8k
from .base_tool import BaseTool
from .schemas import OpenAIFunctionToolSchema
logger = logging.getLogger(__name__)
logger.setLevel(os.getenv("VERL_LOGGING_LEVEL", "WARN"))
class CodeBaseTool(BaseTool):
    def __init__(self, config: dict, tool_schema: OpenAIFunctionToolSchema):
        super().__init__(config, tool_schema)
        self._instance_dict = {}
        self._stack_dict = {}
    def get_openai_tool_schema(self) -> OpenAIFunctionToolSchema:
        return self.tool_schema
    async def create(self, instance_id: Optional[str] = None, repo_id: Optional[str] = None, begin_file:Optional[str] = None **kwargs) -> str:
        if instance_id is None:
            instance_id = str(uuid4())
        self._instance_dict[instance_id] = {
            "response": "",
            "repo_id": repo_id,
            "reward": 0.0,
            "current_file": begin_file 
        }
        self._stack_dict[instance_id] = []
        self._database_dict[instance_id] = None
        return instance_id
    def find_next_file(self, instance_id, current_file:str, function_name:str):
        relation_json_path = "./swe-verified-relations/" + self._instance_dict[instance_id]['repo_id'] + ".json"
        if self._database_dict[instance_id] ==None:
            self._database_dict[instance_id] = json.load(relation_json_path)
        new_file = database[current_file][function_name]
        return new_file
    async def execute(self, instance_id: str, parameters: dict[str, Any], **kwargs) -> Tuple[str, float, dict]:
        function_names = parameters.get("module_names", "").replace(" ", '').replace("None", "").replace("none", "")
        current_file = self._instance_dict[instance_id]["current_file"]
        if not isinstance(function_names, str):
            function_names = str(function_names)
        self._instance_dict[instance_id]["response"] = function_names
        for function_name in function_names.split(",").reverse():
            self._stack_dict[instance_id].append(self.find_next_file(instance_id, current_file, function_name))
        next_file_path = self._stack_dict[instance_id][-1]
        self._stack_dict[instance_id] = self._stack_dict[instance_id][:-1]
        with open(next_file_path, 'r', encoding='utf-8') as f:
            next_file_content = f.read()
        self._instance_dict[instance_id]["current_file"] = next_file_path
        return f"Current parsed {next_file_path}", next_file_path, next_file_content
    async def release(self, instance_id: str, **kwargs) -> None:
        del self._instance_dict[instance_id]