import logging
import os
from tempfile import TemporaryDirectory

_logger = logging.getLogger(__name__)

try:
    from evalplus.evaluate import evaluate
except ImportError:
    _logger.warning('evalplus library is not installed. Cannot use evalplus.')

DEFAULT_EVALPLUS_TASKS = ["humaneval", "mbpp"]

def evaluate_with_evalplus(model, tokenizer, tasks, full_outputs_dir=None, **kwargs):
    """ Instruction prefix is automatically added

    :param model:
    :param tokenizer: Tokenizer must have a prompt template
    :param tasks: list of tasks. Supported tasks: humaneval, mbpp
    :return:
    """
    results = {}
    for task in tasks:
        # write all data into a temporary directory
        with TemporaryDirectory() as td:
            f_name = os.path.join(td, task, "results")
            results[task] = evaluate(
                model="",
                dataset=task,
                greedy=True,
                temperature=0.0,
                device_map="auto",
                attn_implementation="flash_attention_2",
                output_file=f_name,  # sets path for results (these are discarded)
                pre_init_model=model,
                pre_init_tokenizer=tokenizer,
                backend="hf",
                root=full_outputs_dir or td,  # sets path for raw outputs
                **kwargs,
            )
    return results
