Chromium Code Reviews

Side by Side Diff: bin/chromite

Issue 6334039: chromite: Switch from execve to import. (Closed) Base URL: ssh://git@gitrw.chromium.org:9222/chromite.git@master
Patch Set: Remove try: tower. Created 9 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | | 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/env 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 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
diandersAtChromium 2011/02/03 00:44:22 Please make it so that if chromite is already in t
Kenneth Waters 2011/02/03 18:16:41 jrbarnette wanted it this way.
diandersAtChromium 2011/02/03 18:36:01 Talked to jrbarnette. You can push this CL as is.
47 # Outside the chroot, search upward until the "parent" dir doesn't change 33 # Look in $CROS_WORKON_SRCROOT first.
48 # (on Linux, that means we're at '/'). That is an error case. 34 yield os.environ.get('CROS_WORKON_SRCROOT', '')
49 dir = os.getcwd()
50 prev_dir = None
51 while dir != prev_dir:
52 chromite_path = os.path.join(dir, 'chromite', 'shell', 'main.py')
53 if os.path.isfile(chromite_path):
54 # Add the directory above chromite to PYTHONPATH before executing, so
55 # that "import chromite.abc.xyz" works...
56 env = os.environ.copy()
57 if 'PYTHONPATH' in env:
58 env['PYTHONPATH'] += ':%s' % dir
59 else:
60 env['PYTHONPATH'] = dir
61 35
62 # Exec the script, which will never return. 36 # Search upward until we either end up with a blank dir or the "parent" dir
63 os.execve(chromite_path, sys.argv, env) 37 # doesn't change.
38 prev_path = None
39 while path and path != prev_path:
40 yield path
41 path, prev_path = os.path.dirname(path), path
64 42
65 prev_dir = dir
66 dir = os.path.dirname(dir)
67 43
44 sys.path.insert(0, '')
diandersAtChromium 2011/02/03 00:44:22 Please don't add ever '' into the path. This make
Kenneth Waters 2011/02/03 18:16:41 I was partially confused by by what interactive py
45 for path in Search(os.getcwd()):
46 sys.path[0] = path
47 try:
48 import chromite.shell.main
49 break
50 except ImportError:
51 pass
52 else:
68 # TODO(dianders): Should we actually print out the 'repo init' call that 53 # TODO(dianders): Should we actually print out the 'repo init' call that
69 # the user should use? 54 # the user should use?
70 print ( 55 sys.stderr.write(
71 "ERROR: Couldn't find the chromite tool.\n" 56 "ERROR: Couldn't find the chromite tool.\n"
72 "\n" 57 "\n"
73 "Please change to a directory inside your Chromium OS source tree\n" 58 "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" 59 "and retry. If you need to setup a Chromium OS source tree, see:\n"
75 " http://www.chromium.org/chromium-os/developer-guide" 60 " http://www.chromium.org/chromium-os/developer-guide\n")
76 )
77 sys.exit(1) 61 sys.exit(1)
62
63 chromite.shell.main.main()
64 sys.exit(0)
diandersAtChromium 2011/02/03 00:44:22 Can we remove this sys.exit(0)? ...if not, can yo
Kenneth Waters 2011/02/03 18:16:41 legacy. removed.
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine