from __future__ import annotations
import time
from contextlib import contextmanager
import logging

@contextmanager
def timer(name: str, logger: logging.Logger | None = None):
    t0 = time.perf_counter()
    yield
    dt = time.perf_counter() - t0
    if logger is not None:
        logger.info("[timer] %s: %.3fs", name, dt)
