import datasets
import numpy as np


# fmt: off
LETTER_INDICES_AR = ["أ", "ب", "ج", "د", "هـ", "و", "ز", "ح", "ط", "ي", "ك", "ل", "م", "ن", "س", "ع", "ف", "ص", "ق", "ر", "ش", "ت", "ث", "خ", "ذ", "ض", "ظ", "غ"]
# fmt: on


# fmt: off
LETTER_INDICES = ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"]
# fmt: on


def process_docs(dataset: datasets.Dataset):
    def _process_doc(doc):
        topic = doc["subject"]
        instruction = f"الأسئلة التالية هي أسئلة متعددة الإختيارات مع الجواب الصحيح حول {topic.replace('_', ' ')}. \n\n"
        choices = [doc["A"], doc["B"], doc["C"], doc["D"]]
        # Answers are provided with roman letters - we look for the correct index in LETTER_INDICES,
        # it will then be applied to arabic letters
        gold_ix = LETTER_INDICES.index(doc["answer"])

        query = f"{instruction}{doc['question']}\n"
        query += "".join(
            [
                f"{key}. {choice}\n"
                for key, choice in zip(LETTER_INDICES_AR[:4], choices)
            ]
        )
        query += "الإجابة:"

        return {"query": query, "choices": LETTER_INDICES_AR[:4], "gold": gold_ix}

    return dataset.map(_process_doc)
