mirror of
https://chromium.googlesource.com/chromium/tools/depot_tools.git
synced 2026-01-11 18:51:29 +00:00
gclient_utils.py is a kitchen sink and is for that reason expensive to import. Move the comparatively cheap and simple path routines to a new gclient_paths module and use that in gn.py, clang_format.py, dart_format.py. (To be able to move FindGclientRoot() to gclient_paths.py, make it use io.open() instead of FileRead(). FileRead() tries to paper over invalid utf-8, but that was added for presubmits, not for .gclient files, so this is hopefully fine.) Cuts gn.py overhead in half (on my Windows laptop from 0.6s to 0.25s, still high; on my Mac laptop from 0.1s to 0.05s), and probably helps the other two too. Completely remove PathDifference() since it's unused. Bug: 939959 Change-Id: I6a70f6e4c16062b622fb2df8778e8a598d4cc956 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/tools/depot_tools/+/1512058 Commit-Queue: Nico Weber <thakis@chromium.org> Reviewed-by: Andrii Shyshkalov <tandrii@chromium.org>
77 lines
2.9 KiB
Python
Executable File
77 lines
2.9 KiB
Python
Executable File
#!/usr/bin/env python
|
|
# Copyright 2013 The Chromium Authors. All rights reserved.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
|
|
"""This script is a wrapper around the GN binary that is pulled from Google
|
|
Cloud Storage when you sync Chrome. The binaries go into platform-specific
|
|
subdirectories in the source tree.
|
|
|
|
This script makes there be one place for forwarding to the correct platform's
|
|
binary. It will also automatically try to find the gn binary when run inside
|
|
the chrome source tree, so users can just type "gn" on the command line
|
|
(normally depot_tools is on the path)."""
|
|
|
|
import gclient_paths
|
|
import os
|
|
import subprocess
|
|
import sys
|
|
|
|
|
|
def PruneVirtualEnv():
|
|
# Set by VirtualEnv, no need to keep it.
|
|
os.environ.pop('VIRTUAL_ENV', None)
|
|
|
|
# Set by VPython, if scripts want it back they have to set it explicitly.
|
|
os.environ.pop('PYTHONNOUSERSITE', None)
|
|
|
|
# Look for "activate_this.py" in this path, which is installed by VirtualEnv.
|
|
# This mechanism is used by vpython as well to sanitize VirtualEnvs from
|
|
# $PATH.
|
|
os.environ['PATH'] = os.pathsep.join([
|
|
p for p in os.environ.get('PATH', '').split(os.pathsep)
|
|
if not os.path.isfile(os.path.join(p, 'activate_this.py'))
|
|
])
|
|
|
|
|
|
def main(args):
|
|
# Prune all evidence of VPython/VirtualEnv out of the environment. This means
|
|
# that we 'unwrap' vpython VirtualEnv path/env manipulation. Invocations of
|
|
# `python` from GN should never inherit the gn.py's own VirtualEnv. This also
|
|
# helps to ensure that generated ninja files do not reference python.exe from
|
|
# the VirtualEnv generated from depot_tools' own .vpython file (or lack
|
|
# thereof), but instead reference the default python from the PATH.
|
|
PruneVirtualEnv()
|
|
|
|
# Try in primary solution location first, with the gn binary having been
|
|
# downloaded by cipd in the projects DEPS.
|
|
primary_solution_path = gclient_paths.GetPrimarySolutionPath()
|
|
if primary_solution_path:
|
|
gn_path = os.path.join(primary_solution_path, 'third_party',
|
|
'gn', 'gn' + gclient_paths.GetExeSuffix())
|
|
if os.path.exists(gn_path):
|
|
return subprocess.call([gn_path] + args[1:])
|
|
|
|
# Otherwise try the old .sha1 and download_from_google_storage locations
|
|
# inside of buildtools.
|
|
bin_path = gclient_paths.GetBuildtoolsPlatformBinaryPath()
|
|
if not bin_path:
|
|
print >> sys.stderr, ('gn.py: Could not find checkout in any parent of '
|
|
'the current path.\nThis must be run inside a '
|
|
'checkout.')
|
|
return 1
|
|
gn_path = os.path.join(bin_path, 'gn' + gclient_paths.GetExeSuffix())
|
|
if not os.path.exists(gn_path):
|
|
print >> sys.stderr, 'gn.py: Could not find gn executable at: %s' % gn_path
|
|
return 2
|
|
else:
|
|
return subprocess.call([gn_path] + args[1:])
|
|
|
|
|
|
if __name__ == '__main__':
|
|
try:
|
|
sys.exit(main(sys.argv))
|
|
except KeyboardInterrupt:
|
|
sys.stderr.write('interrupted\n')
|
|
sys.exit(1)
|