import sys
import subprocess
import time
from utils.utils import write_running_time

venv_python = sys.executable


def execute_code(filepath, log_file: str, agent_name: str, timeout=10, args=None):
    """
    Executes a Python file in the user's virtual environment with optional command-line arguments.
    Optionally redirects standard output to a specified file.

    :param filepath: path to the file to be executed
    :param log_file: path to the log file for running time
    :param agent_name: name of the agent for logging
    :param timeout: time limit in minutes (default 30 minutes)
    :param args: list of command-line arguments to pass (e.g., ['--flag', 'value'])
    :return: text output of the code and error, if any
    """
    start_work = time.time()
    if args is None:
        args = []

    command = [venv_python, filepath] + args

    # Open the output file if output_filepath is provided
    stdout_file = None
    output_filepath = filepath.replace('.py', '.out')
    try:
        stdout_file = open(output_filepath, 'w')
        result = subprocess.run(
            command,
            text=True,
            stdout=stdout_file,
            stderr=subprocess.PIPE,
            timeout=timeout * 60,
            check=False
        )
        with open(output_filepath, 'r') as f:
            code_output = f.read()

        error = result.stderr if result.returncode != 0 else None

    except subprocess.TimeoutExpired as e:
        code_output = e.stdout or ''
        error = f"Runtime Error: exceeded {timeout} minutes timeout"
    except Exception as e:
        code_output = ""
        error = f"An unexpected error occurred: {e}"
    finally:
        if stdout_file:
            stdout_file.close()

    write_running_time(start_work, log_file, f"execute_{agent_name}")
    return code_output, error
