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

Side by Side Diff: git-cl-upload-hook

Issue 2852032: git-cl-upload-hook: improved finding depot_tools algorithm... (Closed) Base URL: http://src.chromium.org/svn/trunk/tools/depot_tools/
Patch Set: '' Created 10 years, 5 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 | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/usr/bin/python 1 #!/usr/bin/python
2 # Copyright (c) 2009 The Chromium Authors. All rights reserved. 2 # Copyright (c) 2009 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be 3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file. 4 # found in the LICENSE file.
5 5
6 import os 6 import os
7 import sys 7 import sys
8 from subprocess import Popen, PIPE
8 9
9 # Try locating depot_tools from the user's PATH. 10 # Try locating depot_tools from the user's PATH.
10 depot_tools_path = None 11 depot_tools_path = None
12
13 # First parse PATH if there's a "depot_tools" inside
11 for path in os.environ.get("PATH").split(os.pathsep): 14 for path in os.environ.get("PATH").split(os.pathsep):
12 if not path.endswith("depot_tools"): 15 if not path.endswith("depot_tools") and not path.endswith("depot_tools/"):
13 continue 16 continue
14 depot_tools_path = path 17 depot_tools_path = path
15 break 18 break
16 19
20 # If depot_tools dir is not called depot_tools, or other weirdness
21 if not depot_tools_path:
22 # Grab a `which gclient', which gives first match
23 # `which' also uses PATH, but is not restricted to specific directory name
24 path = Popen(["which", "gclient"], stdout=PIPE).communicate()[0]
25 if path:
26 depot_tools_path = path.replace("/gclient","")
27
17 # If we found depot_tools, add it to the script's import path. 28 # If we found depot_tools, add it to the script's import path.
29 # Use realpath to normalize the actual path
18 if depot_tools_path: 30 if depot_tools_path:
19 sys.path.append(depot_tools_path) 31 sys.path.append(os.path.realpath(depot_tools_path))
20 else: 32 else:
21 print "ERROR: Could not find depot_tools in your PATH." 33 print "ERROR: Could not find depot_tools in your PATH."
22 print "ERROR: Please add it to your PATH and try again." 34 print "ERROR: Please add it to your PATH and try again."
23 sys.exit(1) 35 sys.exit(1)
24 36
25 # Try importing git_cl_hooks from depot_tools. 37 # Try importing git_cl_hooks from depot_tools.
26 try: 38 try:
27 import git_cl_hooks 39 import git_cl_hooks
28 except ImportError: 40 except ImportError:
29 print "ERROR: Could not import git_cl_hooks from depot_tools in your PATH." 41 print "ERROR: Could not import git_cl_hooks from depot_tools in your PATH."
30 print "ERROR: Make sure %s is up-to-date and try again." % depot_tools_path 42 print "ERROR: Make sure %s is up-to-date and try again." % depot_tools_path
31 sys.exit(1) 43 sys.exit(1)
32 44
33 # Ensure we were called with the necessary number of arguments. 45 # Ensure we were called with the necessary number of arguments.
34 program_name = os.path.basename(sys.argv[0]) 46 program_name = os.path.basename(sys.argv[0])
35 if len(sys.argv) != 2: 47 if len(sys.argv) != 2:
36 print "usage: %s [upstream branch]" % program_name 48 print "usage: %s [upstream branch]" % program_name
37 sys.exit(1) 49 sys.exit(1)
38 50
39 # Run the hooks library with our arguments. 51 # Run the hooks library with our arguments.
40 exec git_cl_hooks.RunHooks(hook_name=program_name, upstream_branch=sys.argv[1]) 52 exec git_cl_hooks.RunHooks(hook_name=program_name, upstream_branch=sys.argv[1])
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698