1
0
mirror of https://github.com/openSUSE/osc.git synced 2024-12-31 20:26:13 +01:00

Do not mmap the ar archive

There is really no need for a mmap here. Also, the comment in the
docstr does not apply/is nonsense (there is no performance gain).
This commit is contained in:
Marcus Huewe 2019-01-15 16:44:29 +01:00
parent e12181b11d
commit 68cf974c78

View File

@ -165,20 +165,9 @@ class Ar:
self.__file.read(hdr.size)) self.__file.read(hdr.size))
def read(self): def read(self):
"""reads in the archive. It tries to use mmap due to performance reasons (in case of large files)""" """reads in the archive."""
if not self.__file: if not self.__file:
import mmap
self.__file = open(self.filename, 'rb') self.__file = open(self.filename, 'rb')
try:
if sys.platform[:3] != 'win':
self.__file = mmap.mmap(self.__file.fileno(), os.path.getsize(self.__file.name), prot=mmap.PROT_READ)
else:
self.__file = mmap.mmap(self.__file.fileno(), os.path.getsize(self.__file.name))
except EnvironmentError as e:
if e.errno == 19 or ( hasattr(e, 'winerror') and e.winerror == 5 ):
print('cannot use mmap to read the file, falling back to the default io', file=sys.stderr)
else:
raise e
else: else:
self.__file.seek(0, os.SEEK_SET) self.__file.seek(0, os.SEEK_SET)
self._init_datastructs() self._init_datastructs()