from __future__ import annotations

import re
from typing import Union

from agentverse.parser import OutputParser, LLMResult

from agentverse.utils import AgentAction, AgentFinish

from agentverse.parser import OutputParserError, output_parser_registry


@output_parser_registry.register("llm_eval/single_role/faireval/calc_score_comparison/gpt_35_0301")
class LLMEvalParser(OutputParser):
    def parse(self, output: LLMResult) -> Union[AgentAction, AgentFinish]:
        text = output.content
        cleaned_output = text.strip()
        cleaned_output = re.sub(r"\n+", "\n", cleaned_output)
        cleaned_output = cleaned_output.split("\n")

        

        if not (cleaned_output[-2].startswith("The score of Assistant 1:") and \
                cleaned_output[-1].startswith("The score of Assistant 2:")):
            raise OutputParserError(text)

        return AgentFinish({"output": text}, text)
