|
OLD | NEW |
---|---|
(Empty) | |
1 #!/usr/bin/python | |
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 | |
4 # found in the LICENSE file. | |
5 | |
6 """Wapper for the chromite shell. | |
M-A Ruel
2011/01/26 21:08:18
Wrapper
diandersAtChromium
2011/01/26 21:17:44
Done.
| |
7 | |
8 This script is intended to run in several ways: | |
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 | |
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 | |
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 | |
15 real 'chromite/shell/main.py' based on the environment variable | |
16 CROS_WORKON_SRCROOT, so it doesn't matter what the CWD is. | |
17 | |
18 If you're looking at a copy and want to know where the original looks at, look | |
19 here: | |
20 http://git.chromium.org/gitweb/?p=chromite.git;a=blob;f=bin/chromite | |
21 | |
22 Since this script is _copied_, it should remain small and not use internal libs. | |
23 """ | |
24 | |
25 # Python imports. | |
26 import os | |
27 import sys | |
28 | |
29 if __name__ == '__main__': | |
30 # Look relative to CROS_WORKON_SRCROOT if that variable exists. This is | |
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; note that python will | |
37 # replace argv[0] with chromite_path when called, so we'll lose | |
38 # the name of / path to this wrapper. | |
39 os.execv(chromite_path, sys.argv) | |
40 | |
41 # Outside the chroot, search upward until we either end up with a blank dir | |
42 # or the "parent" dir doesn't change. Either of those is an error case. | |
43 dir = os.getcwd() | |
44 prev_dir = None | |
45 while dir and dir != prev_dir: | |
46 chromite_path = os.path.join(dir, 'chromite', 'shell', 'main.py') | |
47 if os.path.isfile(chromite_path): | |
48 # Add the directory above chromite to PYTHONPATH before executing, so | |
49 # that "import chromite.abc.xyz" works... | |
50 env = dict(os.environ) | |
M-A Ruel
2011/01/26 21:08:18
os.environ.copy()
diandersAtChromium
2011/01/26 21:17:44
Done.
| |
51 if 'PYTHONPATH' in env: | |
52 env['PYTHONPATH'] = "%s:%s" % (env['PYTHONPATH'], dir) | |
M-A Ruel
2011/01/26 21:08:18
env['PYTHONPATH'] += ':%s' % dir
diandersAtChromium
2011/01/26 21:17:44
Done.
| |
53 else: | |
54 env['PYTHONPATH'] = dir | |
55 | |
56 # Exec the script, which will never return; note that python will | |
57 # replace argv[0] with chromite_path when called, so we'll lose | |
58 # the name of / path to this wrapper. | |
59 os.execve(chromite_path, sys.argv, env) | |
60 | |
61 prev_dir = dir | |
62 dir = os.path.dirname(dir) | |
63 | |
64 # TODO(dianders): Should we actually print out the 'repo init' call that | |
65 # the user should use? | |
66 print ( | |
67 "ERROR: Couldn't find the chromite tool.\n" | |
68 "\n" | |
69 "Please change to a directory inside your Chromium OS source tree\n" | |
70 "and retry. If you need to setup a Chromium OS source tree, see:\n" | |
71 " http://www.chromium.org/chromium-os/developer-guide" | |
72 ) | |
OLD | NEW |