"""
To support TRL supervised fine-tuning. Right now, we need to manually set the template here.
"""

alpaca_template = """Below is an instruction that describes a task. Write a response that appropriately completes the request.

### Instruction:
{} 

### Response: {}{}"""

vicuna_template = """A chat between a curious user and an artificial intelligence assistant. The assistant gives helpful, detailed, and polite answers to the user's questions. USER: {} ASSISTANT: {}{}"""


self_instruct_box_template = """<|user|>\n{}\nEnclose the final answer using \\boxed{{}}.\n<|assistant|>\n{}{}"""

kpmath_template = """User: Please reason step by step and put your final answer at the end with "The answer is: ".\n\n{}\n\nAssistant:\n{}{}"""

TEMPLATE_DICT = {
    'alpaca': (alpaca_template, '\n### Response:'),
    'vicuna': (vicuna_template, ' ASSISTANT:'),
}

TEMPLATE_DICT['self_instruct_box'] = (self_instruct_box_template, '\n<|assistant|>\n')

TEMPLATE_DICT['kpmath'] = (kpmath_template,'\n\nAssistant:\n')

def get_formatting_prompts_func(template_name, eos_token):
    overall_temp, response_temp = TEMPLATE_DICT[template_name]
    def formatting_prompts_func(example):    
        output_texts = []    
        for i in range(len(example['instruction'])):    
            text = overall_temp.format(example['instruction'][i], example['response'][i], eos_token)    
            output_texts.append(text)  
        return output_texts    
    
    return formatting_prompts_func, response_temp
