Commit a229fc69 authored by tarek's avatar tarek

fixed another sandbox viloation issue

--HG--
branch : distribute
extra : rebase_source : 9f4bc3640cd4f76834682b567ce4c7e7a14e59f7
parent 0b112ddd
...@@ -6,6 +6,7 @@ CHANGES ...@@ -6,6 +6,7 @@ CHANGES
0.6.11 0.6.11
------ ------
* Found another case of SandboxViolation - fixed
------ ------
......
...@@ -203,36 +203,18 @@ def download_setuptools(version=DEFAULT_VERSION, download_base=DEFAULT_URL, ...@@ -203,36 +203,18 @@ def download_setuptools(version=DEFAULT_VERSION, download_base=DEFAULT_URL,
dst.close() dst.close()
return os.path.realpath(saveto) return os.path.realpath(saveto)
def _patch_file(path, content):
"""Will backup the file then patch it"""
existing_content = open(path).read()
if existing_content == content:
# already patched
log.warn('Already patched.')
return False
log.warn('Patching...')
_rename_path(path)
f = open(path, 'w')
try:
f.write(content)
finally:
f.close()
return True
def _same_content(path, content):
return open(path).read() == content
def _no_sandbox(function): def _no_sandbox(function):
def __no_sandbox(*args, **kw): def __no_sandbox(*args, **kw):
try: try:
from setuptools.sandbox import DirectorySandbox from setuptools.sandbox import DirectorySandbox
if not hasattr(DirectorySandbox, '_old'):
def violation(*args): def violation(*args):
pass pass
DirectorySandbox._old = DirectorySandbox._violation DirectorySandbox._old = DirectorySandbox._violation
DirectorySandbox._violation = violation DirectorySandbox._violation = violation
patched = True patched = True
else:
patched = False
except ImportError: except ImportError:
patched = False patched = False
...@@ -246,12 +228,33 @@ def _no_sandbox(function): ...@@ -246,12 +228,33 @@ def _no_sandbox(function):
return __no_sandbox return __no_sandbox
@_no_sandbox @_no_sandbox
def _patch_file(path, content):
"""Will backup the file then patch it"""
existing_content = open(path).read()
if existing_content == content:
# already patched
log.warn('Already patched.')
return False
log.warn('Patching...')
_rename_path(path)
f = open(path, 'w')
try:
f.write(content)
finally:
f.close()
return True
def _same_content(path, content):
return open(path).read() == content
def _rename_path(path): def _rename_path(path):
new_name = path + '.OLD.%s' % time.time() new_name = path + '.OLD.%s' % time.time()
log.warn('Renaming %s into %s', path, new_name) log.warn('Renaming %s into %s', path, new_name)
os.rename(path, new_name) os.rename(path, new_name)
return new_name return new_name
@_no_sandbox
def _remove_flat_installation(placeholder): def _remove_flat_installation(placeholder):
if not os.path.isdir(placeholder): if not os.path.isdir(placeholder):
log.warn('Unkown installation at %s', placeholder) log.warn('Unkown installation at %s', placeholder)
...@@ -319,6 +322,7 @@ def _create_fake_setuptools_pkg_info(placeholder): ...@@ -319,6 +322,7 @@ def _create_fake_setuptools_pkg_info(placeholder):
finally: finally:
f.close() f.close()
@_no_sandbox
def _patch_egg_dir(path): def _patch_egg_dir(path):
# let's check if it's already patched # let's check if it's already patched
pkg_info = os.path.join(path, 'EGG-INFO', 'PKG-INFO') pkg_info = os.path.join(path, 'EGG-INFO', 'PKG-INFO')
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment