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

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

Issue 2813963002: //tools/binary_size: Consolidate most tools into "supersize" command (Closed)
Patch Set: Fix readme formatting. Make archive's --outoput-file a positional arg Created 3 years, 8 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/integration_test.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, argv, pypy_warn=True):
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 args = parser.parse_args(argv[1:])
28
29 logging.basicConfig(level=logging.WARNING - args.verbose * 10,
30 format='%(levelname).1s %(relativeCreated)6d %(message)s')
31
32 if not args.no_pypy and platform.python_implementation() == 'CPython':
33 # Switch to pypy if it's available.
34 pypy_path = distutils.spawn.find_executable('pypy')
35 if pypy_path:
36 logging.debug('Switching to pypy.')
37 os.execv(pypy_path, [pypy_path] + sys.argv)
38 # NOTE! Running with python: 6s. Running with pypy: 3s
39 if pypy_warn:
40 logging.warning(
41 'This script runs more than 2x faster if you install pypy.')
42
43 if logging.getLogger().isEnabledFor(logging.DEBUG):
44 atexit.register(_LogPeakRamUsage)
45 return args
46
47
48 def _LogPeakRamUsage():
49 peak_ram_usage = resource.getrusage(resource.RUSAGE_SELF).ru_maxrss
50 peak_ram_usage += resource.getrusage(resource.RUSAGE_CHILDREN).ru_maxrss
51 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/integration_test.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698