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

Side by Side Diff: chromite

Issue 6286160: Update chromite to match the changes in chromiumos's git server. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/tools/depot_tools/
Patch Set: Created 9 years, 10 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) 2011 The Chromium OS Authors. All rights reserved. 2 # Copyright (c) 2011 The Chromium OS 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 """Wrapper for the chromite shell. 6 """Wrapper for the chromite shell.
7 7
8 This script is intended to run in several ways: 8 This script is intended to run in several ways:
9 - Outside the chroot, it should be _copied_ to someplace that is in the 9 - Outside the chroot, it should be _copied_ to someplace that is in the
10 path (like depot_tools). It will search for the right chromite by looking 10 path (like depot_tools). It will search for the right chromite by looking
11 for a file 'chromite/shell/main.py' upward based on the CWD. 11 for a file 'chromite/shell/main.py' upward based on the CWD.
12 - Inside the chroot, it might be _either_ copied to someplace in the path (since 12 - Inside the chroot, it might be _either_ copied to someplace in the path (since
13 depot_tools is in the path in the chroot) or it might run from chromite/bin 13 depot_tools is in the path in the chroot) or it might run from chromite/bin
14 directly, which should be in the PATH. In any case, we'll look for the 14 directly, which should be in the PATH. In any case, we'll look for the
15 real 'chromite/shell/main.py' based on the environment variable 15 real 'chromite/shell/main.py' based on the environment variable
16 CROS_WORKON_SRCROOT, so it doesn't matter what the CWD is. 16 CROS_WORKON_SRCROOT, so it doesn't matter what the CWD is.
17 17
18 If you're looking at a copy and want to know where the original looks at, look 18 If you're looking at a copy and want to know where the original looks at, look
19 here: 19 here:
20 http://git.chromium.org/gitweb/?p=chromite.git;a=blob;f=bin/chromite 20 http://git.chromium.org/gitweb/?p=chromite.git;a=blob;f=bin/chromite
21 21
22 Since this script is _copied_, it should remain small and not use internal libs. 22 Since this script is _copied_, it should remain small and not use internal libs.
23
23 """ 24 """
24 25
25 # Python imports. 26 # Python imports.
26 import os 27 import os
27 import sys 28 import sys
28 29
29 if __name__ == '__main__': 30 def Search(path):
30 # Look relative to CROS_WORKON_SRCROOT if that variable exists. This is 31 """Return an iterator of lists of places to look for chromite."""
31 # the "inside the chroot" case.
32 if 'CROS_WORKON_SRCROOT' in os.environ:
33 chromite_path = os.path.join(os.environ['CROS_WORKON_SRCROOT'],
34 'chromite', 'shell', 'main.py')
35 if os.path.isfile(chromite_path):
36 # Exec the script, which will never return.
37 os.execv(chromite_path, sys.argv)
38 else:
39 print (
40 "ERROR: Couldn't find the chromite tool.\n"
41 "\n"
42 "You may need to update your chroot. If you need help, see:\n"
43 " http://www.chromium.org/chromium-os/developer-guide"
44 )
45 sys.exit(1)
46 32
47 # Outside the chroot, search upward until the "parent" dir doesn't change 33 if os.path.exists('/etc/debian_chroot'):
48 # (on Linux, that means we're at '/'). That is an error case. 34 # We're in the chroot. Chromite should be in the python path inside the
49 dir = os.getcwd() 35 # chroot, so we don't do any searching. NOTE that we purposely don't want
50 prev_dir = None 36 # CROS_WORKON_SRCROOT in the python path.
51 while dir != prev_dir: 37 yield []
52 chromite_path = os.path.join(dir, 'chromite', 'shell', 'main.py') 38 else:
53 if os.path.isfile(chromite_path): 39 # Look in $CROS_WORKON_SRCROOT first. The idea is that a user would set
54 # Add the directory above chromite to PYTHONPATH before executing, so 40 # this manually if they wanted to specify a particular version of chromite.
55 # that "import chromite.abc.xyz" works... 41 if 'CROS_WORKON_SRCROOT' in os.environ:
56 env = os.environ.copy() 42 yield [os.environ['CROS_WORKON_SRCROOT']]
57 if 'PYTHONPATH' in env:
58 env['PYTHONPATH'] += ':%s' % dir
59 else:
60 env['PYTHONPATH'] = dir
61 43
62 # Exec the script, which will never return. 44 # Search upward until we either end up with a blank dir or the "parent" dir
63 os.execve(chromite_path, sys.argv, env) 45 # doesn't change.
46 prev_path = None
47 while path and path != prev_path:
48 yield [path]
49 path, prev_path = os.path.dirname(path), path
64 50
65 prev_dir = dir
66 dir = os.path.dirname(dir)
67 51
52 for path in Search(os.getcwd()):
53 sys.path = path + sys.path
54 try:
55 import chromite.shell.main
56 break
57 except ImportError, e:
58 # We've got different modules named chromite in the tree, pulling in the
59 # wrong one will break the right one. So unload it.
60 if 'chromite' in sys.modules:
61 del sys.modules['chromite']
62 sys.path = sys.path[len(path):]
63 else:
68 # TODO(dianders): Should we actually print out the 'repo init' call that 64 # TODO(dianders): Should we actually print out the 'repo init' call that
69 # the user should use? 65 # the user should use?
70 print ( 66 sys.stderr.write(
71 "ERROR: Couldn't find the chromite tool.\n" 67 "ERROR: Couldn't find the chromite tool.\n"
72 "\n" 68 "\n"
73 "Please change to a directory inside your Chromium OS source tree\n" 69 "Please change to a directory inside your Chromium OS source tree\n"
74 "and retry. If you need to setup a Chromium OS source tree, see:\n" 70 "and retry. If you need to setup a Chromium OS source tree, see:\n"
75 " http://www.chromium.org/chromium-os/developer-guide" 71 " http://www.chromium.org/chromium-os/developer-guide\n")
76 )
77 sys.exit(1) 72 sys.exit(1)
73
74 chromite.shell.main.main()
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