Source code for angr.utils.timing

# pylint:disable=no-member
import time
from functools import wraps
from collections import defaultdict

TIMING = False
PRINT = False
TIME_DISTRIBUTION = False

total_time = defaultdict(float)
time_distribution = defaultdict(list)


[docs]def timethis(func): @wraps(func) def timed_func(*args, **kwargs): if TIMING: def _t(): return time.perf_counter_ns() / 1000000 start = _t() r = func(*args, **kwargs) millisec = _t() - start sec = millisec / 1000 if PRINT: if sec > 1.0: print(f"[timing] {func.__name__} took {sec:f} seconds ({millisec:f} milliseconds).") else: print(f"[timing] {func.__name__} took {millisec:f} milliseconds.") total_time[func] += millisec if TIME_DISTRIBUTION: time_distribution[func].append(millisec) return r else: return func(*args, **kwargs) return timed_func