# turborag/metrics.py
import time
from collections import defaultdict

class QueryMetrics:
    """A simple class to encapsulate timing and other metrics for a single query."""
    def __init__(self):
        self.totals = defaultdict(float)
        self._start_times = {}

    def start(self, name: str):
        """Starts a timer for a given metric."""
        self._start_times[name] = time.perf_counter()

    def stop(self, name: str):
        """Stops a timer and accumulates the elapsed time."""
        if name in self._start_times:
            elapsed = time.perf_counter() - self._start_times.pop(name)
            self.totals[name] += elapsed

    def add(self, name: str, value: float):
        """Adds a value to a given metric."""
        self.totals[name] += value

    def get(self, name: str) -> float:
        """Gets the total value for a given metric."""
        return self.totals.get(name, 0.0) 