Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(138)

Side by Side Diff: build/android/pylib/utils/time_profile.py

Issue 1338813003: GN: Side-load dex files as well as native code in incremental installs (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix pylint warnings Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 # Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 # Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 import logging 5 import logging
6 import time 6 import time
7 7
8 8
9 class TimeProfile(object): 9 class TimeProfile(object):
10 """Class for simple profiling of action, with logging of cost.""" 10 """Class for simple profiling of action, with logging of cost."""
11 11
12 def __init__(self, description): 12 def __init__(self, description='operation'):
13 self._starttime = None 13 self._starttime = None
14 self._endtime = None
14 self._description = description 15 self._description = description
15 self.Start() 16 self.Start()
16 17
17 def Start(self): 18 def Start(self):
18 self._starttime = time.time() 19 self._starttime = time.time()
20 self._endtime = None
19 21
20 def Stop(self): 22 def GetDelta(self):
21 """Stop profiling and dump a log.""" 23 """Returns the rounded delta.
22 if self._starttime: 24
23 stoptime = time.time() 25 Also stops the timer if Stop() has not already been called.
24 logging.info('%fsec to perform %s', 26 """
25 stoptime - self._starttime, self._description) 27 if self._endtime is None:
26 self._starttime = None 28 self.Stop(log=False)
29 delta = self._endtime - self._starttime
30 delta = round(delta, 2) if delta < 10 else round(delta, 1)
31 return delta
32
33 def LogResult(self):
34 """Logs the result."""
35 logging.info('%s seconds to perform %s', self.GetDelta(), self._description)
36
37 def Stop(self, log=True):
38 """Stop profiling.
39
40 Args:
41 log: Log the delta (defaults to true).
42 """
43 self._endtime = time.time()
44 if log:
45 self.LogResult()
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698