import csv
import os
import time
from datetime import datetime

class Logger:

    def __init__(self, args, log_dir='./logs'):

        if not os.path.exists(log_dir):
            os.makedirs(log_dir)

        timestamp = datetime.now().strftime('%Y%m%d_%H%M%S')
        filename = f"{args.dataset}_{args.method}_clients{args.n_clients}_tasks{args.n_tasks}_alpha{args.dirichlet_alpha}_{timestamp}.csv"
        self.log_path = os.path.join(log_dir, filename)
        self.file = open(self.log_path, 'w', newline='')
        self.writer = csv.writer(self.file)
        
        # Write header
        self.header = [
            'task_id',
            'round_time_seconds',
            'accuracy_on_seen_tasks'
        ]
        self.writer.writerow(self.header)
        print(f"Logging results to {self.log_path}")

    def log_round(self, task_id, round_time, accuracy):

        self.writer.writerow([
            task_id,
            f"{round_time:.2f}",
            f"{accuracy:.2f}"
        ])
        self.file.flush() # Ensure data is written to disk

    def close(self):
        """
        Closes the log file.
        """
        self.file.close()
