DownloadItem: Make fileobj public.
This commit is contained in:
parent
f250cd41ad
commit
5ad516a438
@ -59,7 +59,7 @@ class DownloadItem(QObject):
|
|||||||
_bytes_total: The total count of bytes.
|
_bytes_total: The total count of bytes.
|
||||||
None if the total is unknown.
|
None if the total is unknown.
|
||||||
_speed: The current download speed, in bytes per second.
|
_speed: The current download speed, in bytes per second.
|
||||||
_fileobj: The file object to download the file to.
|
fileobj: The file object to download the file to.
|
||||||
_filename: The filename of the download.
|
_filename: The filename of the download.
|
||||||
_is_cancelled: Whether the download was cancelled.
|
_is_cancelled: Whether the download was cancelled.
|
||||||
_speed_avg: A rolling average of speeds.
|
_speed_avg: A rolling average of speeds.
|
||||||
@ -99,7 +99,7 @@ class DownloadItem(QObject):
|
|||||||
samples = int(self.SPEED_AVG_WINDOW *
|
samples = int(self.SPEED_AVG_WINDOW *
|
||||||
(1000 / self.SPEED_REFRESH_INTERVAL))
|
(1000 / self.SPEED_REFRESH_INTERVAL))
|
||||||
self._speed_avg = collections.deque(maxlen=samples)
|
self._speed_avg = collections.deque(maxlen=samples)
|
||||||
self._fileobj = None
|
self.fileobj = None
|
||||||
self._filename = None
|
self._filename = None
|
||||||
self._is_cancelled = False
|
self._is_cancelled = False
|
||||||
self._do_delayed_write = False
|
self._do_delayed_write = False
|
||||||
@ -169,9 +169,9 @@ class DownloadItem(QObject):
|
|||||||
self._reply.abort()
|
self._reply.abort()
|
||||||
self._reply.deleteLater()
|
self._reply.deleteLater()
|
||||||
self._reply = None
|
self._reply = None
|
||||||
if self._fileobj is not None:
|
if self.fileobj is not None:
|
||||||
try:
|
try:
|
||||||
self._fileobj.close()
|
self.fileobj.close()
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
self.error.emit(e.strerror)
|
self.error.emit(e.strerror)
|
||||||
self.data_changed.emit()
|
self.data_changed.emit()
|
||||||
@ -218,8 +218,8 @@ class DownloadItem(QObject):
|
|||||||
if self._reply is not None:
|
if self._reply is not None:
|
||||||
self._reply.abort()
|
self._reply.abort()
|
||||||
self._reply.deleteLater()
|
self._reply.deleteLater()
|
||||||
if self._fileobj is not None:
|
if self.fileobj is not None:
|
||||||
self._fileobj.close()
|
self.fileobj.close()
|
||||||
if self._filename is not None and os.path.exists(self._filename):
|
if self._filename is not None and os.path.exists(self._filename):
|
||||||
os.remove(self._filename)
|
os.remove(self._filename)
|
||||||
self.finished.emit()
|
self.finished.emit()
|
||||||
@ -255,7 +255,7 @@ class DownloadItem(QObject):
|
|||||||
self.basename = filename
|
self.basename = filename
|
||||||
log.downloads.debug("Setting filename to {}".format(filename))
|
log.downloads.debug("Setting filename to {}".format(filename))
|
||||||
try:
|
try:
|
||||||
self._fileobj = open(self._filename, 'wb')
|
self.fileobj = open(self._filename, 'wb')
|
||||||
if self._do_delayed_write:
|
if self._do_delayed_write:
|
||||||
# Downloading to the buffer in RAM has already finished so we
|
# Downloading to the buffer in RAM has already finished so we
|
||||||
# write out the data and clean up now.
|
# write out the data and clean up now.
|
||||||
@ -273,9 +273,9 @@ class DownloadItem(QObject):
|
|||||||
log.downloads.debug("Doing delayed write...")
|
log.downloads.debug("Doing delayed write...")
|
||||||
self._do_delayed_write = False
|
self._do_delayed_write = False
|
||||||
if self._reply.isOpen():
|
if self._reply.isOpen():
|
||||||
self._fileobj.write(self._reply.readAll())
|
self.fileobj.write(self._reply.readAll())
|
||||||
if self.autoclose:
|
if self.autoclose:
|
||||||
self._fileobj.close()
|
self.fileobj.close()
|
||||||
self._reply.close()
|
self._reply.close()
|
||||||
self._reply.deleteLater()
|
self._reply.deleteLater()
|
||||||
self.successful = True
|
self.successful = True
|
||||||
@ -308,8 +308,8 @@ class DownloadItem(QObject):
|
|||||||
self.timer.stop()
|
self.timer.stop()
|
||||||
if self._is_cancelled:
|
if self._is_cancelled:
|
||||||
return
|
return
|
||||||
log.downloads.debug("Reply finished, fileobj {}".format(self._fileobj))
|
log.downloads.debug("Reply finished, fileobj {}".format(self.fileobj))
|
||||||
if self._fileobj is None:
|
if self.fileobj is None:
|
||||||
# We'll handle emptying the buffer and cleaning up as soon as the
|
# We'll handle emptying the buffer and cleaning up as soon as the
|
||||||
# filename is set.
|
# filename is set.
|
||||||
self._do_delayed_write = True
|
self._do_delayed_write = True
|
||||||
@ -321,11 +321,11 @@ class DownloadItem(QObject):
|
|||||||
@pyqtSlot()
|
@pyqtSlot()
|
||||||
def on_ready_read(self):
|
def on_ready_read(self):
|
||||||
"""Read available data and save file when ready to read."""
|
"""Read available data and save file when ready to read."""
|
||||||
if self._fileobj is None:
|
if self.fileobj is None:
|
||||||
# No filename has been set yet, so we don't empty the buffer.
|
# No filename has been set yet, so we don't empty the buffer.
|
||||||
return
|
return
|
||||||
try:
|
try:
|
||||||
self._fileobj.write(self._reply.readAll())
|
self.fileobj.write(self._reply.readAll())
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
self._die(e.strerror)
|
self._die(e.strerror)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user