aboutsummaryrefslogtreecommitdiffstats
path: root/library/python/import_tracing/lib/import_tracer.py
blob: 39dfc11bc98969075fc1dc01831bcfea69caa04a (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
import threading
import time
import collections
import library.python.import_tracing.lib.event as events
import library.python.import_tracing.lib.constants as constants


class ImportTracer:
    def __init__(self):
        self.events = collections.OrderedDict()
        self.start_time = time.time()

    def start_event(self, modname, filename, tid=None):
        tid = tid if tid is not None else threading.current_thread().ident
        time_from_start = self._get_current_time_from_start()

        event_key = (modname, tid)
        new_event = events.Event(
            modname=modname,
            filename=filename,
            tid=tid,
            start_time=time_from_start,
            end_time=None,
        )

        self.events[event_key] = new_event

    def finish_event(self, modname, filename, tid=None):
        tid = tid if tid is not None else threading.current_thread().ident
        event_key = (modname, tid)
        event = self.events[event_key]

        end_time = self._get_current_time_from_start()
        event.end_time = end_time

    def get_events(self, close_not_finished=False):
        end_time = self._get_current_time_from_start()

        for event in self.events.values():
            if close_not_finished and event.end_time is None:
                yield events.Event(
                    modname=event.modname,
                    filename=event.filename,
                    tid=event.tid,
                    start_time=event.start_time,
                    end_time=end_time,
                )
            else:
                yield event

    def _get_current_time_from_start(self):
        return (time.time() - self.start_time) * constants.MCS_IN_SEC