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:
parent
e12181b11d
commit
68cf974c78
@ -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()
|
||||||
|
Loading…
Reference in New Issue
Block a user