X7ROOT File Manager
Current Path:
/lib/python2.7/site-packages/pip/utils
lib
/
python2.7
/
site-packages
/
pip
/
utils
/
??
..
??
__init__.py
(26.55 KB)
??
__init__.pyc
(27.08 KB)
??
__init__.pyo
(27.02 KB)
??
appdirs.py
(8.6 KB)
??
appdirs.pyc
(8.41 KB)
??
appdirs.pyo
(8.41 KB)
??
build.py
(1.28 KB)
??
build.pyc
(1.68 KB)
??
build.pyo
(1.68 KB)
??
deprecation.py
(2.18 KB)
??
deprecation.pyc
(2.26 KB)
??
deprecation.pyo
(2.26 KB)
??
encoding.py
(971 B)
??
encoding.pyc
(1.25 KB)
??
encoding.pyo
(1.25 KB)
??
filesystem.py
(899 B)
??
filesystem.pyc
(780 B)
??
filesystem.pyo
(780 B)
??
glibc.py
(2.87 KB)
??
glibc.pyc
(1.78 KB)
??
glibc.pyo
(1.78 KB)
??
hashes.py
(2.8 KB)
??
hashes.pyc
(3.87 KB)
??
hashes.pyo
(3.87 KB)
??
logging.py
(3.25 KB)
??
logging.pyc
(4.73 KB)
??
logging.pyo
(4.73 KB)
??
outdated.py
(5.85 KB)
??
outdated.pyc
(5.55 KB)
??
outdated.pyo
(5.55 KB)
??
packaging.py
(2.03 KB)
??
packaging.pyc
(2.4 KB)
??
packaging.pyo
(2.4 KB)
??
setuptools_build.py
(278 B)
??
setuptools_build.pyc
(347 B)
??
setuptools_build.pyo
(347 B)
??
ui.py
(11.33 KB)
??
ui.pyc
(11.41 KB)
??
ui.pyo
(11.34 KB)
Editing: hashes.py
from __future__ import absolute_import import hashlib from pip.exceptions import HashMismatch, HashMissing, InstallationError from pip.utils import read_chunks from pip._vendor.six import iteritems, iterkeys, itervalues # The recommended hash algo of the moment. Change this whenever the state of # the art changes; it won't hurt backward compatibility. FAVORITE_HASH = 'sha256' # Names of hashlib algorithms allowed by the --hash option and ``pip hash`` # Currently, those are the ones at least as collision-resistant as sha256. STRONG_HASHES = ['sha256', 'sha384', 'sha512'] class Hashes(object): """A wrapper that builds multiple hashes at once and checks them against known-good values """ def __init__(self, hashes=None): """ :param hashes: A dict of algorithm names pointing to lists of allowed hex digests """ self._allowed = {} if hashes is None else hashes def check_against_chunks(self, chunks): """Check good hashes against ones built from iterable of chunks of data. Raise HashMismatch if none match. """ gots = {} for hash_name in iterkeys(self._allowed): try: gots[hash_name] = hashlib.new(hash_name) except (ValueError, TypeError): raise InstallationError('Unknown hash name: %s' % hash_name) for chunk in chunks: for hash in itervalues(gots): hash.update(chunk) for hash_name, got in iteritems(gots): if got.hexdigest() in self._allowed[hash_name]: return self._raise(gots) def _raise(self, gots): raise HashMismatch(self._allowed, gots) def check_against_file(self, file): """Check good hashes against a file-like object Raise HashMismatch if none match. """ return self.check_against_chunks(read_chunks(file)) def check_against_path(self, path): with open(path, 'rb') as file: return self.check_against_file(file) def __nonzero__(self): """Return whether I know any known-good hashes.""" return bool(self._allowed) def __bool__(self): return self.__nonzero__() class MissingHashes(Hashes): """A workalike for Hashes used when we're missing a hash for a requirement It computes the actual hash of the requirement and raises a HashMissing exception showing it to the user. """ def __init__(self): """Don't offer the ``hashes`` kwarg.""" # Pass our favorite hash in to generate a "gotten hash". With the # empty list, it will never match, so an error will always raise. super(MissingHashes, self).__init__(hashes={FAVORITE_HASH: []}) def _raise(self, gots): raise HashMissing(gots[FAVORITE_HASH].hexdigest())
Upload File
Create Folder