from .top_metrics import top_metrics


class EvaluateTool(object):
    def __init__(self, args):
        self.args = args

    def evaluate(self, preds, golds, section):
        summary = {}

        # Here is the post-process code from huggingface transformers,
        # it clean up clean up the space from tokenization(" 's"->"'s" e.t.c)
        # which is different from tensorflow.

        # @staticmethod
        # def clean_up_tokenization(out_string: str) -> str:
        # """
        # Clean up a list of simple English tokenization artifacts like spaces
        # before punctuations and abbreviated forms.
        #
        # Args:
        #     out_string (:obj:`str`): The text to clean up.
        #
        # Returns:
        #     :obj:`str`: The cleaned-up string.
        # """
        # out_string = (
        #     out_string.replace(" .", ".")
        #     .replace(" ?", "?")
        #     .replace(" !", "!")
        #     .replace(" ,", ",")
        #     .replace(" ' ", "'")
        #     .replace(" n't", "n't")
        #     .replace(" 'm", "'m")
        #     .replace(" 's", "'s")
        #     .replace(" 've", "'ve")
        #     .replace(" 're", "'re")
        # )
        # return out_string

        # Therefore, to make fair comparison, we "convert that back".

        preds = [pred.replace("'s", " 's").replace(",", " ,").replace("?", " ?").replace("a.m.",
                                                                                         "a.m .").replace(
            "p.m.", "p.m .").replace("p. m.", "p . m .").replace("Dr.", "Dr .").replace("Mrs.", "Mrs .").replace("Mr.",
                                                                                                                 "Mr .").replace(
            "O.J.", "O.J .").replace("Jr.", "Jr .").replace("N.", "N .").replace("J.", "J .").replace("Y.",
                                                                                                      "Y .").replace(
            "drs.", "drs .").replace("St.", "St .").replace("Portugal.", "Portugal .") for pred in preds]

        # new_preds = []
        # for pred in preds:
        #     # count the number of opening and closing brackets
        #     # if the number of closing brackets is more than opening brackets
        #     # add an opening bracket at the beginning of the string
        #     opening = pred.count("[")
        #     closing = pred.count("]")
        #     if closing > opening:
        #         pred = "[" + pred
        #     else:
        #         pred = "[" + pred + " ]"
            
        #     # if the prediction does not start with an opening bracket
        #     # add an opening bracket at the beginning and end of the string
        #     if pred[0] != "[":
        #         pred = "[" + pred
        #         pred = pred + " ]"
        #     new_preds.append(pred)

        # preds = new_preds
        # golds = [gold["seq_out"] for gold in golds]
        eval_results = top_metrics(golds, preds)
        summary["exact_match"] = eval_results["full_accuracy"]
        summary["template_accuracy"] = eval_results["intent_arg_accuracy"]
        return summary

def evaluate(preds, golds):
    evaluator = EvaluateTool(None)
    return evaluator.evaluate(preds, golds, None)["exact_match"]