author | durandn |
Tue, 13 Sep 2016 17:06:44 +0200 | |
changeset 199 | fe88e9c5dd60 |
parent 191 | 38be6b00f568 |
permissions | -rwxr-xr-x |
3 | 1 |
#!/usr/bin/env python |
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2 |
"""Create a "virtual" Python installation""" |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
3 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
4 |
import os |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
5 |
import sys |
3 | 6 |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
7 |
# If we are running in a new interpreter to create a virtualenv, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
8 |
# we do NOT want paths from our existing location interfering with anything, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
9 |
# So we remove this file's directory from sys.path - most likely to be |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
10 |
# the previous interpreter's site-packages. Solves #705, #763, #779 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
11 |
if os.environ.get('VIRTUALENV_INTERPRETER_RUNNING'): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
12 |
for path in sys.path[:]: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
13 |
if os.path.realpath(os.path.dirname(__file__)) == os.path.realpath(path): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
14 |
sys.path.remove(path) |
3 | 15 |
|
16 |
import base64 |
|
17 |
import codecs |
|
18 |
import optparse |
|
19 |
import re |
|
20 |
import shutil |
|
21 |
import logging |
|
22 |
import zlib |
|
23 |
import errno |
|
24 |
import glob |
|
25 |
import distutils.sysconfig |
|
26 |
import struct |
|
27 |
import subprocess |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
28 |
import pkgutil |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
29 |
import tempfile |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
30 |
import textwrap |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
31 |
from distutils.util import strtobool |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
32 |
from os.path import join |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
33 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
34 |
try: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
35 |
import ConfigParser |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
36 |
except ImportError: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
37 |
import configparser as ConfigParser |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
38 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
39 |
__version__ = "15.0.0" |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
40 |
virtualenv_version = __version__ # legacy |
3 | 41 |
|
42 |
if sys.version_info < (2, 6): |
|
43 |
print('ERROR: %s' % sys.exc_info()[1]) |
|
44 |
print('ERROR: this script requires Python 2.6 or greater.') |
|
45 |
sys.exit(101) |
|
46 |
||
47 |
try: |
|
48 |
basestring |
|
49 |
except NameError: |
|
50 |
basestring = str |
|
51 |
||
52 |
py_version = 'python%s.%s' % (sys.version_info[0], sys.version_info[1]) |
|
53 |
||
54 |
is_jython = sys.platform.startswith('java') |
|
55 |
is_pypy = hasattr(sys, 'pypy_version_info') |
|
56 |
is_win = (sys.platform == 'win32') |
|
57 |
is_cygwin = (sys.platform == 'cygwin') |
|
58 |
is_darwin = (sys.platform == 'darwin') |
|
59 |
abiflags = getattr(sys, 'abiflags', '') |
|
60 |
||
61 |
user_dir = os.path.expanduser('~') |
|
62 |
if is_win: |
|
63 |
default_storage_dir = os.path.join(user_dir, 'virtualenv') |
|
64 |
else: |
|
65 |
default_storage_dir = os.path.join(user_dir, '.virtualenv') |
|
66 |
default_config_file = os.path.join(default_storage_dir, 'virtualenv.ini') |
|
67 |
||
68 |
if is_pypy: |
|
69 |
expected_exe = 'pypy' |
|
70 |
elif is_jython: |
|
71 |
expected_exe = 'jython' |
|
72 |
else: |
|
73 |
expected_exe = 'python' |
|
74 |
||
75 |
# Return a mapping of version -> Python executable |
|
76 |
# Only provided for Windows, where the information in the registry is used |
|
77 |
if not is_win: |
|
78 |
def get_installed_pythons(): |
|
79 |
return {} |
|
80 |
else: |
|
81 |
try: |
|
82 |
import winreg |
|
83 |
except ImportError: |
|
84 |
import _winreg as winreg |
|
85 |
||
86 |
def get_installed_pythons(): |
|
87 |
try: |
|
88 |
python_core = winreg.CreateKey(winreg.HKEY_LOCAL_MACHINE, |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
89 |
"Software\\Python\\PythonCore") |
3 | 90 |
except WindowsError: |
91 |
# No registered Python installations |
|
92 |
return {} |
|
93 |
i = 0 |
|
94 |
versions = [] |
|
95 |
while True: |
|
96 |
try: |
|
97 |
versions.append(winreg.EnumKey(python_core, i)) |
|
98 |
i = i + 1 |
|
99 |
except WindowsError: |
|
100 |
break |
|
101 |
exes = dict() |
|
102 |
for ver in versions: |
|
103 |
try: |
|
104 |
path = winreg.QueryValue(python_core, "%s\\InstallPath" % ver) |
|
105 |
except WindowsError: |
|
106 |
continue |
|
107 |
exes[ver] = join(path, "python.exe") |
|
108 |
||
109 |
winreg.CloseKey(python_core) |
|
110 |
||
111 |
# Add the major versions |
|
112 |
# Sort the keys, then repeatedly update the major version entry |
|
113 |
# Last executable (i.e., highest version) wins with this approach |
|
114 |
for ver in sorted(exes): |
|
115 |
exes[ver[0]] = exes[ver] |
|
116 |
||
117 |
return exes |
|
118 |
||
119 |
REQUIRED_MODULES = ['os', 'posix', 'posixpath', 'nt', 'ntpath', 'genericpath', |
|
120 |
'fnmatch', 'locale', 'encodings', 'codecs', |
|
121 |
'stat', 'UserDict', 'readline', 'copy_reg', 'types', |
|
122 |
're', 'sre', 'sre_parse', 'sre_constants', 'sre_compile', |
|
123 |
'zlib'] |
|
124 |
||
125 |
REQUIRED_FILES = ['lib-dynload', 'config'] |
|
126 |
||
127 |
majver, minver = sys.version_info[:2] |
|
128 |
if majver == 2: |
|
129 |
if minver >= 6: |
|
130 |
REQUIRED_MODULES.extend(['warnings', 'linecache', '_abcoll', 'abc']) |
|
131 |
if minver >= 7: |
|
132 |
REQUIRED_MODULES.extend(['_weakrefset']) |
|
133 |
elif majver == 3: |
|
134 |
# Some extra modules are needed for Python 3, but different ones |
|
135 |
# for different versions. |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
136 |
REQUIRED_MODULES.extend([ |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
137 |
'_abcoll', 'warnings', 'linecache', 'abc', 'io', '_weakrefset', |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
138 |
'copyreg', 'tempfile', 'random', '__future__', 'collections', |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
139 |
'keyword', 'tarfile', 'shutil', 'struct', 'copy', 'tokenize', |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
140 |
'token', 'functools', 'heapq', 'bisect', 'weakref', 'reprlib' |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
141 |
]) |
3 | 142 |
if minver >= 2: |
143 |
REQUIRED_FILES[-1] = 'config-%s' % majver |
|
144 |
if minver >= 3: |
|
145 |
import sysconfig |
|
146 |
platdir = sysconfig.get_config_var('PLATDIR') |
|
147 |
REQUIRED_FILES.append(platdir) |
|
148 |
REQUIRED_MODULES.extend([ |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
149 |
'base64', '_dummy_thread', 'hashlib', 'hmac', |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
150 |
'imp', 'importlib', 'rlcompleter' |
3 | 151 |
]) |
152 |
if minver >= 4: |
|
153 |
REQUIRED_MODULES.extend([ |
|
154 |
'operator', |
|
155 |
'_collections_abc', |
|
156 |
'_bootlocale', |
|
157 |
]) |
|
158 |
||
159 |
if is_pypy: |
|
160 |
# these are needed to correctly display the exceptions that may happen |
|
161 |
# during the bootstrap |
|
162 |
REQUIRED_MODULES.extend(['traceback', 'linecache']) |
|
163 |
||
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
164 |
|
3 | 165 |
class Logger(object): |
166 |
||
167 |
""" |
|
168 |
Logging object for use in command-line script. Allows ranges of |
|
169 |
levels, to avoid some redundancy of displayed information. |
|
170 |
""" |
|
171 |
||
172 |
DEBUG = logging.DEBUG |
|
173 |
INFO = logging.INFO |
|
174 |
NOTIFY = (logging.INFO+logging.WARN)/2 |
|
175 |
WARN = WARNING = logging.WARN |
|
176 |
ERROR = logging.ERROR |
|
177 |
FATAL = logging.FATAL |
|
178 |
||
179 |
LEVELS = [DEBUG, INFO, NOTIFY, WARN, ERROR, FATAL] |
|
180 |
||
181 |
def __init__(self, consumers): |
|
182 |
self.consumers = consumers |
|
183 |
self.indent = 0 |
|
184 |
self.in_progress = None |
|
185 |
self.in_progress_hanging = False |
|
186 |
||
187 |
def debug(self, msg, *args, **kw): |
|
188 |
self.log(self.DEBUG, msg, *args, **kw) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
189 |
|
3 | 190 |
def info(self, msg, *args, **kw): |
191 |
self.log(self.INFO, msg, *args, **kw) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
192 |
|
3 | 193 |
def notify(self, msg, *args, **kw): |
194 |
self.log(self.NOTIFY, msg, *args, **kw) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
195 |
|
3 | 196 |
def warn(self, msg, *args, **kw): |
197 |
self.log(self.WARN, msg, *args, **kw) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
198 |
|
3 | 199 |
def error(self, msg, *args, **kw): |
200 |
self.log(self.ERROR, msg, *args, **kw) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
201 |
|
3 | 202 |
def fatal(self, msg, *args, **kw): |
203 |
self.log(self.FATAL, msg, *args, **kw) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
204 |
|
3 | 205 |
def log(self, level, msg, *args, **kw): |
206 |
if args: |
|
207 |
if kw: |
|
208 |
raise TypeError( |
|
209 |
"You may give positional or keyword arguments, not both") |
|
210 |
args = args or kw |
|
211 |
rendered = None |
|
212 |
for consumer_level, consumer in self.consumers: |
|
213 |
if self.level_matches(level, consumer_level): |
|
214 |
if (self.in_progress_hanging |
|
215 |
and consumer in (sys.stdout, sys.stderr)): |
|
216 |
self.in_progress_hanging = False |
|
217 |
sys.stdout.write('\n') |
|
218 |
sys.stdout.flush() |
|
219 |
if rendered is None: |
|
220 |
if args: |
|
221 |
rendered = msg % args |
|
222 |
else: |
|
223 |
rendered = msg |
|
224 |
rendered = ' '*self.indent + rendered |
|
225 |
if hasattr(consumer, 'write'): |
|
226 |
consumer.write(rendered+'\n') |
|
227 |
else: |
|
228 |
consumer(rendered) |
|
229 |
||
230 |
def start_progress(self, msg): |
|
231 |
assert not self.in_progress, ( |
|
232 |
"Tried to start_progress(%r) while in_progress %r" |
|
233 |
% (msg, self.in_progress)) |
|
234 |
if self.level_matches(self.NOTIFY, self._stdout_level()): |
|
235 |
sys.stdout.write(msg) |
|
236 |
sys.stdout.flush() |
|
237 |
self.in_progress_hanging = True |
|
238 |
else: |
|
239 |
self.in_progress_hanging = False |
|
240 |
self.in_progress = msg |
|
241 |
||
242 |
def end_progress(self, msg='done.'): |
|
243 |
assert self.in_progress, ( |
|
244 |
"Tried to end_progress without start_progress") |
|
245 |
if self.stdout_level_matches(self.NOTIFY): |
|
246 |
if not self.in_progress_hanging: |
|
247 |
# Some message has been printed out since start_progress |
|
248 |
sys.stdout.write('...' + self.in_progress + msg + '\n') |
|
249 |
sys.stdout.flush() |
|
250 |
else: |
|
251 |
sys.stdout.write(msg + '\n') |
|
252 |
sys.stdout.flush() |
|
253 |
self.in_progress = None |
|
254 |
self.in_progress_hanging = False |
|
255 |
||
256 |
def show_progress(self): |
|
257 |
"""If we are in a progress scope, and no log messages have been |
|
258 |
shown, write out another '.'""" |
|
259 |
if self.in_progress_hanging: |
|
260 |
sys.stdout.write('.') |
|
261 |
sys.stdout.flush() |
|
262 |
||
263 |
def stdout_level_matches(self, level): |
|
264 |
"""Returns true if a message at this level will go to stdout""" |
|
265 |
return self.level_matches(level, self._stdout_level()) |
|
266 |
||
267 |
def _stdout_level(self): |
|
268 |
"""Returns the level that stdout runs at""" |
|
269 |
for level, consumer in self.consumers: |
|
270 |
if consumer is sys.stdout: |
|
271 |
return level |
|
272 |
return self.FATAL |
|
273 |
||
274 |
def level_matches(self, level, consumer_level): |
|
275 |
""" |
|
276 |
>>> l = Logger([]) |
|
277 |
>>> l.level_matches(3, 4) |
|
278 |
False |
|
279 |
>>> l.level_matches(3, 2) |
|
280 |
True |
|
281 |
>>> l.level_matches(slice(None, 3), 3) |
|
282 |
False |
|
283 |
>>> l.level_matches(slice(None, 3), 2) |
|
284 |
True |
|
285 |
>>> l.level_matches(slice(1, 3), 1) |
|
286 |
True |
|
287 |
>>> l.level_matches(slice(2, 3), 1) |
|
288 |
False |
|
289 |
""" |
|
290 |
if isinstance(level, slice): |
|
291 |
start, stop = level.start, level.stop |
|
292 |
if start is not None and start > consumer_level: |
|
293 |
return False |
|
294 |
if stop is not None and stop <= consumer_level: |
|
295 |
return False |
|
296 |
return True |
|
297 |
else: |
|
298 |
return level >= consumer_level |
|
299 |
||
300 |
#@classmethod |
|
301 |
def level_for_integer(cls, level): |
|
302 |
levels = cls.LEVELS |
|
303 |
if level < 0: |
|
304 |
return levels[0] |
|
305 |
if level >= len(levels): |
|
306 |
return levels[-1] |
|
307 |
return levels[level] |
|
308 |
||
309 |
level_for_integer = classmethod(level_for_integer) |
|
310 |
||
311 |
# create a silent logger just to prevent this from being undefined |
|
312 |
# will be overridden with requested verbosity main() is called. |
|
313 |
logger = Logger([(Logger.LEVELS[-1], sys.stdout)]) |
|
314 |
||
315 |
def mkdir(path): |
|
316 |
if not os.path.exists(path): |
|
317 |
logger.info('Creating %s', path) |
|
318 |
os.makedirs(path) |
|
319 |
else: |
|
320 |
logger.info('Directory %s already exists', path) |
|
321 |
||
322 |
def copyfileordir(src, dest, symlink=True): |
|
323 |
if os.path.isdir(src): |
|
324 |
shutil.copytree(src, dest, symlink) |
|
325 |
else: |
|
326 |
shutil.copy2(src, dest) |
|
327 |
||
328 |
def copyfile(src, dest, symlink=True): |
|
329 |
if not os.path.exists(src): |
|
330 |
# Some bad symlink in the src |
|
331 |
logger.warn('Cannot find file %s (bad symlink)', src) |
|
332 |
return |
|
333 |
if os.path.exists(dest): |
|
334 |
logger.debug('File %s already exists', dest) |
|
335 |
return |
|
336 |
if not os.path.exists(os.path.dirname(dest)): |
|
337 |
logger.info('Creating parent directories for %s', os.path.dirname(dest)) |
|
338 |
os.makedirs(os.path.dirname(dest)) |
|
339 |
if not os.path.islink(src): |
|
340 |
srcpath = os.path.abspath(src) |
|
341 |
else: |
|
342 |
srcpath = os.readlink(src) |
|
343 |
if symlink and hasattr(os, 'symlink') and not is_win: |
|
344 |
logger.info('Symlinking %s', dest) |
|
345 |
try: |
|
346 |
os.symlink(srcpath, dest) |
|
347 |
except (OSError, NotImplementedError): |
|
348 |
logger.info('Symlinking failed, copying to %s', dest) |
|
349 |
copyfileordir(src, dest, symlink) |
|
350 |
else: |
|
351 |
logger.info('Copying to %s', dest) |
|
352 |
copyfileordir(src, dest, symlink) |
|
353 |
||
354 |
def writefile(dest, content, overwrite=True): |
|
355 |
if not os.path.exists(dest): |
|
356 |
logger.info('Writing %s', dest) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
357 |
with open(dest, 'wb') as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
358 |
f.write(content.encode('utf-8')) |
3 | 359 |
return |
360 |
else: |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
361 |
with open(dest, 'rb') as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
362 |
c = f.read() |
3 | 363 |
if c != content.encode("utf-8"): |
364 |
if not overwrite: |
|
365 |
logger.notify('File %s exists with different content; not overwriting', dest) |
|
366 |
return |
|
367 |
logger.notify('Overwriting %s with new content', dest) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
368 |
with open(dest, 'wb') as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
369 |
f.write(content.encode('utf-8')) |
3 | 370 |
else: |
371 |
logger.info('Content %s already in place', dest) |
|
372 |
||
373 |
def rmtree(dir): |
|
374 |
if os.path.exists(dir): |
|
375 |
logger.notify('Deleting tree %s', dir) |
|
376 |
shutil.rmtree(dir) |
|
377 |
else: |
|
378 |
logger.info('Do not need to delete %s; already gone', dir) |
|
379 |
||
380 |
def make_exe(fn): |
|
381 |
if hasattr(os, 'chmod'): |
|
382 |
oldmode = os.stat(fn).st_mode & 0xFFF # 0o7777 |
|
383 |
newmode = (oldmode | 0x16D) & 0xFFF # 0o555, 0o7777 |
|
384 |
os.chmod(fn, newmode) |
|
385 |
logger.info('Changed mode of %s to %s', fn, oct(newmode)) |
|
386 |
||
387 |
def _find_file(filename, dirs): |
|
388 |
for dir in reversed(dirs): |
|
389 |
files = glob.glob(os.path.join(dir, filename)) |
|
390 |
if files and os.path.isfile(files[0]): |
|
391 |
return True, files[0] |
|
392 |
return False, filename |
|
393 |
||
394 |
def file_search_dirs(): |
|
395 |
here = os.path.dirname(os.path.abspath(__file__)) |
|
396 |
dirs = [here, join(here, 'virtualenv_support')] |
|
397 |
if os.path.splitext(os.path.dirname(__file__))[0] != 'virtualenv': |
|
398 |
# Probably some boot script; just in case virtualenv is installed... |
|
399 |
try: |
|
400 |
import virtualenv |
|
401 |
except ImportError: |
|
402 |
pass |
|
403 |
else: |
|
404 |
dirs.append(os.path.join( |
|
405 |
os.path.dirname(virtualenv.__file__), 'virtualenv_support')) |
|
406 |
return [d for d in dirs if os.path.isdir(d)] |
|
407 |
||
408 |
||
409 |
class UpdatingDefaultsHelpFormatter(optparse.IndentedHelpFormatter): |
|
410 |
""" |
|
411 |
Custom help formatter for use in ConfigOptionParser that updates |
|
412 |
the defaults before expanding them, allowing them to show up correctly |
|
413 |
in the help listing |
|
414 |
""" |
|
415 |
def expand_default(self, option): |
|
416 |
if self.parser is not None: |
|
417 |
self.parser.update_defaults(self.parser.defaults) |
|
418 |
return optparse.IndentedHelpFormatter.expand_default(self, option) |
|
419 |
||
420 |
||
421 |
class ConfigOptionParser(optparse.OptionParser): |
|
422 |
""" |
|
423 |
Custom option parser which updates its defaults by checking the |
|
424 |
configuration files and environmental variables |
|
425 |
""" |
|
426 |
def __init__(self, *args, **kwargs): |
|
427 |
self.config = ConfigParser.RawConfigParser() |
|
428 |
self.files = self.get_config_files() |
|
429 |
self.config.read(self.files) |
|
430 |
optparse.OptionParser.__init__(self, *args, **kwargs) |
|
431 |
||
432 |
def get_config_files(self): |
|
433 |
config_file = os.environ.get('VIRTUALENV_CONFIG_FILE', False) |
|
434 |
if config_file and os.path.exists(config_file): |
|
435 |
return [config_file] |
|
436 |
return [default_config_file] |
|
437 |
||
438 |
def update_defaults(self, defaults): |
|
439 |
""" |
|
440 |
Updates the given defaults with values from the config files and |
|
441 |
the environ. Does a little special handling for certain types of |
|
442 |
options (lists). |
|
443 |
""" |
|
444 |
# Then go and look for the other sources of configuration: |
|
445 |
config = {} |
|
446 |
# 1. config files |
|
447 |
config.update(dict(self.get_config_section('virtualenv'))) |
|
448 |
# 2. environmental variables |
|
449 |
config.update(dict(self.get_environ_vars())) |
|
450 |
# Then set the options with those values |
|
451 |
for key, val in config.items(): |
|
452 |
key = key.replace('_', '-') |
|
453 |
if not key.startswith('--'): |
|
454 |
key = '--%s' % key # only prefer long opts |
|
455 |
option = self.get_option(key) |
|
456 |
if option is not None: |
|
457 |
# ignore empty values |
|
458 |
if not val: |
|
459 |
continue |
|
460 |
# handle multiline configs |
|
461 |
if option.action == 'append': |
|
462 |
val = val.split() |
|
463 |
else: |
|
464 |
option.nargs = 1 |
|
465 |
if option.action == 'store_false': |
|
466 |
val = not strtobool(val) |
|
467 |
elif option.action in ('store_true', 'count'): |
|
468 |
val = strtobool(val) |
|
469 |
try: |
|
470 |
val = option.convert_value(key, val) |
|
471 |
except optparse.OptionValueError: |
|
472 |
e = sys.exc_info()[1] |
|
473 |
print("An error occurred during configuration: %s" % e) |
|
474 |
sys.exit(3) |
|
475 |
defaults[option.dest] = val |
|
476 |
return defaults |
|
477 |
||
478 |
def get_config_section(self, name): |
|
479 |
""" |
|
480 |
Get a section of a configuration |
|
481 |
""" |
|
482 |
if self.config.has_section(name): |
|
483 |
return self.config.items(name) |
|
484 |
return [] |
|
485 |
||
486 |
def get_environ_vars(self, prefix='VIRTUALENV_'): |
|
487 |
""" |
|
488 |
Returns a generator with all environmental vars with prefix VIRTUALENV |
|
489 |
""" |
|
490 |
for key, val in os.environ.items(): |
|
491 |
if key.startswith(prefix): |
|
492 |
yield (key.replace(prefix, '').lower(), val) |
|
493 |
||
494 |
def get_default_values(self): |
|
495 |
""" |
|
496 |
Overridding to make updating the defaults after instantiation of |
|
497 |
the option parser possible, update_defaults() does the dirty work. |
|
498 |
""" |
|
499 |
if not self.process_default_values: |
|
500 |
# Old, pre-Optik 1.5 behaviour. |
|
501 |
return optparse.Values(self.defaults) |
|
502 |
||
503 |
defaults = self.update_defaults(self.defaults.copy()) # ours |
|
504 |
for option in self._get_all_options(): |
|
505 |
default = defaults.get(option.dest) |
|
506 |
if isinstance(default, basestring): |
|
507 |
opt_str = option.get_opt_string() |
|
508 |
defaults[option.dest] = option.check_value(opt_str, default) |
|
509 |
return optparse.Values(defaults) |
|
510 |
||
511 |
||
512 |
def main(): |
|
513 |
parser = ConfigOptionParser( |
|
514 |
version=virtualenv_version, |
|
515 |
usage="%prog [OPTIONS] DEST_DIR", |
|
516 |
formatter=UpdatingDefaultsHelpFormatter()) |
|
517 |
||
518 |
parser.add_option( |
|
519 |
'-v', '--verbose', |
|
520 |
action='count', |
|
521 |
dest='verbose', |
|
522 |
default=0, |
|
523 |
help="Increase verbosity.") |
|
524 |
||
525 |
parser.add_option( |
|
526 |
'-q', '--quiet', |
|
527 |
action='count', |
|
528 |
dest='quiet', |
|
529 |
default=0, |
|
530 |
help='Decrease verbosity.') |
|
531 |
||
532 |
parser.add_option( |
|
533 |
'-p', '--python', |
|
534 |
dest='python', |
|
535 |
metavar='PYTHON_EXE', |
|
536 |
help='The Python interpreter to use, e.g., --python=python2.5 will use the python2.5 ' |
|
537 |
'interpreter to create the new environment. The default is the interpreter that ' |
|
538 |
'virtualenv was installed with (%s)' % sys.executable) |
|
539 |
||
540 |
parser.add_option( |
|
541 |
'--clear', |
|
542 |
dest='clear', |
|
543 |
action='store_true', |
|
544 |
help="Clear out the non-root install and start from scratch.") |
|
545 |
||
546 |
parser.set_defaults(system_site_packages=False) |
|
547 |
parser.add_option( |
|
548 |
'--no-site-packages', |
|
549 |
dest='system_site_packages', |
|
550 |
action='store_false', |
|
551 |
help="DEPRECATED. Retained only for backward compatibility. " |
|
552 |
"Not having access to global site-packages is now the default behavior.") |
|
553 |
||
554 |
parser.add_option( |
|
555 |
'--system-site-packages', |
|
556 |
dest='system_site_packages', |
|
557 |
action='store_true', |
|
558 |
help="Give the virtual environment access to the global site-packages.") |
|
559 |
||
560 |
parser.add_option( |
|
561 |
'--always-copy', |
|
562 |
dest='symlink', |
|
563 |
action='store_false', |
|
564 |
default=True, |
|
565 |
help="Always copy files rather than symlinking.") |
|
566 |
||
567 |
parser.add_option( |
|
568 |
'--unzip-setuptools', |
|
569 |
dest='unzip_setuptools', |
|
570 |
action='store_true', |
|
571 |
help="Unzip Setuptools when installing it.") |
|
572 |
||
573 |
parser.add_option( |
|
574 |
'--relocatable', |
|
575 |
dest='relocatable', |
|
576 |
action='store_true', |
|
577 |
help='Make an EXISTING virtualenv environment relocatable. ' |
|
578 |
'This fixes up scripts and makes all .pth files relative.') |
|
579 |
||
580 |
parser.add_option( |
|
581 |
'--no-setuptools', |
|
582 |
dest='no_setuptools', |
|
583 |
action='store_true', |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
584 |
help='Do not install setuptools in the new virtualenv.') |
3 | 585 |
|
586 |
parser.add_option( |
|
587 |
'--no-pip', |
|
588 |
dest='no_pip', |
|
589 |
action='store_true', |
|
590 |
help='Do not install pip in the new virtualenv.') |
|
591 |
||
592 |
parser.add_option( |
|
593 |
'--no-wheel', |
|
594 |
dest='no_wheel', |
|
595 |
action='store_true', |
|
596 |
help='Do not install wheel in the new virtualenv.') |
|
597 |
||
598 |
default_search_dirs = file_search_dirs() |
|
599 |
parser.add_option( |
|
600 |
'--extra-search-dir', |
|
601 |
dest="search_dirs", |
|
602 |
action="append", |
|
603 |
metavar='DIR', |
|
604 |
default=default_search_dirs, |
|
605 |
help="Directory to look for setuptools/pip distributions in. " |
|
606 |
"This option can be used multiple times.") |
|
607 |
||
608 |
parser.add_option( |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
609 |
"--download", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
610 |
dest="download", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
611 |
default=True, |
3 | 612 |
action="store_true", |
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
613 |
help="Download preinstalled packages from PyPI.", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
614 |
) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
615 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
616 |
parser.add_option( |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
617 |
"--no-download", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
618 |
'--never-download', |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
619 |
dest="download", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
620 |
action="store_false", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
621 |
help="Do not download preinstalled packages from PyPI.", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
622 |
) |
3 | 623 |
|
624 |
parser.add_option( |
|
625 |
'--prompt', |
|
626 |
dest='prompt', |
|
627 |
help='Provides an alternative prompt prefix for this environment.') |
|
628 |
||
629 |
parser.add_option( |
|
630 |
'--setuptools', |
|
631 |
dest='setuptools', |
|
632 |
action='store_true', |
|
633 |
help="DEPRECATED. Retained only for backward compatibility. This option has no effect.") |
|
634 |
||
635 |
parser.add_option( |
|
636 |
'--distribute', |
|
637 |
dest='distribute', |
|
638 |
action='store_true', |
|
639 |
help="DEPRECATED. Retained only for backward compatibility. This option has no effect.") |
|
640 |
||
641 |
if 'extend_parser' in globals(): |
|
642 |
extend_parser(parser) |
|
643 |
||
644 |
options, args = parser.parse_args() |
|
645 |
||
646 |
global logger |
|
647 |
||
648 |
if 'adjust_options' in globals(): |
|
649 |
adjust_options(options, args) |
|
650 |
||
651 |
verbosity = options.verbose - options.quiet |
|
652 |
logger = Logger([(Logger.level_for_integer(2 - verbosity), sys.stdout)]) |
|
653 |
||
654 |
if options.python and not os.environ.get('VIRTUALENV_INTERPRETER_RUNNING'): |
|
655 |
env = os.environ.copy() |
|
656 |
interpreter = resolve_interpreter(options.python) |
|
657 |
if interpreter == sys.executable: |
|
658 |
logger.warn('Already using interpreter %s' % interpreter) |
|
659 |
else: |
|
660 |
logger.notify('Running virtualenv with interpreter %s' % interpreter) |
|
661 |
env['VIRTUALENV_INTERPRETER_RUNNING'] = 'true' |
|
662 |
file = __file__ |
|
663 |
if file.endswith('.pyc'): |
|
664 |
file = file[:-1] |
|
665 |
popen = subprocess.Popen([interpreter, file] + sys.argv[1:], env=env) |
|
666 |
raise SystemExit(popen.wait()) |
|
667 |
||
668 |
if not args: |
|
669 |
print('You must provide a DEST_DIR') |
|
670 |
parser.print_help() |
|
671 |
sys.exit(2) |
|
672 |
if len(args) > 1: |
|
673 |
print('There must be only one argument: DEST_DIR (you gave %s)' % ( |
|
674 |
' '.join(args))) |
|
675 |
parser.print_help() |
|
676 |
sys.exit(2) |
|
677 |
||
678 |
home_dir = args[0] |
|
679 |
||
680 |
if os.environ.get('WORKING_ENV'): |
|
681 |
logger.fatal('ERROR: you cannot run virtualenv while in a workingenv') |
|
682 |
logger.fatal('Please deactivate your workingenv, then re-run this script') |
|
683 |
sys.exit(3) |
|
684 |
||
685 |
if 'PYTHONHOME' in os.environ: |
|
686 |
logger.warn('PYTHONHOME is set. You *must* activate the virtualenv before using it') |
|
687 |
del os.environ['PYTHONHOME'] |
|
688 |
||
689 |
if options.relocatable: |
|
690 |
make_environment_relocatable(home_dir) |
|
691 |
return |
|
692 |
||
693 |
create_environment(home_dir, |
|
694 |
site_packages=options.system_site_packages, |
|
695 |
clear=options.clear, |
|
696 |
unzip_setuptools=options.unzip_setuptools, |
|
697 |
prompt=options.prompt, |
|
698 |
search_dirs=options.search_dirs, |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
699 |
download=options.download, |
3 | 700 |
no_setuptools=options.no_setuptools, |
701 |
no_pip=options.no_pip, |
|
702 |
no_wheel=options.no_wheel, |
|
703 |
symlink=options.symlink) |
|
704 |
if 'after_install' in globals(): |
|
705 |
after_install(options, home_dir) |
|
706 |
||
707 |
def call_subprocess(cmd, show_stdout=True, |
|
708 |
filter_stdout=None, cwd=None, |
|
709 |
raise_on_returncode=True, extra_env=None, |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
710 |
remove_from_env=None, stdin=None): |
3 | 711 |
cmd_parts = [] |
712 |
for part in cmd: |
|
713 |
if len(part) > 45: |
|
714 |
part = part[:20]+"..."+part[-20:] |
|
715 |
if ' ' in part or '\n' in part or '"' in part or "'" in part: |
|
716 |
part = '"%s"' % part.replace('"', '\\"') |
|
717 |
if hasattr(part, 'decode'): |
|
718 |
try: |
|
719 |
part = part.decode(sys.getdefaultencoding()) |
|
720 |
except UnicodeDecodeError: |
|
721 |
part = part.decode(sys.getfilesystemencoding()) |
|
722 |
cmd_parts.append(part) |
|
723 |
cmd_desc = ' '.join(cmd_parts) |
|
724 |
if show_stdout: |
|
725 |
stdout = None |
|
726 |
else: |
|
727 |
stdout = subprocess.PIPE |
|
728 |
logger.debug("Running command %s" % cmd_desc) |
|
729 |
if extra_env or remove_from_env: |
|
730 |
env = os.environ.copy() |
|
731 |
if extra_env: |
|
732 |
env.update(extra_env) |
|
733 |
if remove_from_env: |
|
734 |
for varname in remove_from_env: |
|
735 |
env.pop(varname, None) |
|
736 |
else: |
|
737 |
env = None |
|
738 |
try: |
|
739 |
proc = subprocess.Popen( |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
740 |
cmd, stderr=subprocess.STDOUT, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
741 |
stdin=None if stdin is None else subprocess.PIPE, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
742 |
stdout=stdout, |
3 | 743 |
cwd=cwd, env=env) |
744 |
except Exception: |
|
745 |
e = sys.exc_info()[1] |
|
746 |
logger.fatal( |
|
747 |
"Error %s while executing command %s" % (e, cmd_desc)) |
|
748 |
raise |
|
749 |
all_output = [] |
|
750 |
if stdout is not None: |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
751 |
if stdin is not None: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
752 |
proc.stdin.write(stdin) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
753 |
proc.stdin.close() |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
754 |
|
3 | 755 |
stdout = proc.stdout |
756 |
encoding = sys.getdefaultencoding() |
|
757 |
fs_encoding = sys.getfilesystemencoding() |
|
758 |
while 1: |
|
759 |
line = stdout.readline() |
|
760 |
try: |
|
761 |
line = line.decode(encoding) |
|
762 |
except UnicodeDecodeError: |
|
763 |
line = line.decode(fs_encoding) |
|
764 |
if not line: |
|
765 |
break |
|
766 |
line = line.rstrip() |
|
767 |
all_output.append(line) |
|
768 |
if filter_stdout: |
|
769 |
level = filter_stdout(line) |
|
770 |
if isinstance(level, tuple): |
|
771 |
level, line = level |
|
772 |
logger.log(level, line) |
|
773 |
if not logger.stdout_level_matches(level): |
|
774 |
logger.show_progress() |
|
775 |
else: |
|
776 |
logger.info(line) |
|
777 |
else: |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
778 |
proc.communicate(stdin) |
3 | 779 |
proc.wait() |
780 |
if proc.returncode: |
|
781 |
if raise_on_returncode: |
|
782 |
if all_output: |
|
783 |
logger.notify('Complete output from command %s:' % cmd_desc) |
|
784 |
logger.notify('\n'.join(all_output) + '\n----------------------------------------') |
|
785 |
raise OSError( |
|
786 |
"Command %s failed with error code %s" |
|
787 |
% (cmd_desc, proc.returncode)) |
|
788 |
else: |
|
789 |
logger.warn( |
|
790 |
"Command %s had error code %s" |
|
791 |
% (cmd_desc, proc.returncode)) |
|
792 |
||
793 |
def filter_install_output(line): |
|
794 |
if line.strip().startswith('running'): |
|
795 |
return Logger.INFO |
|
796 |
return Logger.DEBUG |
|
797 |
||
798 |
def find_wheels(projects, search_dirs): |
|
799 |
"""Find wheels from which we can import PROJECTS. |
|
800 |
||
801 |
Scan through SEARCH_DIRS for a wheel for each PROJECT in turn. Return |
|
802 |
a list of the first wheel found for each PROJECT |
|
803 |
""" |
|
804 |
||
805 |
wheels = [] |
|
806 |
||
807 |
# Look through SEARCH_DIRS for the first suitable wheel. Don't bother |
|
808 |
# about version checking here, as this is simply to get something we can |
|
809 |
# then use to install the correct version. |
|
810 |
for project in projects: |
|
811 |
for dirname in search_dirs: |
|
812 |
# This relies on only having "universal" wheels available. |
|
813 |
# The pattern could be tightened to require -py2.py3-none-any.whl. |
|
814 |
files = glob.glob(os.path.join(dirname, project + '-*.whl')) |
|
815 |
if files: |
|
816 |
wheels.append(os.path.abspath(files[0])) |
|
817 |
break |
|
818 |
else: |
|
819 |
# We're out of luck, so quit with a suitable error |
|
820 |
logger.fatal('Cannot find a wheel for %s' % (project,)) |
|
821 |
||
822 |
return wheels |
|
823 |
||
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
824 |
def install_wheel(project_names, py_executable, search_dirs=None, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
825 |
download=False): |
3 | 826 |
if search_dirs is None: |
827 |
search_dirs = file_search_dirs() |
|
828 |
||
829 |
wheels = find_wheels(['setuptools', 'pip'], search_dirs) |
|
830 |
pythonpath = os.pathsep.join(wheels) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
831 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
832 |
# PIP_FIND_LINKS uses space as the path separator and thus cannot have paths |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
833 |
# with spaces in them. Convert any of those to local file:// URL form. |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
834 |
try: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
835 |
from urlparse import urljoin |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
836 |
from urllib import pathname2url |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
837 |
except ImportError: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
838 |
from urllib.parse import urljoin |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
839 |
from urllib.request import pathname2url |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
840 |
def space_path2url(p): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
841 |
if ' ' not in p: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
842 |
return p |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
843 |
return urljoin('file:', pathname2url(os.path.abspath(p))) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
844 |
findlinks = ' '.join(space_path2url(d) for d in search_dirs) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
845 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
846 |
SCRIPT = textwrap.dedent(""" |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
847 |
import sys |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
848 |
import pkgutil |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
849 |
import tempfile |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
850 |
import os |
3 | 851 |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
852 |
import pip |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
853 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
854 |
cert_data = pkgutil.get_data("pip._vendor.requests", "cacert.pem") |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
855 |
if cert_data is not None: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
856 |
cert_file = tempfile.NamedTemporaryFile(delete=False) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
857 |
cert_file.write(cert_data) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
858 |
cert_file.close() |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
859 |
else: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
860 |
cert_file = None |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
861 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
862 |
try: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
863 |
args = ["install", "--ignore-installed"] |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
864 |
if cert_file is not None: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
865 |
args += ["--cert", cert_file.name] |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
866 |
args += sys.argv[1:] |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
867 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
868 |
sys.exit(pip.main(args)) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
869 |
finally: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
870 |
if cert_file is not None: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
871 |
os.remove(cert_file.name) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
872 |
""").encode("utf8") |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
873 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
874 |
cmd = [py_executable, '-'] + project_names |
3 | 875 |
logger.start_progress('Installing %s...' % (', '.join(project_names))) |
876 |
logger.indent += 2 |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
877 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
878 |
env = { |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
879 |
"PYTHONPATH": pythonpath, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
880 |
"JYTHONPATH": pythonpath, # for Jython < 3.x |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
881 |
"PIP_FIND_LINKS": findlinks, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
882 |
"PIP_USE_WHEEL": "1", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
883 |
"PIP_ONLY_BINARY": ":all:", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
884 |
"PIP_PRE": "1", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
885 |
"PIP_USER": "0", |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
886 |
} |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
887 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
888 |
if not download: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
889 |
env["PIP_NO_INDEX"] = "1" |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
890 |
|
3 | 891 |
try: |
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
892 |
call_subprocess(cmd, show_stdout=False, extra_env=env, stdin=SCRIPT) |
3 | 893 |
finally: |
894 |
logger.indent -= 2 |
|
895 |
logger.end_progress() |
|
896 |
||
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
897 |
|
3 | 898 |
def create_environment(home_dir, site_packages=False, clear=False, |
899 |
unzip_setuptools=False, |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
900 |
prompt=None, search_dirs=None, download=False, |
3 | 901 |
no_setuptools=False, no_pip=False, no_wheel=False, |
902 |
symlink=True): |
|
903 |
""" |
|
904 |
Creates a new environment in ``home_dir``. |
|
905 |
||
906 |
If ``site_packages`` is true, then the global ``site-packages/`` |
|
907 |
directory will be on the path. |
|
908 |
||
909 |
If ``clear`` is true (default False) then the environment will |
|
910 |
first be cleared. |
|
911 |
""" |
|
912 |
home_dir, lib_dir, inc_dir, bin_dir = path_locations(home_dir) |
|
913 |
||
914 |
py_executable = os.path.abspath(install_python( |
|
915 |
home_dir, lib_dir, inc_dir, bin_dir, |
|
916 |
site_packages=site_packages, clear=clear, symlink=symlink)) |
|
917 |
||
918 |
install_distutils(home_dir) |
|
919 |
||
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
920 |
to_install = [] |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
921 |
|
3 | 922 |
if not no_setuptools: |
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
923 |
to_install.append('setuptools') |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
924 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
925 |
if not no_pip: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
926 |
to_install.append('pip') |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
927 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
928 |
if not no_wheel: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
929 |
to_install.append('wheel') |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
930 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
931 |
if to_install: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
932 |
install_wheel( |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
933 |
to_install, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
934 |
py_executable, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
935 |
search_dirs, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
936 |
download=download, |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
937 |
) |
3 | 938 |
|
939 |
install_activate(home_dir, bin_dir, prompt) |
|
940 |
||
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
941 |
install_python_config(home_dir, bin_dir, prompt) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
942 |
|
3 | 943 |
def is_executable_file(fpath): |
944 |
return os.path.isfile(fpath) and os.access(fpath, os.X_OK) |
|
945 |
||
946 |
def path_locations(home_dir): |
|
947 |
"""Return the path locations for the environment (where libraries are, |
|
948 |
where scripts go, etc)""" |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
949 |
home_dir = os.path.abspath(home_dir) |
3 | 950 |
# XXX: We'd use distutils.sysconfig.get_python_inc/lib but its |
951 |
# prefix arg is broken: http://bugs.python.org/issue3386 |
|
952 |
if is_win: |
|
953 |
# Windows has lots of problems with executables with spaces in |
|
954 |
# the name; this function will remove them (using the ~1 |
|
955 |
# format): |
|
956 |
mkdir(home_dir) |
|
957 |
if ' ' in home_dir: |
|
958 |
import ctypes |
|
959 |
GetShortPathName = ctypes.windll.kernel32.GetShortPathNameW |
|
960 |
size = max(len(home_dir)+1, 256) |
|
961 |
buf = ctypes.create_unicode_buffer(size) |
|
962 |
try: |
|
963 |
u = unicode |
|
964 |
except NameError: |
|
965 |
u = str |
|
966 |
ret = GetShortPathName(u(home_dir), buf, size) |
|
967 |
if not ret: |
|
968 |
print('Error: the path "%s" has a space in it' % home_dir) |
|
969 |
print('We could not determine the short pathname for it.') |
|
970 |
print('Exiting.') |
|
971 |
sys.exit(3) |
|
972 |
home_dir = str(buf.value) |
|
973 |
lib_dir = join(home_dir, 'Lib') |
|
974 |
inc_dir = join(home_dir, 'Include') |
|
975 |
bin_dir = join(home_dir, 'Scripts') |
|
976 |
if is_jython: |
|
977 |
lib_dir = join(home_dir, 'Lib') |
|
978 |
inc_dir = join(home_dir, 'Include') |
|
979 |
bin_dir = join(home_dir, 'bin') |
|
980 |
elif is_pypy: |
|
981 |
lib_dir = home_dir |
|
982 |
inc_dir = join(home_dir, 'include') |
|
983 |
bin_dir = join(home_dir, 'bin') |
|
984 |
elif not is_win: |
|
985 |
lib_dir = join(home_dir, 'lib', py_version) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
986 |
inc_dir = join(home_dir, 'include', py_version + abiflags) |
3 | 987 |
bin_dir = join(home_dir, 'bin') |
988 |
return home_dir, lib_dir, inc_dir, bin_dir |
|
989 |
||
990 |
||
991 |
def change_prefix(filename, dst_prefix): |
|
992 |
prefixes = [sys.prefix] |
|
993 |
||
994 |
if is_darwin: |
|
995 |
prefixes.extend(( |
|
996 |
os.path.join("/Library/Python", sys.version[:3], "site-packages"), |
|
997 |
os.path.join(sys.prefix, "Extras", "lib", "python"), |
|
998 |
os.path.join("~", "Library", "Python", sys.version[:3], "site-packages"), |
|
999 |
# Python 2.6 no-frameworks |
|
1000 |
os.path.join("~", ".local", "lib","python", sys.version[:3], "site-packages"), |
|
1001 |
# System Python 2.7 on OSX Mountain Lion |
|
1002 |
os.path.join("~", "Library", "Python", sys.version[:3], "lib", "python", "site-packages"))) |
|
1003 |
||
1004 |
if hasattr(sys, 'real_prefix'): |
|
1005 |
prefixes.append(sys.real_prefix) |
|
1006 |
if hasattr(sys, 'base_prefix'): |
|
1007 |
prefixes.append(sys.base_prefix) |
|
1008 |
prefixes = list(map(os.path.expanduser, prefixes)) |
|
1009 |
prefixes = list(map(os.path.abspath, prefixes)) |
|
1010 |
# Check longer prefixes first so we don't split in the middle of a filename |
|
1011 |
prefixes = sorted(prefixes, key=len, reverse=True) |
|
1012 |
filename = os.path.abspath(filename) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1013 |
# On Windows, make sure drive letter is uppercase |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1014 |
if is_win and filename[0] in 'abcdefghijklmnopqrstuvwxyz': |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1015 |
filename = filename[0].upper() + filename[1:] |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1016 |
for i, prefix in enumerate(prefixes): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1017 |
if is_win and prefix[0] in 'abcdefghijklmnopqrstuvwxyz': |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1018 |
prefixes[i] = prefix[0].upper() + prefix[1:] |
3 | 1019 |
for src_prefix in prefixes: |
1020 |
if filename.startswith(src_prefix): |
|
1021 |
_, relpath = filename.split(src_prefix, 1) |
|
1022 |
if src_prefix != os.sep: # sys.prefix == "/" |
|
1023 |
assert relpath[0] == os.sep |
|
1024 |
relpath = relpath[1:] |
|
1025 |
return join(dst_prefix, relpath) |
|
1026 |
assert False, "Filename %s does not start with any of these prefixes: %s" % \ |
|
1027 |
(filename, prefixes) |
|
1028 |
||
1029 |
def copy_required_modules(dst_prefix, symlink): |
|
1030 |
import imp |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1031 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1032 |
for modname in REQUIRED_MODULES: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1033 |
if modname in sys.builtin_module_names: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1034 |
logger.info("Ignoring built-in bootstrap module: %s" % modname) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1035 |
continue |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1036 |
try: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1037 |
f, filename, _ = imp.find_module(modname) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1038 |
except ImportError: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1039 |
logger.info("Cannot import bootstrap module: %s" % modname) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1040 |
else: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1041 |
if f is not None: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1042 |
f.close() |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1043 |
# special-case custom readline.so on OS X, but not for pypy: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1044 |
if modname == 'readline' and sys.platform == 'darwin' and not ( |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1045 |
is_pypy or filename.endswith(join('lib-dynload', 'readline.so'))): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1046 |
dst_filename = join(dst_prefix, 'lib', 'python%s' % sys.version[:3], 'readline.so') |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1047 |
elif modname == 'readline' and sys.platform == 'win32': |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1048 |
# special-case for Windows, where readline is not a |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1049 |
# standard module, though it may have been installed in |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1050 |
# site-packages by a third-party package |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1051 |
pass |
3 | 1052 |
else: |
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1053 |
dst_filename = change_prefix(filename, dst_prefix) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1054 |
copyfile(filename, dst_filename, symlink) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1055 |
if filename.endswith('.pyc'): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1056 |
pyfile = filename[:-1] |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1057 |
if os.path.exists(pyfile): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1058 |
copyfile(pyfile, dst_filename[:-1], symlink) |
3 | 1059 |
|
1060 |
||
1061 |
def subst_path(prefix_path, prefix, home_dir): |
|
1062 |
prefix_path = os.path.normpath(prefix_path) |
|
1063 |
prefix = os.path.normpath(prefix) |
|
1064 |
home_dir = os.path.normpath(home_dir) |
|
1065 |
if not prefix_path.startswith(prefix): |
|
1066 |
logger.warn('Path not in prefix %r %r', prefix_path, prefix) |
|
1067 |
return |
|
1068 |
return prefix_path.replace(prefix, home_dir, 1) |
|
1069 |
||
1070 |
||
1071 |
def install_python(home_dir, lib_dir, inc_dir, bin_dir, site_packages, clear, symlink=True): |
|
1072 |
"""Install just the base environment, no distutils patches etc""" |
|
1073 |
if sys.executable.startswith(bin_dir): |
|
1074 |
print('Please use the *system* python to run this script') |
|
1075 |
return |
|
1076 |
||
1077 |
if clear: |
|
1078 |
rmtree(lib_dir) |
|
1079 |
## FIXME: why not delete it? |
|
1080 |
## Maybe it should delete everything with #!/path/to/venv/python in it |
|
1081 |
logger.notify('Not deleting %s', bin_dir) |
|
1082 |
||
1083 |
if hasattr(sys, 'real_prefix'): |
|
1084 |
logger.notify('Using real prefix %r' % sys.real_prefix) |
|
1085 |
prefix = sys.real_prefix |
|
1086 |
elif hasattr(sys, 'base_prefix'): |
|
1087 |
logger.notify('Using base prefix %r' % sys.base_prefix) |
|
1088 |
prefix = sys.base_prefix |
|
1089 |
else: |
|
1090 |
prefix = sys.prefix |
|
1091 |
mkdir(lib_dir) |
|
1092 |
fix_lib64(lib_dir, symlink) |
|
1093 |
stdlib_dirs = [os.path.dirname(os.__file__)] |
|
1094 |
if is_win: |
|
1095 |
stdlib_dirs.append(join(os.path.dirname(stdlib_dirs[0]), 'DLLs')) |
|
1096 |
elif is_darwin: |
|
1097 |
stdlib_dirs.append(join(stdlib_dirs[0], 'site-packages')) |
|
1098 |
if hasattr(os, 'symlink'): |
|
1099 |
logger.info('Symlinking Python bootstrap modules') |
|
1100 |
else: |
|
1101 |
logger.info('Copying Python bootstrap modules') |
|
1102 |
logger.indent += 2 |
|
1103 |
try: |
|
1104 |
# copy required files... |
|
1105 |
for stdlib_dir in stdlib_dirs: |
|
1106 |
if not os.path.isdir(stdlib_dir): |
|
1107 |
continue |
|
1108 |
for fn in os.listdir(stdlib_dir): |
|
1109 |
bn = os.path.splitext(fn)[0] |
|
1110 |
if fn != 'site-packages' and bn in REQUIRED_FILES: |
|
1111 |
copyfile(join(stdlib_dir, fn), join(lib_dir, fn), symlink) |
|
1112 |
# ...and modules |
|
1113 |
copy_required_modules(home_dir, symlink) |
|
1114 |
finally: |
|
1115 |
logger.indent -= 2 |
|
1116 |
mkdir(join(lib_dir, 'site-packages')) |
|
1117 |
import site |
|
1118 |
site_filename = site.__file__ |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1119 |
if site_filename.endswith('.pyc') or site_filename.endswith('.pyo'): |
3 | 1120 |
site_filename = site_filename[:-1] |
1121 |
elif site_filename.endswith('$py.class'): |
|
1122 |
site_filename = site_filename.replace('$py.class', '.py') |
|
1123 |
site_filename_dst = change_prefix(site_filename, home_dir) |
|
1124 |
site_dir = os.path.dirname(site_filename_dst) |
|
1125 |
writefile(site_filename_dst, SITE_PY) |
|
1126 |
writefile(join(site_dir, 'orig-prefix.txt'), prefix) |
|
1127 |
site_packages_filename = join(site_dir, 'no-global-site-packages.txt') |
|
1128 |
if not site_packages: |
|
1129 |
writefile(site_packages_filename, '') |
|
1130 |
||
1131 |
if is_pypy or is_win: |
|
1132 |
stdinc_dir = join(prefix, 'include') |
|
1133 |
else: |
|
1134 |
stdinc_dir = join(prefix, 'include', py_version + abiflags) |
|
1135 |
if os.path.exists(stdinc_dir): |
|
1136 |
copyfile(stdinc_dir, inc_dir, symlink) |
|
1137 |
else: |
|
1138 |
logger.debug('No include dir %s' % stdinc_dir) |
|
1139 |
||
1140 |
platinc_dir = distutils.sysconfig.get_python_inc(plat_specific=1) |
|
1141 |
if platinc_dir != stdinc_dir: |
|
1142 |
platinc_dest = distutils.sysconfig.get_python_inc( |
|
1143 |
plat_specific=1, prefix=home_dir) |
|
1144 |
if platinc_dir == platinc_dest: |
|
1145 |
# Do platinc_dest manually due to a CPython bug; |
|
1146 |
# not http://bugs.python.org/issue3386 but a close cousin |
|
1147 |
platinc_dest = subst_path(platinc_dir, prefix, home_dir) |
|
1148 |
if platinc_dest: |
|
1149 |
# PyPy's stdinc_dir and prefix are relative to the original binary |
|
1150 |
# (traversing virtualenvs), whereas the platinc_dir is relative to |
|
1151 |
# the inner virtualenv and ignores the prefix argument. |
|
1152 |
# This seems more evolved than designed. |
|
1153 |
copyfile(platinc_dir, platinc_dest, symlink) |
|
1154 |
||
1155 |
# pypy never uses exec_prefix, just ignore it |
|
1156 |
if sys.exec_prefix != prefix and not is_pypy: |
|
1157 |
if is_win: |
|
1158 |
exec_dir = join(sys.exec_prefix, 'lib') |
|
1159 |
elif is_jython: |
|
1160 |
exec_dir = join(sys.exec_prefix, 'Lib') |
|
1161 |
else: |
|
1162 |
exec_dir = join(sys.exec_prefix, 'lib', py_version) |
|
1163 |
for fn in os.listdir(exec_dir): |
|
1164 |
copyfile(join(exec_dir, fn), join(lib_dir, fn), symlink) |
|
1165 |
||
1166 |
if is_jython: |
|
1167 |
# Jython has either jython-dev.jar and javalib/ dir, or just |
|
1168 |
# jython.jar |
|
1169 |
for name in 'jython-dev.jar', 'javalib', 'jython.jar': |
|
1170 |
src = join(prefix, name) |
|
1171 |
if os.path.exists(src): |
|
1172 |
copyfile(src, join(home_dir, name), symlink) |
|
1173 |
# XXX: registry should always exist after Jython 2.5rc1 |
|
1174 |
src = join(prefix, 'registry') |
|
1175 |
if os.path.exists(src): |
|
1176 |
copyfile(src, join(home_dir, 'registry'), symlink=False) |
|
1177 |
copyfile(join(prefix, 'cachedir'), join(home_dir, 'cachedir'), |
|
1178 |
symlink=False) |
|
1179 |
||
1180 |
mkdir(bin_dir) |
|
1181 |
py_executable = join(bin_dir, os.path.basename(sys.executable)) |
|
1182 |
if 'Python.framework' in prefix: |
|
1183 |
# OS X framework builds cause validation to break |
|
1184 |
# https://github.com/pypa/virtualenv/issues/322 |
|
1185 |
if os.environ.get('__PYVENV_LAUNCHER__'): |
|
1186 |
del os.environ["__PYVENV_LAUNCHER__"] |
|
1187 |
if re.search(r'/Python(?:-32|-64)*$', py_executable): |
|
1188 |
# The name of the python executable is not quite what |
|
1189 |
# we want, rename it. |
|
1190 |
py_executable = os.path.join( |
|
1191 |
os.path.dirname(py_executable), 'python') |
|
1192 |
||
1193 |
logger.notify('New %s executable in %s', expected_exe, py_executable) |
|
1194 |
pcbuild_dir = os.path.dirname(sys.executable) |
|
1195 |
pyd_pth = os.path.join(lib_dir, 'site-packages', 'virtualenv_builddir_pyd.pth') |
|
1196 |
if is_win and os.path.exists(os.path.join(pcbuild_dir, 'build.bat')): |
|
1197 |
logger.notify('Detected python running from build directory %s', pcbuild_dir) |
|
1198 |
logger.notify('Writing .pth file linking to build directory for *.pyd files') |
|
1199 |
writefile(pyd_pth, pcbuild_dir) |
|
1200 |
else: |
|
1201 |
pcbuild_dir = None |
|
1202 |
if os.path.exists(pyd_pth): |
|
1203 |
logger.info('Deleting %s (not Windows env or not build directory python)' % pyd_pth) |
|
1204 |
os.unlink(pyd_pth) |
|
1205 |
||
1206 |
if sys.executable != py_executable: |
|
1207 |
## FIXME: could I just hard link? |
|
1208 |
executable = sys.executable |
|
1209 |
shutil.copyfile(executable, py_executable) |
|
1210 |
make_exe(py_executable) |
|
1211 |
if is_win or is_cygwin: |
|
1212 |
pythonw = os.path.join(os.path.dirname(sys.executable), 'pythonw.exe') |
|
1213 |
if os.path.exists(pythonw): |
|
1214 |
logger.info('Also created pythonw.exe') |
|
1215 |
shutil.copyfile(pythonw, os.path.join(os.path.dirname(py_executable), 'pythonw.exe')) |
|
1216 |
python_d = os.path.join(os.path.dirname(sys.executable), 'python_d.exe') |
|
1217 |
python_d_dest = os.path.join(os.path.dirname(py_executable), 'python_d.exe') |
|
1218 |
if os.path.exists(python_d): |
|
1219 |
logger.info('Also created python_d.exe') |
|
1220 |
shutil.copyfile(python_d, python_d_dest) |
|
1221 |
elif os.path.exists(python_d_dest): |
|
1222 |
logger.info('Removed python_d.exe as it is no longer at the source') |
|
1223 |
os.unlink(python_d_dest) |
|
1224 |
# we need to copy the DLL to enforce that windows will load the correct one. |
|
1225 |
# may not exist if we are cygwin. |
|
1226 |
py_executable_dll = 'python%s%s.dll' % ( |
|
1227 |
sys.version_info[0], sys.version_info[1]) |
|
1228 |
py_executable_dll_d = 'python%s%s_d.dll' % ( |
|
1229 |
sys.version_info[0], sys.version_info[1]) |
|
1230 |
pythondll = os.path.join(os.path.dirname(sys.executable), py_executable_dll) |
|
1231 |
pythondll_d = os.path.join(os.path.dirname(sys.executable), py_executable_dll_d) |
|
1232 |
pythondll_d_dest = os.path.join(os.path.dirname(py_executable), py_executable_dll_d) |
|
1233 |
if os.path.exists(pythondll): |
|
1234 |
logger.info('Also created %s' % py_executable_dll) |
|
1235 |
shutil.copyfile(pythondll, os.path.join(os.path.dirname(py_executable), py_executable_dll)) |
|
1236 |
if os.path.exists(pythondll_d): |
|
1237 |
logger.info('Also created %s' % py_executable_dll_d) |
|
1238 |
shutil.copyfile(pythondll_d, pythondll_d_dest) |
|
1239 |
elif os.path.exists(pythondll_d_dest): |
|
1240 |
logger.info('Removed %s as the source does not exist' % pythondll_d_dest) |
|
1241 |
os.unlink(pythondll_d_dest) |
|
1242 |
if is_pypy: |
|
1243 |
# make a symlink python --> pypy-c |
|
1244 |
python_executable = os.path.join(os.path.dirname(py_executable), 'python') |
|
1245 |
if sys.platform in ('win32', 'cygwin'): |
|
1246 |
python_executable += '.exe' |
|
1247 |
logger.info('Also created executable %s' % python_executable) |
|
1248 |
copyfile(py_executable, python_executable, symlink) |
|
1249 |
||
1250 |
if is_win: |
|
1251 |
for name in ['libexpat.dll', 'libpypy.dll', 'libpypy-c.dll', |
|
1252 |
'libeay32.dll', 'ssleay32.dll', 'sqlite3.dll', |
|
1253 |
'tcl85.dll', 'tk85.dll']: |
|
1254 |
src = join(prefix, name) |
|
1255 |
if os.path.exists(src): |
|
1256 |
copyfile(src, join(bin_dir, name), symlink) |
|
1257 |
||
1258 |
for d in sys.path: |
|
1259 |
if d.endswith('lib_pypy'): |
|
1260 |
break |
|
1261 |
else: |
|
1262 |
logger.fatal('Could not find lib_pypy in sys.path') |
|
1263 |
raise SystemExit(3) |
|
1264 |
logger.info('Copying lib_pypy') |
|
1265 |
copyfile(d, os.path.join(home_dir, 'lib_pypy'), symlink) |
|
1266 |
||
1267 |
if os.path.splitext(os.path.basename(py_executable))[0] != expected_exe: |
|
1268 |
secondary_exe = os.path.join(os.path.dirname(py_executable), |
|
1269 |
expected_exe) |
|
1270 |
py_executable_ext = os.path.splitext(py_executable)[1] |
|
1271 |
if py_executable_ext.lower() == '.exe': |
|
1272 |
# python2.4 gives an extension of '.4' :P |
|
1273 |
secondary_exe += py_executable_ext |
|
1274 |
if os.path.exists(secondary_exe): |
|
1275 |
logger.warn('Not overwriting existing %s script %s (you must use %s)' |
|
1276 |
% (expected_exe, secondary_exe, py_executable)) |
|
1277 |
else: |
|
1278 |
logger.notify('Also creating executable in %s' % secondary_exe) |
|
1279 |
shutil.copyfile(sys.executable, secondary_exe) |
|
1280 |
make_exe(secondary_exe) |
|
1281 |
||
1282 |
if '.framework' in prefix: |
|
1283 |
if 'Python.framework' in prefix: |
|
1284 |
logger.debug('MacOSX Python framework detected') |
|
1285 |
# Make sure we use the embedded interpreter inside |
|
1286 |
# the framework, even if sys.executable points to |
|
1287 |
# the stub executable in ${sys.prefix}/bin |
|
1288 |
# See http://groups.google.com/group/python-virtualenv/ |
|
1289 |
# browse_thread/thread/17cab2f85da75951 |
|
1290 |
original_python = os.path.join( |
|
1291 |
prefix, 'Resources/Python.app/Contents/MacOS/Python') |
|
1292 |
if 'EPD' in prefix: |
|
1293 |
logger.debug('EPD framework detected') |
|
1294 |
original_python = os.path.join(prefix, 'bin/python') |
|
1295 |
shutil.copy(original_python, py_executable) |
|
1296 |
||
1297 |
# Copy the framework's dylib into the virtual |
|
1298 |
# environment |
|
1299 |
virtual_lib = os.path.join(home_dir, '.Python') |
|
1300 |
||
1301 |
if os.path.exists(virtual_lib): |
|
1302 |
os.unlink(virtual_lib) |
|
1303 |
copyfile( |
|
1304 |
os.path.join(prefix, 'Python'), |
|
1305 |
virtual_lib, |
|
1306 |
symlink) |
|
1307 |
||
1308 |
# And then change the install_name of the copied python executable |
|
1309 |
try: |
|
1310 |
mach_o_change(py_executable, |
|
1311 |
os.path.join(prefix, 'Python'), |
|
1312 |
'@executable_path/../.Python') |
|
1313 |
except: |
|
1314 |
e = sys.exc_info()[1] |
|
1315 |
logger.warn("Could not call mach_o_change: %s. " |
|
1316 |
"Trying to call install_name_tool instead." % e) |
|
1317 |
try: |
|
1318 |
call_subprocess( |
|
1319 |
["install_name_tool", "-change", |
|
1320 |
os.path.join(prefix, 'Python'), |
|
1321 |
'@executable_path/../.Python', |
|
1322 |
py_executable]) |
|
1323 |
except: |
|
1324 |
logger.fatal("Could not call install_name_tool -- you must " |
|
1325 |
"have Apple's development tools installed") |
|
1326 |
raise |
|
1327 |
||
1328 |
if not is_win: |
|
1329 |
# Ensure that 'python', 'pythonX' and 'pythonX.Y' all exist |
|
1330 |
py_exe_version_major = 'python%s' % sys.version_info[0] |
|
1331 |
py_exe_version_major_minor = 'python%s.%s' % ( |
|
1332 |
sys.version_info[0], sys.version_info[1]) |
|
1333 |
py_exe_no_version = 'python' |
|
1334 |
required_symlinks = [ py_exe_no_version, py_exe_version_major, |
|
1335 |
py_exe_version_major_minor ] |
|
1336 |
||
1337 |
py_executable_base = os.path.basename(py_executable) |
|
1338 |
||
1339 |
if py_executable_base in required_symlinks: |
|
1340 |
# Don't try to symlink to yourself. |
|
1341 |
required_symlinks.remove(py_executable_base) |
|
1342 |
||
1343 |
for pth in required_symlinks: |
|
1344 |
full_pth = join(bin_dir, pth) |
|
1345 |
if os.path.exists(full_pth): |
|
1346 |
os.unlink(full_pth) |
|
1347 |
if symlink: |
|
1348 |
os.symlink(py_executable_base, full_pth) |
|
1349 |
else: |
|
1350 |
copyfile(py_executable, full_pth, symlink) |
|
1351 |
||
1352 |
if is_win and ' ' in py_executable: |
|
1353 |
# There's a bug with subprocess on Windows when using a first |
|
1354 |
# argument that has a space in it. Instead we have to quote |
|
1355 |
# the value: |
|
1356 |
py_executable = '"%s"' % py_executable |
|
1357 |
# NOTE: keep this check as one line, cmd.exe doesn't cope with line breaks |
|
1358 |
cmd = [py_executable, '-c', 'import sys;out=sys.stdout;' |
|
1359 |
'getattr(out, "buffer", out).write(sys.prefix.encode("utf-8"))'] |
|
1360 |
logger.info('Testing executable with %s %s "%s"' % tuple(cmd)) |
|
1361 |
try: |
|
1362 |
proc = subprocess.Popen(cmd, |
|
1363 |
stdout=subprocess.PIPE) |
|
1364 |
proc_stdout, proc_stderr = proc.communicate() |
|
1365 |
except OSError: |
|
1366 |
e = sys.exc_info()[1] |
|
1367 |
if e.errno == errno.EACCES: |
|
1368 |
logger.fatal('ERROR: The executable %s could not be run: %s' % (py_executable, e)) |
|
1369 |
sys.exit(100) |
|
1370 |
else: |
|
1371 |
raise e |
|
1372 |
||
1373 |
proc_stdout = proc_stdout.strip().decode("utf-8") |
|
1374 |
proc_stdout = os.path.normcase(os.path.abspath(proc_stdout)) |
|
1375 |
norm_home_dir = os.path.normcase(os.path.abspath(home_dir)) |
|
1376 |
if hasattr(norm_home_dir, 'decode'): |
|
1377 |
norm_home_dir = norm_home_dir.decode(sys.getfilesystemencoding()) |
|
1378 |
if proc_stdout != norm_home_dir: |
|
1379 |
logger.fatal( |
|
1380 |
'ERROR: The executable %s is not functioning' % py_executable) |
|
1381 |
logger.fatal( |
|
1382 |
'ERROR: It thinks sys.prefix is %r (should be %r)' |
|
1383 |
% (proc_stdout, norm_home_dir)) |
|
1384 |
logger.fatal( |
|
1385 |
'ERROR: virtualenv is not compatible with this system or executable') |
|
1386 |
if is_win: |
|
1387 |
logger.fatal( |
|
1388 |
'Note: some Windows users have reported this error when they ' |
|
1389 |
'installed Python for "Only this user" or have multiple ' |
|
1390 |
'versions of Python installed. Copying the appropriate ' |
|
1391 |
'PythonXX.dll to the virtualenv Scripts/ directory may fix ' |
|
1392 |
'this problem.') |
|
1393 |
sys.exit(100) |
|
1394 |
else: |
|
1395 |
logger.info('Got sys.prefix result: %r' % proc_stdout) |
|
1396 |
||
1397 |
pydistutils = os.path.expanduser('~/.pydistutils.cfg') |
|
1398 |
if os.path.exists(pydistutils): |
|
1399 |
logger.notify('Please make sure you remove any previous custom paths from ' |
|
1400 |
'your %s file.' % pydistutils) |
|
1401 |
## FIXME: really this should be calculated earlier |
|
1402 |
||
1403 |
fix_local_scheme(home_dir, symlink) |
|
1404 |
||
1405 |
if site_packages: |
|
1406 |
if os.path.exists(site_packages_filename): |
|
1407 |
logger.info('Deleting %s' % site_packages_filename) |
|
1408 |
os.unlink(site_packages_filename) |
|
1409 |
||
1410 |
return py_executable |
|
1411 |
||
1412 |
||
1413 |
def install_activate(home_dir, bin_dir, prompt=None): |
|
1414 |
if is_win or is_jython and os._name == 'nt': |
|
1415 |
files = { |
|
1416 |
'activate.bat': ACTIVATE_BAT, |
|
1417 |
'deactivate.bat': DEACTIVATE_BAT, |
|
1418 |
'activate.ps1': ACTIVATE_PS, |
|
1419 |
} |
|
1420 |
||
1421 |
# MSYS needs paths of the form /c/path/to/file |
|
1422 |
drive, tail = os.path.splitdrive(home_dir.replace(os.sep, '/')) |
|
1423 |
home_dir_msys = (drive and "/%s%s" or "%s%s") % (drive[:1], tail) |
|
1424 |
||
1425 |
# Run-time conditional enables (basic) Cygwin compatibility |
|
1426 |
home_dir_sh = ("""$(if [ "$OSTYPE" "==" "cygwin" ]; then cygpath -u '%s'; else echo '%s'; fi;)""" % |
|
1427 |
(home_dir, home_dir_msys)) |
|
1428 |
files['activate'] = ACTIVATE_SH.replace('__VIRTUAL_ENV__', home_dir_sh) |
|
1429 |
||
1430 |
else: |
|
1431 |
files = {'activate': ACTIVATE_SH} |
|
1432 |
||
1433 |
# suppling activate.fish in addition to, not instead of, the |
|
1434 |
# bash script support. |
|
1435 |
files['activate.fish'] = ACTIVATE_FISH |
|
1436 |
||
1437 |
# same for csh/tcsh support... |
|
1438 |
files['activate.csh'] = ACTIVATE_CSH |
|
1439 |
||
1440 |
files['activate_this.py'] = ACTIVATE_THIS |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1441 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1442 |
install_files(home_dir, bin_dir, prompt, files) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1443 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1444 |
def install_files(home_dir, bin_dir, prompt, files): |
3 | 1445 |
if hasattr(home_dir, 'decode'): |
1446 |
home_dir = home_dir.decode(sys.getfilesystemencoding()) |
|
1447 |
vname = os.path.basename(home_dir) |
|
1448 |
for name, content in files.items(): |
|
1449 |
content = content.replace('__VIRTUAL_PROMPT__', prompt or '') |
|
1450 |
content = content.replace('__VIRTUAL_WINPROMPT__', prompt or '(%s)' % vname) |
|
1451 |
content = content.replace('__VIRTUAL_ENV__', home_dir) |
|
1452 |
content = content.replace('__VIRTUAL_NAME__', vname) |
|
1453 |
content = content.replace('__BIN_NAME__', os.path.basename(bin_dir)) |
|
1454 |
writefile(os.path.join(bin_dir, name), content) |
|
1455 |
||
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1456 |
def install_python_config(home_dir, bin_dir, prompt=None): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1457 |
if sys.platform == 'win32' or is_jython and os._name == 'nt': |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1458 |
files = {} |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1459 |
else: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1460 |
files = {'python-config': PYTHON_CONFIG} |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1461 |
install_files(home_dir, bin_dir, prompt, files) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1462 |
for name, content in files.items(): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1463 |
make_exe(os.path.join(bin_dir, name)) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1464 |
|
3 | 1465 |
def install_distutils(home_dir): |
1466 |
distutils_path = change_prefix(distutils.__path__[0], home_dir) |
|
1467 |
mkdir(distutils_path) |
|
1468 |
## FIXME: maybe this prefix setting should only be put in place if |
|
1469 |
## there's a local distutils.cfg with a prefix setting? |
|
1470 |
home_dir = os.path.abspath(home_dir) |
|
1471 |
## FIXME: this is breaking things, removing for now: |
|
1472 |
#distutils_cfg = DISTUTILS_CFG + "\n[install]\nprefix=%s\n" % home_dir |
|
1473 |
writefile(os.path.join(distutils_path, '__init__.py'), DISTUTILS_INIT) |
|
1474 |
writefile(os.path.join(distutils_path, 'distutils.cfg'), DISTUTILS_CFG, overwrite=False) |
|
1475 |
||
1476 |
def fix_local_scheme(home_dir, symlink=True): |
|
1477 |
""" |
|
1478 |
Platforms that use the "posix_local" install scheme (like Ubuntu with |
|
1479 |
Python 2.7) need to be given an additional "local" location, sigh. |
|
1480 |
""" |
|
1481 |
try: |
|
1482 |
import sysconfig |
|
1483 |
except ImportError: |
|
1484 |
pass |
|
1485 |
else: |
|
1486 |
if sysconfig._get_default_scheme() == 'posix_local': |
|
1487 |
local_path = os.path.join(home_dir, 'local') |
|
1488 |
if not os.path.exists(local_path): |
|
1489 |
os.mkdir(local_path) |
|
1490 |
for subdir_name in os.listdir(home_dir): |
|
1491 |
if subdir_name == 'local': |
|
1492 |
continue |
|
1493 |
copyfile(os.path.abspath(os.path.join(home_dir, subdir_name)), \ |
|
1494 |
os.path.join(local_path, subdir_name), symlink) |
|
1495 |
||
1496 |
def fix_lib64(lib_dir, symlink=True): |
|
1497 |
""" |
|
1498 |
Some platforms (particularly Gentoo on x64) put things in lib64/pythonX.Y |
|
1499 |
instead of lib/pythonX.Y. If this is such a platform we'll just create a |
|
1500 |
symlink so lib64 points to lib |
|
1501 |
""" |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1502 |
# PyPy's library path scheme is not affected by this. |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1503 |
# Return early or we will die on the following assert. |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1504 |
if is_pypy: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1505 |
logger.debug('PyPy detected, skipping lib64 symlinking') |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1506 |
return |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1507 |
# Check we have a lib64 library path |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1508 |
if not [p for p in distutils.sysconfig.get_config_vars().values() |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1509 |
if isinstance(p, basestring) and 'lib64' in p]: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1510 |
return |
3 | 1511 |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1512 |
logger.debug('This system uses lib64; symlinking lib64 to lib') |
3 | 1513 |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1514 |
assert os.path.basename(lib_dir) == 'python%s' % sys.version[:3], ( |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1515 |
"Unexpected python lib dir: %r" % lib_dir) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1516 |
lib_parent = os.path.dirname(lib_dir) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1517 |
top_level = os.path.dirname(lib_parent) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1518 |
lib_dir = os.path.join(top_level, 'lib') |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1519 |
lib64_link = os.path.join(top_level, 'lib64') |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1520 |
assert os.path.basename(lib_parent) == 'lib', ( |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1521 |
"Unexpected parent dir: %r" % lib_parent) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1522 |
if os.path.lexists(lib64_link): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1523 |
return |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1524 |
if symlink: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1525 |
os.symlink('lib', lib64_link) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1526 |
else: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1527 |
copyfile('lib', lib64_link) |
3 | 1528 |
|
1529 |
def resolve_interpreter(exe): |
|
1530 |
""" |
|
1531 |
If the executable given isn't an absolute path, search $PATH for the interpreter |
|
1532 |
""" |
|
1533 |
# If the "executable" is a version number, get the installed executable for |
|
1534 |
# that version |
|
1535 |
python_versions = get_installed_pythons() |
|
1536 |
if exe in python_versions: |
|
1537 |
exe = python_versions[exe] |
|
1538 |
||
1539 |
if os.path.abspath(exe) != exe: |
|
1540 |
paths = os.environ.get('PATH', '').split(os.pathsep) |
|
1541 |
for path in paths: |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1542 |
if os.path.exists(join(path, exe)): |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1543 |
exe = join(path, exe) |
3 | 1544 |
break |
1545 |
if not os.path.exists(exe): |
|
1546 |
logger.fatal('The executable %s (from --python=%s) does not exist' % (exe, exe)) |
|
1547 |
raise SystemExit(3) |
|
1548 |
if not is_executable(exe): |
|
1549 |
logger.fatal('The executable %s (from --python=%s) is not executable' % (exe, exe)) |
|
1550 |
raise SystemExit(3) |
|
1551 |
return exe |
|
1552 |
||
1553 |
def is_executable(exe): |
|
1554 |
"""Checks a file is executable""" |
|
1555 |
return os.access(exe, os.X_OK) |
|
1556 |
||
1557 |
############################################################ |
|
1558 |
## Relocating the environment: |
|
1559 |
||
1560 |
def make_environment_relocatable(home_dir): |
|
1561 |
""" |
|
1562 |
Makes the already-existing environment use relative paths, and takes out |
|
1563 |
the #!-based environment selection in scripts. |
|
1564 |
""" |
|
1565 |
home_dir, lib_dir, inc_dir, bin_dir = path_locations(home_dir) |
|
1566 |
activate_this = os.path.join(bin_dir, 'activate_this.py') |
|
1567 |
if not os.path.exists(activate_this): |
|
1568 |
logger.fatal( |
|
1569 |
'The environment doesn\'t have a file %s -- please re-run virtualenv ' |
|
1570 |
'on this environment to update it' % activate_this) |
|
1571 |
fixup_scripts(home_dir, bin_dir) |
|
1572 |
fixup_pth_and_egg_link(home_dir) |
|
1573 |
## FIXME: need to fix up distutils.cfg |
|
1574 |
||
1575 |
OK_ABS_SCRIPTS = ['python', 'python%s' % sys.version[:3], |
|
1576 |
'activate', 'activate.bat', 'activate_this.py', |
|
1577 |
'activate.fish', 'activate.csh'] |
|
1578 |
||
1579 |
def fixup_scripts(home_dir, bin_dir): |
|
1580 |
if is_win: |
|
1581 |
new_shebang_args = ( |
|
1582 |
'%s /c' % os.path.normcase(os.environ.get('COMSPEC', 'cmd.exe')), |
|
1583 |
'', '.exe') |
|
1584 |
else: |
|
1585 |
new_shebang_args = ('/usr/bin/env', sys.version[:3], '') |
|
1586 |
||
1587 |
# This is what we expect at the top of scripts: |
|
1588 |
shebang = '#!%s' % os.path.normcase(os.path.join( |
|
1589 |
os.path.abspath(bin_dir), 'python%s' % new_shebang_args[2])) |
|
1590 |
# This is what we'll put: |
|
1591 |
new_shebang = '#!%s python%s%s' % new_shebang_args |
|
1592 |
||
1593 |
for filename in os.listdir(bin_dir): |
|
1594 |
filename = os.path.join(bin_dir, filename) |
|
1595 |
if not os.path.isfile(filename): |
|
1596 |
# ignore subdirs, e.g. .svn ones. |
|
1597 |
continue |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1598 |
lines = None |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1599 |
with open(filename, 'rb') as f: |
3 | 1600 |
try: |
1601 |
lines = f.read().decode('utf-8').splitlines() |
|
1602 |
except UnicodeDecodeError: |
|
1603 |
# This is probably a binary program instead |
|
1604 |
# of a script, so just ignore it. |
|
1605 |
continue |
|
1606 |
if not lines: |
|
1607 |
logger.warn('Script %s is an empty file' % filename) |
|
1608 |
continue |
|
1609 |
||
1610 |
old_shebang = lines[0].strip() |
|
1611 |
old_shebang = old_shebang[0:2] + os.path.normcase(old_shebang[2:]) |
|
1612 |
||
1613 |
if not old_shebang.startswith(shebang): |
|
1614 |
if os.path.basename(filename) in OK_ABS_SCRIPTS: |
|
1615 |
logger.debug('Cannot make script %s relative' % filename) |
|
1616 |
elif lines[0].strip() == new_shebang: |
|
1617 |
logger.info('Script %s has already been made relative' % filename) |
|
1618 |
else: |
|
1619 |
logger.warn('Script %s cannot be made relative (it\'s not a normal script that starts with %s)' |
|
1620 |
% (filename, shebang)) |
|
1621 |
continue |
|
1622 |
logger.notify('Making script %s relative' % filename) |
|
1623 |
script = relative_script([new_shebang] + lines[1:]) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1624 |
with open(filename, 'wb') as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1625 |
f.write('\n'.join(script).encode('utf-8')) |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1626 |
|
3 | 1627 |
|
1628 |
def relative_script(lines): |
|
1629 |
"Return a script that'll work in a relocatable environment." |
|
1630 |
activate = "import os; activate_this=os.path.join(os.path.dirname(os.path.realpath(__file__)), 'activate_this.py'); exec(compile(open(activate_this).read(), activate_this, 'exec'), dict(__file__=activate_this)); del os, activate_this" |
|
1631 |
# Find the last future statement in the script. If we insert the activation |
|
1632 |
# line before a future statement, Python will raise a SyntaxError. |
|
1633 |
activate_at = None |
|
1634 |
for idx, line in reversed(list(enumerate(lines))): |
|
1635 |
if line.split()[:3] == ['from', '__future__', 'import']: |
|
1636 |
activate_at = idx + 1 |
|
1637 |
break |
|
1638 |
if activate_at is None: |
|
1639 |
# Activate after the shebang. |
|
1640 |
activate_at = 1 |
|
1641 |
return lines[:activate_at] + ['', activate, ''] + lines[activate_at:] |
|
1642 |
||
1643 |
def fixup_pth_and_egg_link(home_dir, sys_path=None): |
|
1644 |
"""Makes .pth and .egg-link files use relative paths""" |
|
1645 |
home_dir = os.path.normcase(os.path.abspath(home_dir)) |
|
1646 |
if sys_path is None: |
|
1647 |
sys_path = sys.path |
|
1648 |
for path in sys_path: |
|
1649 |
if not path: |
|
1650 |
path = '.' |
|
1651 |
if not os.path.isdir(path): |
|
1652 |
continue |
|
1653 |
path = os.path.normcase(os.path.abspath(path)) |
|
1654 |
if not path.startswith(home_dir): |
|
1655 |
logger.debug('Skipping system (non-environment) directory %s' % path) |
|
1656 |
continue |
|
1657 |
for filename in os.listdir(path): |
|
1658 |
filename = os.path.join(path, filename) |
|
1659 |
if filename.endswith('.pth'): |
|
1660 |
if not os.access(filename, os.W_OK): |
|
1661 |
logger.warn('Cannot write .pth file %s, skipping' % filename) |
|
1662 |
else: |
|
1663 |
fixup_pth_file(filename) |
|
1664 |
if filename.endswith('.egg-link'): |
|
1665 |
if not os.access(filename, os.W_OK): |
|
1666 |
logger.warn('Cannot write .egg-link file %s, skipping' % filename) |
|
1667 |
else: |
|
1668 |
fixup_egg_link(filename) |
|
1669 |
||
1670 |
def fixup_pth_file(filename): |
|
1671 |
lines = [] |
|
1672 |
prev_lines = [] |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1673 |
with open(filename) as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1674 |
prev_lines = f.readlines() |
3 | 1675 |
for line in prev_lines: |
1676 |
line = line.strip() |
|
1677 |
if (not line or line.startswith('#') or line.startswith('import ') |
|
1678 |
or os.path.abspath(line) != line): |
|
1679 |
lines.append(line) |
|
1680 |
else: |
|
1681 |
new_value = make_relative_path(filename, line) |
|
1682 |
if line != new_value: |
|
1683 |
logger.debug('Rewriting path %s as %s (in %s)' % (line, new_value, filename)) |
|
1684 |
lines.append(new_value) |
|
1685 |
if lines == prev_lines: |
|
1686 |
logger.info('No changes to .pth file %s' % filename) |
|
1687 |
return |
|
1688 |
logger.notify('Making paths in .pth file %s relative' % filename) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1689 |
with open(filename, 'w') as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1690 |
f.write('\n'.join(lines) + '\n') |
3 | 1691 |
|
1692 |
def fixup_egg_link(filename): |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1693 |
with open(filename) as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1694 |
link = f.readline().strip() |
3 | 1695 |
if os.path.abspath(link) != link: |
1696 |
logger.debug('Link in %s already relative' % filename) |
|
1697 |
return |
|
1698 |
new_link = make_relative_path(filename, link) |
|
1699 |
logger.notify('Rewriting link %s in %s as %s' % (link, filename, new_link)) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1700 |
with open(filename, 'w') as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1701 |
f.write(new_link) |
3 | 1702 |
|
1703 |
def make_relative_path(source, dest, dest_is_directory=True): |
|
1704 |
""" |
|
1705 |
Make a filename relative, where the filename is dest, and it is |
|
1706 |
being referred to from the filename source. |
|
1707 |
||
1708 |
>>> make_relative_path('/usr/share/something/a-file.pth', |
|
1709 |
... '/usr/share/another-place/src/Directory') |
|
1710 |
'../another-place/src/Directory' |
|
1711 |
>>> make_relative_path('/usr/share/something/a-file.pth', |
|
1712 |
... '/home/user/src/Directory') |
|
1713 |
'../../../home/user/src/Directory' |
|
1714 |
>>> make_relative_path('/usr/share/a-file.pth', '/usr/share/') |
|
1715 |
'./' |
|
1716 |
""" |
|
1717 |
source = os.path.dirname(source) |
|
1718 |
if not dest_is_directory: |
|
1719 |
dest_filename = os.path.basename(dest) |
|
1720 |
dest = os.path.dirname(dest) |
|
1721 |
dest = os.path.normpath(os.path.abspath(dest)) |
|
1722 |
source = os.path.normpath(os.path.abspath(source)) |
|
1723 |
dest_parts = dest.strip(os.path.sep).split(os.path.sep) |
|
1724 |
source_parts = source.strip(os.path.sep).split(os.path.sep) |
|
1725 |
while dest_parts and source_parts and dest_parts[0] == source_parts[0]: |
|
1726 |
dest_parts.pop(0) |
|
1727 |
source_parts.pop(0) |
|
1728 |
full_parts = ['..']*len(source_parts) + dest_parts |
|
1729 |
if not dest_is_directory: |
|
1730 |
full_parts.append(dest_filename) |
|
1731 |
if not full_parts: |
|
1732 |
# Special case for the current directory (otherwise it'd be '') |
|
1733 |
return './' |
|
1734 |
return os.path.sep.join(full_parts) |
|
1735 |
||
1736 |
||
1737 |
||
1738 |
############################################################ |
|
1739 |
## Bootstrap script creation: |
|
1740 |
||
1741 |
def create_bootstrap_script(extra_text, python_version=''): |
|
1742 |
""" |
|
1743 |
Creates a bootstrap script, which is like this script but with |
|
1744 |
extend_parser, adjust_options, and after_install hooks. |
|
1745 |
||
1746 |
This returns a string that (written to disk of course) can be used |
|
1747 |
as a bootstrap script with your own customizations. The script |
|
1748 |
will be the standard virtualenv.py script, with your extra text |
|
1749 |
added (your extra text should be Python code). |
|
1750 |
||
1751 |
If you include these functions, they will be called: |
|
1752 |
||
1753 |
``extend_parser(optparse_parser)``: |
|
1754 |
You can add or remove options from the parser here. |
|
1755 |
||
1756 |
``adjust_options(options, args)``: |
|
1757 |
You can change options here, or change the args (if you accept |
|
1758 |
different kinds of arguments, be sure you modify ``args`` so it is |
|
1759 |
only ``[DEST_DIR]``). |
|
1760 |
||
1761 |
``after_install(options, home_dir)``: |
|
1762 |
||
1763 |
After everything is installed, this function is called. This |
|
1764 |
is probably the function you are most likely to use. An |
|
1765 |
example would be:: |
|
1766 |
||
1767 |
def after_install(options, home_dir): |
|
1768 |
subprocess.call([join(home_dir, 'bin', 'easy_install'), |
|
1769 |
'MyPackage']) |
|
1770 |
subprocess.call([join(home_dir, 'bin', 'my-package-script'), |
|
1771 |
'setup', home_dir]) |
|
1772 |
||
1773 |
This example immediately installs a package, and runs a setup |
|
1774 |
script from that package. |
|
1775 |
||
1776 |
If you provide something like ``python_version='2.5'`` then the |
|
1777 |
script will start with ``#!/usr/bin/env python2.5`` instead of |
|
1778 |
``#!/usr/bin/env python``. You can use this when the script must |
|
1779 |
be run with a particular Python version. |
|
1780 |
""" |
|
1781 |
filename = __file__ |
|
1782 |
if filename.endswith('.pyc'): |
|
1783 |
filename = filename[:-1] |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1784 |
with codecs.open(filename, 'r', encoding='utf-8') as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1785 |
content = f.read() |
3 | 1786 |
py_exe = 'python%s' % python_version |
1787 |
content = (('#!/usr/bin/env %s\n' % py_exe) |
|
1788 |
+ '## WARNING: This file is generated\n' |
|
1789 |
+ content) |
|
1790 |
return content.replace('##EXT' 'END##', extra_text) |
|
1791 |
||
1792 |
##EXTEND## |
|
1793 |
||
1794 |
def convert(s): |
|
1795 |
b = base64.b64decode(s.encode('ascii')) |
|
1796 |
return zlib.decompress(b).decode('utf-8') |
|
1797 |
||
1798 |
##file site.py |
|
1799 |
SITE_PY = convert(""" |
|
1800 |
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 |
|
1940 |
AVijEPwfucjncQ== |
|
1941 |
""") |
|
1942 |
||
1943 |
##file activate.sh |
|
1944 |
ACTIVATE_SH = convert(""" |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1945 |
eJytVd9v2kAMfs9fYQLq2m4MscdNVKMqEkgtVIQxbeuUHolpTgsXdHehpT/+9/mSEBJS2MOaB0ji |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1946 |
z77P9menDpOAK5jzEGERKw0zhFihD/dcB2CrKJYewoyLFvM0XzGNNpzOZbSAGVPBqVWHdRSDx4SI |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1947 |
NMhYANfgc4meDteW5ePGC45P4MkCumKhUENzDsu1H3lw1vJx1RJxGMKns6O2lWDqINGgotAHFCsu |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1948 |
I7FAoWHFJGezEFWGqsEvaD5C42naHb93X+A3+elYCgVaxgh8DmQAys9HL2SS0mIaWBgm7mTN/O3G |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1949 |
kzu6vHCng/HkW/fSve5O+hTOpnhfQAcoEry5jKVjNypoO0fgwzKSOgHm79KUK06Jfc7/RebHpD8a |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1950 |
9kdXvT2UcnuFWG6p0stNB0mWUUQ1q3uiGRVEMfXHR03dTuQATPjwqIIPcB9wL4CArRAY/ZHJixYL |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1951 |
Y9YBtcAoLQtFevOoI9QaHcEdMSAB0d08kuZhyUiSmav6CPCdVBnFOjNrLu6yMCWgKRA0TInBC5i4 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1952 |
QwX3JG/mm581GKnSsSSxJTFHf9MAKr8w5T/vOv1mUurn5/zlT6fvTntjZzAaNl9rQ5JkU5KIc0GX |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1953 |
inagwU57T2eddqWlTrvaS6d9sImZeUMkhWysveF0m37NcGub9Dpgi0j4qGiOzATjDr06OBjOYQOo |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1954 |
7RBoGtNm9Denv1i0LVI7lxJDXLHSSBeWRflsyyqw7diuW3h0XdvK6lBMyaoMG1UyHdTsoYBuue75 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1955 |
YOgOu1c91/2cwYpznPPeDoQpGL2xSm09NKp7BsvQ2hnT3aMs07lUnskpxewvBk73/LLnXo9HV9eT |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1956 |
ijB3hWBO2ygoiWg/bKuZxqCCQq0DD3vkWIVvI2KosIw+vqW1gIItEG5KJb+xb09g65ktwYKgTc51 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1957 |
uGJ/EFQs0ayEWLCQM5V9N4g+1+8UbXOJzF8bqhKtIqIwicWvzNFROZJlpfD8A7Vc044R0FxkcezG |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1958 |
VzsV75usvTdYef+57v5n1b225qhXfwEmxHEs |
3 | 1959 |
""") |
1960 |
||
1961 |
##file activate.fish |
|
1962 |
ACTIVATE_FISH = convert(""" |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1963 |
eJyFVVFv0zAQfs+vONJO3RDNxCsSQoMVrdK2Vl03CSHkesllMXLsYDvZivjx2GmTOG0YfWhV+7u7 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1964 |
73z33Y1gnTENKeMIeakNPCKUGhP7xcQTbCJ4ZOKcxoZV1GCUMp1t4O0zMxkTQEGVQjicO4dTyIwp |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1965 |
Ppyfu386Q86jWOZwBhq1ZlK8jYIRXEoQ0jhDYAYSpjA2fBsFQVoKG0UKSLAJB9MEJrMXi6uYMiXl |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1966 |
KCrIZYJARQIKTakEGAkmQ+tU5ZSDRTAlRY7CRJMA7GdkgRoNSJ74t1BRxegjR12jWAoGbfpTAeGY |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1967 |
LK4vycN8tb6/uCbLi/VVWGPcx3maPr2AO4VjYB+HMAxAkQT/i/ptfbW4vVrczAZit3eHDNqL13n0 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1968 |
Ya+w+Tq/uyLL1eJmuSaLh9lqNb/0+IzgznqnAjAvzBa4jG0BNmNXfdJUkxTU2I6xRaKcy+e6VApz |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1969 |
WVmoTGFTgwslrYdN03ONrbbMN1E/FQ7H7gOP0UxRjV67TPRBjF3naCMV1mSkYk9MUN7F8cODZzsE |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1970 |
iIHYviIe6n8WeGQxWKuhl+9Xa49uijq7fehXMRxT9VR9f/8jhDcfYSKkSOyxKp22cNIrIk+nzd2b |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1971 |
Yc7FNpHx8FUn15ZfzXEE98JxZEohx4r6kosCT+R9ZkHQtLmXGYSEeH8JCTvYkcRgXAutp9Rw7Jmf |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1972 |
E/J5fktuL25m1tMe3vLdjDt9bNxr2sMo2P3C9BccqGeYhqfQITz6XurXaqdf99LF1mT2YJrvzqCu |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1973 |
5w7dKvV3PzNyOb+7+Hw923dOuB+AX2SxrZs9Lm0xbCH6kmhjUyuWw+7cC7DX8367H3VzDz6oBtty |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1974 |
tMIeobE21JT6HaRS+TbaoqhbE7rgdGs3xtE4cOF3xo0TfxwsdyRlhUoxuzes18r+Jp88zDx1G+kd |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1975 |
/HTrr1BY2CeuyfnbQtAcu9j+pOw6cy9X0k3IuoyKCZPC5ESf6MkgHE5tLiSW3Oa+W2NnrQfkGv/h |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1976 |
7tR5PNFnMBlw4B9NJTxnzKA9fLTT0aXSb5vw7FUKzcTZPddqYHi2T9/axJmEEN3qHncVCuEPaFmq |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1977 |
uEtpcBj2Z1wjrqGReJBHrY6/go21NA== |
3 | 1978 |
""") |
1979 |
||
1980 |
##file activate.csh |
|
1981 |
ACTIVATE_CSH = convert(""" |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1982 |
eJx1U2FP2zAQ/e5f8TAV3Soo+0zXbYUiDQkKQgVp2ibjJNfFUuIg22nVf885SVFLO3+I7Lt3fr6X |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1983 |
d8eY58ZjYQpCWfuAhFB7yrAyIYf0Ve1SQmLsuU6DWepAw9TnEoOFq0rwdjAUx/hV1Ui1tVWAqy1M |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1984 |
QGYcpaFYx+yVI67LkKwx1UuTEaYGl4X2Bl+zJpAlP/6V2hTDtCq/DYXQhdEeGW040Q/Eb+t9V/e3 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1985 |
U/V88zh/mtyqh8n8J47G+IKTE3gKZJdoYrK3h5MRU1tGYS83gqNc+3yEgyyP93cP820evHLvr2H8 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1986 |
kaYB/peoyY7aVHzpJnE9e+6I5Z+ji4GMTNJWNuOQq6MA1N25p8pW9HWdVWlfsNpPDbdxjgpaahuw |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1987 |
1M7opCA/FFu1uwxC7L8KUqmto1KyQe3rx0I0Eovdf7BVe67U5c1MzSZ310pddGheZoFPWyytRkzU |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1988 |
aCA/I+RkBXhFXr5aWV0SxjhUI6jwdAj8kmhPzX7nTfJFkM3MImp2VdVFFq1vLHSU5szYQK4Ri+Jd |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1989 |
xlW2JBtOGcyYVW7SnB3v6RS91g3gKapZ0oWxbHVteYIIq3iv7QeuSrUj6KSqQ+yqsxDj1ivNQxKF |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1990 |
YON10Q+NH/ARS95i5Tuqq2Vxfvc23f/FO6zrtXXmJr+ZtMY9/A15ZXFWtmch2rEQ4g1ryVHH |
3 | 1991 |
""") |
1992 |
||
1993 |
##file activate.bat |
|
1994 |
ACTIVATE_BAT = convert(""" |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1995 |
eJx9Ul9LhEAQfxf8DoOclI/dYyFkaCmcq4gZQTBUrincuZFbff12T133TM+nnd35/Zvxlr7XDFhV |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1996 |
mUZHOVhFlOWP3g4DUriIWoVomYZpNBWUtGpaWgImO191pFkSpzlcmgaI70jVX7n2Qp8tuByg+46O |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1997 |
CMHbMq64T+nmlJt082D1T44muCDk2prgEHF4mdI9RaS/QwSt3zSyIAaftRccvqVTBziD1x/WlPD5 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1998 |
xd729NDBb8Nr4DU9QNMKsJeH9pkhPedhQsIkDuCDCa6A+NF9IevVFAohkqizdHetg/tkWvPoftWJ |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
1999 |
MCqnOxv7/x7Np6yv9P2Ker5dmX8yNyCkkWnbZy3N5LarczlqL8htx2EM9rQ/2H5BvIsIEi8OEG8U |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2000 |
+g8CsNTr |
3 | 2001 |
""") |
2002 |
||
2003 |
##file deactivate.bat |
|
2004 |
DEACTIVATE_BAT = convert(""" |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2005 |
eJyFkN0KgkAUhO8F32EQpHqFQEjQUPAPMaErqVxzId3IrV6/XST/UDx3c86c4WMO5FYysKJQFVVp |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2006 |
CEfqxsnJ9DI7SA25i20fFqs3HO+GYLsDZ7h8GM3xfLHrg1QNvpSX4CWpQGvokZk4uqrQAjXjyElB |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2007 |
a5IjCz0r+2dHcehHCe5MZNmB5R7TdqMqECMptHZh6DN/utb7Zs6Cej8OXYE5J04YOKFvD4GkHuJ0 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2008 |
pilSd1jG6n87tDZ+BUwUOepI6CGSkFMYWf0ihvT33Qj1A+tCkSI= |
3 | 2009 |
""") |
2010 |
||
2011 |
##file activate.ps1 |
|
2012 |
ACTIVATE_PS = convert(""" |
|
2013 |
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 |
|
2099 |
rKQDxR6N/rffXv+lROXet/9Q+l9I4D1U |
|
2100 |
""") |
|
2101 |
||
2102 |
##file distutils-init.py |
|
2103 |
DISTUTILS_INIT = convert(""" |
|
2104 |
eJytV1uL4zYUfvevOE0ottuMW9q3gVDa3aUMXXbLMlDKMBiNrSTqOJKRlMxkf33PkXyRbGe7Dw2E |
|
2105 |
UXTu37lpxLFV2oIyifAncxmOL0xLIfcG+gv80x9VW6maw7o/CANSWWBwFtqeWMPlGY6qPjV8A0bB |
|
2106 |
C4eKSTgZ5LRgFeyErMEeOBhbN+Ipgeizhjtnhkn7DdyjuNLPoCS0l/ayQTG0djwZC08cLXozeMss |
|
2107 |
aG5EzQ0IScpnWtHSTXuxByV/QCmxE7y+eS0uxWeoheaVVfqSJHiU7Mhhi6gULbOHorshkrEnKxpT |
|
2108 |
0n3A8Y8SMpuwZx6aoix3ouFlmW8gHRSkeSJ2g7hU+kiHLDaQw3bmRDaTGfTnty7gPm0FHbIBg9U9 |
|
2109 |
oh1kZzAFLaue2R6htPCtAda2nGlDSUJ4PZBgCJBGVcwKTAMz/vJiLD+Oin5Z5QlvDPdulC6EsiyE |
|
2110 |
NFzb7McNTKJzbJqzphx92VKRFY1idenzmq3K0emRcbWBD0ryqc4NZGmKOOOX9Pz5x+/l27tP797c |
|
2111 |
f/z0d+4NruGNai8uAM0bfsYaw8itFk8ny41jsfpyO+BWlpqfhcG4yxLdi/0tQqoT4a8Vby382mt8 |
|
2112 |
p7XSo7aWGdPBc+b6utaBmCQ7rQKQoWtAuthQCiold2KfJIPTT8xwg9blPumc+YDZC/wYGdAyHpJk |
|
2113 |
vUbHbHWAp5No6pK/WhhLEWrFjUwtPEv1Agf8YmnsuXUQYkeZoHm8ogP16gt2uHoxcEMdf2C6pmbw |
|
2114 |
hUMsWGhanboh4IzzmsIpWs134jVPqD/c74bZHdY69UKKSn/+KfVhxLgUlToemayLMYQOqfEC61bh |
|
2115 |
cbhwaqoGUzIyZRFHPmau5juaWqwRn3mpWmoEA5nhzS5gog/5jbcFQqOZvmBasZtwYlG93k5GEiyw |
|
2116 |
buHhMWLjDarEGpMGB2LFs5nIJkhp/nUmZneFaRth++lieJtHepIvKgx6PJqIlD9X2j6pG1i9x3pZ |
|
2117 |
5bHuCPFiirGHeO7McvoXkz786GaKVzC9DSpnOxJdc4xm6NSVq7lNEnKdVlnpu9BNYoKX2Iq3wvgh |
|
2118 |
gGEUM66kK6j4NiyoneuPLSwaCWDxczgaolEWpiMyDVDb7dNuLAbriL8ig8mmeju31oNvQdpnvEPC |
|
2119 |
1vAXbWacGRVrGt/uXN/gU0CDDwgooKRrHfTBb1/s9lYZ8ZqOBU0yLvpuP6+K9hLFsvIjeNhBi0KL |
|
2120 |
MlOuWRn3FRwx5oHXjl0YImUx0+gLzjGchrgzca026ETmYJzPD+IpuKzNi8AFn048Thd63OdD86M6 |
|
2121 |
84zE8yQm0VqXdbbgvub2pKVnS76icBGdeTHHXTKspUmr4NYo/furFLKiMdQzFjHJNcdAnMhltBJK |
|
2122 |
0/IKX3DVFqvPJ2dLE7bDBkH0l/PJ29074+F0CsGYOxsb7U3myTUncYfXqnLLfa6sJybX4g+hmcjO |
|
2123 |
kMRBfA1JellfRRKJcyRpxdS4rIl6FdmQCWjo/o9Qz7yKffoP4JHjOvABcRn4CZIT2RH4jnxmfpVG |
|
2124 |
qgLaAvQBNfuO6X0/Ux02nb4FKx3vgP+XnkX0QW9pLy/NsXgdN24dD3LxO2Nwil7Zlc1dqtP3d7/h |
|
2125 |
kzp1/+7hGBuY4pk0XD/0Ao/oTe/XGrfyM773aB7iUhgkpy+dwAMalxMP0DrBcsVw/6p25+/hobP9 |
|
2126 |
GBknrWExDhLJ1bwt1NcCNblaFbMKCyvmX0PeRaQ= |
|
2127 |
""") |
|
2128 |
||
2129 |
##file distutils.cfg |
|
2130 |
DISTUTILS_CFG = convert(""" |
|
2131 |
eJxNj00KwkAMhfc9xYNuxe4Ft57AjYiUtDO1wXSmNJnK3N5pdSEEAu8nH6lxHVlRhtDHMPATA4uH |
|
2132 |
xJ4EFmGbvfJiicSHFRzUSISMY6hq3GLCRLnIvSTnEefN0FIjw5tF0Hkk9Q5dRunBsVoyFi24aaLg |
|
2133 |
9FDOlL0FPGluf4QjcInLlxd6f6rqkgPu/5nHLg0cXCscXoozRrP51DRT3j9QNl99AP53T2Q= |
|
2134 |
""") |
|
2135 |
||
2136 |
##file activate_this.py |
|
2137 |
ACTIVATE_THIS = convert(""" |
|
2138 |
eJyNU01v2zAMvetXEB4K21jnDOstQA4dMGCHbeihlyEIDMWmE62yJEiKE//7kXKdpEWLzYBt8evx |
|
2139 |
kRSzLPs6wiEoswM8YdMpjUXcq1Dz6RZa1cSiTkJdr86GsoTRHuCotBayiWqQEYGtMCgfD1KjGYBe |
|
2140 |
5a3p0cRKiEe2NtLAFikftnDco0ko/SFEVgEZ8aRCZDIPY9xbA8pE9M4jfW/B2CjiHq9zbJVZuOQq |
|
2141 |
siwTIvpxKYCembPAU4Muwi/Z4zfvrZ/MXipKeB8C+qisSZYiWfjJfs+0/MFMdWn1hJcO5U7G/SLa |
|
2142 |
xVx8zU6VG/PXLXvfsyyzUqjeWR8hjGE+2iCE1W1tQ82hsCJN9dzKaoexyB/uH79TnjwvxcW0ntSb |
|
2143 |
yZ8jq1Z5Q1UXsyy3gf9nbjTEj7NzQMfCJa/YSmrQ+2D/BqfiOi6sclrGzvoeVivIj8rcfcmnIQRF |
|
2144 |
7XCyeZI7DFe5/lhlCs5PRf5QW66VXT/NrlQ46oD/D6InkOmi3IQcbhKxAX2g4a+Xd5s3UtCtG2py |
|
2145 |
m8eg6WYWqR6SL5OjKMGfSrYt/6kxxQtOpeAgj1LXBNmpE2ElmCSIy5H0zFd8gJ924HWijWhb2hRC |
|
2146 |
6wNEm1QdDZtuSZcEprIUBo/XRNcbQe1OUbQ/r3hPTaPJJDNtFLu8KHV5XoNr3Eo6h6YtOKw8e8yw |
|
2147 |
VF5PnJ+ts3a9/Mz38RpG/AUSzYUW |
|
2148 |
""") |
|
2149 |
||
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2150 |
##file python-config |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2151 |
PYTHON_CONFIG = convert(""" |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2152 |
eJyNVV1P2zAUfc+v8ODBiSABxlulTipbO6p1LWqBgVhlhcZpPYUkctzSivHfd6+dpGloGH2Ja/ue |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2153 |
e+65Hz78xNhtf3x90xmw7vCWsRPGLvpDNuz87MKfdKMWSWxZ4ilNpCLZJiuWc66SVFUOZkkcirll |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2154 |
rfxIBAzOMtImDzSVPBRrekwoX/OZu/0r4lm0DHiG60g86u8sjPw5rCyy86NRkB8QuuBRSqfAKESn |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2155 |
3orLTCQxE3GYkC9tYp8fk89OSwNsmXgizrhUtnumeSgeo5GbLUMk49Rv+2nK48Cm/qMwfp333J2/ |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2156 |
dVcAGE0CIQHBsgIeEr4Wij0LtWDLzJ9ze5YEvH2WI6CHTAVcSu9ZCsXtgxu81CIvp6/k4eXsdfo7 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2157 |
PvDCRD75yi41QitfzlcPp1OI7i/1/iQitqnr0iMgQ+A6wa+IKwwdxyk9IiXNAzgquTFU8NIxAVjM |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2158 |
osm1Zz526e+shQ4hKRVci69nPC3Kw4NQEmkQ65E7OodxorSvxjvpBjQHDmWFIQ1mlmzlS5vedseT |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2159 |
/mgIEsMJ7Lxz2bLAF9M5xeLEhdbHxpWOw0GdkJApMVBRF1y+a0z3c9WZPAXGFcFrJgCIB+024uad |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2160 |
0CrzmEoRa3Ub4swNIHPGf7QDV+2uj2OiFWsChgCwjKqN6rp5izpbH6Wc1O1TclQTP/XVwi6anTr1 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2161 |
1sbubjZLI1+VptPSdCfwnFBrB1jvebrTA9uUhU2/9gad7xPqeFkaQcnnLbCViZK8d7R1kxzFrIJV |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2162 |
8EaLYmKYpvGVkig+3C5HCXbM1jGCGekiM2pRCVPyRyXYdPf6kcbWEQ36F5V4Gq9N7icNNw+JHwRE |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2163 |
LTgxRXACpvnQv/PuT0xCCAywY/K4hE6Now2qDwaSE5FB+1agsoUveYDepS83qFcF1NufvULD3fTl |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2164 |
g6Hgf7WBt6lzMeiyyWVn3P1WVbwaczHmTzE9A5SyItTVgFYyvs/L/fXlaNgbw8v3azT+0eikVlWD |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2165 |
/vBHbzQumP23uBCjsYdrL9OWARwxs/nuLOzeXbPJTa/Xv6sUmQir5pC1YRLz3eA+CD8Z0XpcW8v9 |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2166 |
MZWF36ryyXXf3yBIz6nzqz8Muyz0m5Qj7OexfYo/Ph3LqvkHUg7AuA== |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2167 |
""") |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2168 |
|
3 | 2169 |
MH_MAGIC = 0xfeedface |
2170 |
MH_CIGAM = 0xcefaedfe |
|
2171 |
MH_MAGIC_64 = 0xfeedfacf |
|
2172 |
MH_CIGAM_64 = 0xcffaedfe |
|
2173 |
FAT_MAGIC = 0xcafebabe |
|
2174 |
BIG_ENDIAN = '>' |
|
2175 |
LITTLE_ENDIAN = '<' |
|
2176 |
LC_LOAD_DYLIB = 0xc |
|
2177 |
maxint = majver == 3 and getattr(sys, 'maxsize') or getattr(sys, 'maxint') |
|
2178 |
||
2179 |
||
2180 |
class fileview(object): |
|
2181 |
""" |
|
2182 |
A proxy for file-like objects that exposes a given view of a file. |
|
2183 |
Modified from macholib. |
|
2184 |
""" |
|
2185 |
||
2186 |
def __init__(self, fileobj, start=0, size=maxint): |
|
2187 |
if isinstance(fileobj, fileview): |
|
2188 |
self._fileobj = fileobj._fileobj |
|
2189 |
else: |
|
2190 |
self._fileobj = fileobj |
|
2191 |
self._start = start |
|
2192 |
self._end = start + size |
|
2193 |
self._pos = 0 |
|
2194 |
||
2195 |
def __repr__(self): |
|
2196 |
return '<fileview [%d, %d] %r>' % ( |
|
2197 |
self._start, self._end, self._fileobj) |
|
2198 |
||
2199 |
def tell(self): |
|
2200 |
return self._pos |
|
2201 |
||
2202 |
def _checkwindow(self, seekto, op): |
|
2203 |
if not (self._start <= seekto <= self._end): |
|
2204 |
raise IOError("%s to offset %d is outside window [%d, %d]" % ( |
|
2205 |
op, seekto, self._start, self._end)) |
|
2206 |
||
2207 |
def seek(self, offset, whence=0): |
|
2208 |
seekto = offset |
|
2209 |
if whence == os.SEEK_SET: |
|
2210 |
seekto += self._start |
|
2211 |
elif whence == os.SEEK_CUR: |
|
2212 |
seekto += self._start + self._pos |
|
2213 |
elif whence == os.SEEK_END: |
|
2214 |
seekto += self._end |
|
2215 |
else: |
|
2216 |
raise IOError("Invalid whence argument to seek: %r" % (whence,)) |
|
2217 |
self._checkwindow(seekto, 'seek') |
|
2218 |
self._fileobj.seek(seekto) |
|
2219 |
self._pos = seekto - self._start |
|
2220 |
||
2221 |
def write(self, bytes): |
|
2222 |
here = self._start + self._pos |
|
2223 |
self._checkwindow(here, 'write') |
|
2224 |
self._checkwindow(here + len(bytes), 'write') |
|
2225 |
self._fileobj.seek(here, os.SEEK_SET) |
|
2226 |
self._fileobj.write(bytes) |
|
2227 |
self._pos += len(bytes) |
|
2228 |
||
2229 |
def read(self, size=maxint): |
|
2230 |
assert size >= 0 |
|
2231 |
here = self._start + self._pos |
|
2232 |
self._checkwindow(here, 'read') |
|
2233 |
size = min(size, self._end - here) |
|
2234 |
self._fileobj.seek(here, os.SEEK_SET) |
|
2235 |
bytes = self._fileobj.read(size) |
|
2236 |
self._pos += len(bytes) |
|
2237 |
return bytes |
|
2238 |
||
2239 |
||
2240 |
def read_data(file, endian, num=1): |
|
2241 |
""" |
|
2242 |
Read a given number of 32-bits unsigned integers from the given file |
|
2243 |
with the given endianness. |
|
2244 |
""" |
|
2245 |
res = struct.unpack(endian + 'L' * num, file.read(num * 4)) |
|
2246 |
if len(res) == 1: |
|
2247 |
return res[0] |
|
2248 |
return res |
|
2249 |
||
2250 |
||
2251 |
def mach_o_change(path, what, value): |
|
2252 |
""" |
|
2253 |
Replace a given name (what) in any LC_LOAD_DYLIB command found in |
|
2254 |
the given binary with a new name (value), provided it's shorter. |
|
2255 |
""" |
|
2256 |
||
2257 |
def do_macho(file, bits, endian): |
|
2258 |
# Read Mach-O header (the magic number is assumed read by the caller) |
|
2259 |
cputype, cpusubtype, filetype, ncmds, sizeofcmds, flags = read_data(file, endian, 6) |
|
2260 |
# 64-bits header has one more field. |
|
2261 |
if bits == 64: |
|
2262 |
read_data(file, endian) |
|
2263 |
# The header is followed by ncmds commands |
|
2264 |
for n in range(ncmds): |
|
2265 |
where = file.tell() |
|
2266 |
# Read command header |
|
2267 |
cmd, cmdsize = read_data(file, endian, 2) |
|
2268 |
if cmd == LC_LOAD_DYLIB: |
|
2269 |
# The first data field in LC_LOAD_DYLIB commands is the |
|
2270 |
# offset of the name, starting from the beginning of the |
|
2271 |
# command. |
|
2272 |
name_offset = read_data(file, endian) |
|
2273 |
file.seek(where + name_offset, os.SEEK_SET) |
|
2274 |
# Read the NUL terminated string |
|
2275 |
load = file.read(cmdsize - name_offset).decode() |
|
2276 |
load = load[:load.index('\0')] |
|
2277 |
# If the string is what is being replaced, overwrite it. |
|
2278 |
if load == what: |
|
2279 |
file.seek(where + name_offset, os.SEEK_SET) |
|
2280 |
file.write(value.encode() + '\0'.encode()) |
|
2281 |
# Seek to the next command |
|
2282 |
file.seek(where + cmdsize, os.SEEK_SET) |
|
2283 |
||
2284 |
def do_file(file, offset=0, size=maxint): |
|
2285 |
file = fileview(file, offset, size) |
|
2286 |
# Read magic number |
|
2287 |
magic = read_data(file, BIG_ENDIAN) |
|
2288 |
if magic == FAT_MAGIC: |
|
2289 |
# Fat binaries contain nfat_arch Mach-O binaries |
|
2290 |
nfat_arch = read_data(file, BIG_ENDIAN) |
|
2291 |
for n in range(nfat_arch): |
|
2292 |
# Read arch header |
|
2293 |
cputype, cpusubtype, offset, size, align = read_data(file, BIG_ENDIAN, 5) |
|
2294 |
do_file(file, offset, size) |
|
2295 |
elif magic == MH_MAGIC: |
|
2296 |
do_macho(file, 32, BIG_ENDIAN) |
|
2297 |
elif magic == MH_CIGAM: |
|
2298 |
do_macho(file, 32, LITTLE_ENDIAN) |
|
2299 |
elif magic == MH_MAGIC_64: |
|
2300 |
do_macho(file, 64, BIG_ENDIAN) |
|
2301 |
elif magic == MH_CIGAM_64: |
|
2302 |
do_macho(file, 64, LITTLE_ENDIAN) |
|
2303 |
||
2304 |
assert(len(what) >= len(value)) |
|
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2305 |
|
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2306 |
with open(path, 'r+b') as f: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2307 |
do_file(f) |
3 | 2308 |
|
2309 |
||
2310 |
if __name__ == '__main__': |
|
2311 |
main() |
|
2312 |
||
191
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2313 |
# TODO: |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2314 |
# Copy python.exe.manifest |
38be6b00f568
Upgrade ldt + elasticsearch after upgrade to elesticsearch 2.2 + new version
ymh <ymh.work@gmail.com>
parents:
88
diff
changeset
|
2315 |
# Monkeypatch distutils.sysconfig |