from datetime import datetime
from .ctflogging import status
from pathlib import Path
import re, sys

class CallIDGenerator:
    def __init__(self):
        self._id = 0

    def __call__(self):
        self._id += 1
        # status.debug_message(f"Call ID call-{self._id} generated by {inspect.stack()[1].function}")
        return f"call-{self._id}"

    def reset(self):
        self._id = 0

CALL_ID = CallIDGenerator()

def str2bool(s  : str) -> bool:
    """Convert a string to a boolean, with some reasonable variants on 'true'."""
    return str(s).strip().lower() in {"true", "1", "t", "y", "yes"}

def timestamp() -> str:
    """Return a timestamp string."""
    return datetime.now().astimezone().isoformat()

import sys
import re

ANSI_RE = re.compile(r"\x1b\[[0-?]*[ -/]*[@-~]")

class TeeOutput:
    def __init__(self, filename, mode="a", strip_ansi=True):
        self.terminal = sys.stdout
        self.logfile = open(filename, mode, encoding="utf-8")
        self.strip_ansi = strip_ansi
        self._buffer = ""

    def write(self, message):
        # Mirror to terminal
        self.terminal.write(message)

        # Buffer and flush on newline
        self._buffer += message
        while '\n' in self._buffer:
            line, self._buffer = self._buffer.split('\n', 1)
            if self.strip_ansi:
                line = ANSI_RE.sub("", line)
            self.logfile.write(line + '\n')
        self.logfile.flush()

    def flush(self):
        self.terminal.flush()
        self.logfile.flush()

    def close(self):
        if self._buffer:
            line = self._buffer
            if self.strip_ansi:
                line = ANSI_RE.sub("", line)
            self.logfile.write(line + '\n')
            self._buffer = ""
        self.flush()
        self.logfile.close()


def get_log_filename(args, challenge_id):
    # chalname = challenge.canonical_name
    chalname = challenge_id
    logdir = Path(args.logdir)
    logdir.mkdir(parents=True, exist_ok=True)

    # Append datetime to make unique name
    now = datetime.now().strftime("%y%m%d%H%M%S")
    return logdir / f"agent_communication_{chalname}-{now}.json"