import random
import sys

sys.path.append("..")

from game import Game


def full_context_aug_strat_prompt_generator(game: Game, task_setter_tag: str):
    """
    Full personal context --
    see own questions, own scores and competitor's scores.
    AND competitor questions and scores/ competitor's scores on those.
    """
    with open(
        "skate/prompts/full-context-prompt.txt",
        "r",
    ) as f:
        prompt = f.read()

    competitor_tag = game.get_competitor_tag(task_setter_tag)
    questions = game.archive.questions[task_setter_tag]
    if len(questions) > 0:
        random.shuffle(questions)

    previous_questions = "\n".join(
        f"On the following question which you wrote, you scored {round(100 * q.scores[task_setter_tag], 2)} and your competitor scored {round(100 * q.scores[competitor_tag], 2)}%: "
        + "\n"
        + str(q.text)
        for q in questions
    )

    comp_questions = game.archive.questions[competitor_tag]
    if len(comp_questions) > 0:
        random.shuffle(comp_questions)
    previous_questions += "\n\n" + "\n".join(
        f"On the following question which your competitor wrote, you scored {round(100 * q.scores[task_setter_tag], 2)} and your competitor scored {round(100 * q.scores[competitor_tag], 2)}%: "
        + "\n"
        + str(q.text)
        for q in comp_questions
    )

    round_number = game.current_round.round_number

    failed_attempts = game.current_round.rejected_questions.get(task_setter_tag, [])
    num_failed_attempts = len(failed_attempts)
    num_attempts_left = game.num_attempts - num_failed_attempts

    failed_attempt_string = ""
    if len(failed_attempts) > 0:
        for attempt in failed_attempts:
            text = attempt["text"]
            reason = attempt["reason"]
            failed_attempt_string += f"Question: {text}\nReason: {reason}\n"

    return prompt.format(
        previous_questions=previous_questions,
        round_number=round_number,
        num_attempts_left=num_attempts_left,
        failed_attempts=failed_attempt_string,
    )


def full_personal_context_aug_strat_prompt_generator(game: Game, task_setter_tag: str):
    """
    Full personal context --
    see own questions, own scores and competitor's scores.
    """
    with open(
        "skate/prompts/full-personal-context-prompt.txt",
        "r",
    ) as f:
        prompt = f.read()

    questions = game.archive.questions[task_setter_tag]
    competitor_tag = game.get_competitor_tag(task_setter_tag)
    if len(questions) > 0:
        random.shuffle(questions)

    previous_questions = "\n".join(
        f"On the following question, you scored {round(100 * q.scores[task_setter_tag], 2)} and your competitor scored {round(100 * q.scores[competitor_tag], 2)}%: "
        + "\n"
        + str(q.text)
        for q in questions
    )
    round_number = game.current_round.round_number

    failed_attempts = game.current_round.rejected_questions.get(task_setter_tag, [])
    num_failed_attempts = len(failed_attempts)
    num_attempts_left = game.num_attempts - num_failed_attempts

    failed_attempt_string = ""
    if len(failed_attempts) > 0:
        for attempt in failed_attempts:
            text = attempt["text"]
            reason = attempt["reason"]
            failed_attempt_string += f"Question: {text}\nReason: {reason}\n"

    return prompt.format(
        previous_questions=previous_questions,
        round_number=round_number,
        num_attempts_left=num_attempts_left,
        failed_attempts=failed_attempt_string,
    )


def historical_performance_aug_strat_prompt_generator(game: Game, task_setter_tag: str):
    """
    Generate prompt for historical performance augmentation strategy.
    This strategy uses the task setter's archive and task setter's scores and the current round's rejected questions.
    """
    with open(
        "skate/prompts/historical-performance-prompt.txt",
        "r",
    ) as f:
        prompt = f.read()

    questions = game.archive.questions[task_setter_tag]
    if len(questions) > 0:
        random.shuffle(questions)

    previous_questions = "\n".join(
        f"On the following question, you scored {round(100 * q.scores[task_setter_tag], 2)}%: "
        + "\n"
        + str(q.text)
        for q in questions
    )
    round_number = game.current_round.round_number

    failed_attempts = game.current_round.rejected_questions.get(task_setter_tag, [])
    num_failed_attempts = len(failed_attempts)
    num_attempts_left = game.num_attempts - num_failed_attempts

    failed_attempt_string = ""
    if len(failed_attempts) > 0:
        for attempt in failed_attempts:
            text = attempt["text"]
            reason = attempt["reason"]
            failed_attempt_string += f"Question: {text}\nReason: {reason}\n"

    return prompt.format(
        previous_questions=previous_questions,
        round_number=round_number,
        num_attempts_left=num_attempts_left,
        failed_attempts=failed_attempt_string,
    )


def no_info_aug_strat_prompt_generator(game: Game, task_setter_tag: str):
    """
    Generate prompt for historical task augmentation strategy.
    This strategy uses the task setter's archive and the current round's rejected questions.
    """
    with open(
        "skate/prompts/no-info-prompt.txt",
        "r",
    ) as f:
        prompt = f.read()

    round_number = game.current_round.round_number

    failed_attempts = game.current_round.rejected_questions.get(task_setter_tag, [])
    num_failed_attempts = len(failed_attempts)
    num_attempts_left = game.num_attempts - num_failed_attempts

    failed_attempt_string = ""
    if len(failed_attempts) > 0:
        for attempt in failed_attempts:
            text = attempt["text"]
            reason = attempt["reason"]
            failed_attempt_string += f"Question: {text}\nReason: {reason}\n"

    return prompt.format(
        round_number=round_number,
        num_attempts_left=num_attempts_left,
        failed_attempts=failed_attempt_string,
    )


def historical_task_aug_strat_prompt_generator(game: Game, task_setter_tag: str):
    """
    Generate prompt for historical task augmentation strategy.
    This strategy uses the task setter's archive and the current round's rejected questions.
    """
    with open(
        "skate/prompts/historical-tasks-prompt.txt",
        "r",
    ) as f:
        prompt = f.read()

    questions = game.archive.questions[task_setter_tag]
    if len(questions) > 0:
        questions = [q.text for q in questions]
        random.shuffle(questions)

    previous_questions = "\n".join(str(q) for q in questions)
    round_number = game.current_round.round_number

    failed_attempts = game.current_round.rejected_questions.get(task_setter_tag, [])
    num_failed_attempts = len(failed_attempts)
    num_attempts_left = game.num_attempts - num_failed_attempts

    failed_attempt_string = ""
    if len(failed_attempts) > 0:
        for attempt in failed_attempts:
            text = attempt["text"]
            reason = attempt["reason"]
            failed_attempt_string += f"Question: {text}\nReason: {reason}\n"

    return prompt.format(
        previous_questions=previous_questions,
        round_number=round_number,
        num_attempts_left=num_attempts_left,
        failed_attempts=failed_attempt_string,
    )
