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

Side by Side Diff: tools/binary_size/helpers.py

Issue 2724253002: V1 of //tools/binary_size rewrite (Closed)
Patch Set: Put everthing after ()s in the name, not just [attrib] Created 3 years, 9 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
« no previous file with comments | « tools/binary_size/function_signature_test.py ('k') | tools/binary_size/mapfileparser.py » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 # Copyright 2017 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
4
5 """Utility methods."""
6
7 import atexit
8 import distutils.spawn
9 import logging
10 import os
11 import platform
12 import resource
13 import sys
14
15
16 SRC_ROOT = os.path.dirname(os.path.dirname(os.path.dirname(__file__)))
17
18
19 def AddCommonOptionsAndParseArgs(parser):
20 parser.add_argument('--no-pypy', action='store_true',
21 help='Do not automatically switch to pypy when available')
22 parser.add_argument('-v',
23 '--verbose',
24 default=0,
25 action='count',
26 help='Verbose level (multiple times for more)')
27
28 args = parser.parse_args()
29
30 logging.basicConfig(level=logging.WARNING - args.verbose * 10,
31 format='%(levelname).1s %(relativeCreated)6d %(message)s')
32
33 if not args.no_pypy and platform.python_implementation() == 'CPython':
34 # Switch to pypy if it's available.
35 pypy_path = distutils.spawn.find_executable('pypy')
36 if pypy_path:
37 logging.debug('Switching to pypy.')
38 os.execv(pypy_path, [pypy_path] + sys.argv)
39 # NOTE! Running with python: 6s. Running with pypy: 3s
40 logging.warning('This script runs more than 2x faster if you install pypy.')
41
42 if logging.getLogger().isEnabledFor(logging.DEBUG):
43 atexit.register(_LogPeakRamUsage)
44 return args
45
46
47 def _LogPeakRamUsage():
48 peak_ram_usage = resource.getrusage(resource.RUSAGE_SELF).ru_maxrss
49 peak_ram_usage += resource.getrusage(resource.RUSAGE_CHILDREN).ru_maxrss
50 logging.info('Peak RAM usage was %d MB.', peak_ram_usage / 1024)
OLDNEW
« no previous file with comments | « tools/binary_size/function_signature_test.py ('k') | tools/binary_size/mapfileparser.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698