Misc fixes; better GlibURLDownloader error handling, fix GlibXMLRPCRequestHandler argument passing
This commit is contained in:
parent
66b7210481
commit
a5154aa011
@ -167,6 +167,8 @@ class GlibURLDownloader(gobject.GObject):
|
|||||||
|
|
||||||
__gsignals__ = {
|
__gsignals__ = {
|
||||||
'finished': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
|
'finished': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
|
||||||
|
([gobject.TYPE_PYOBJECT, gobject.TYPE_PYOBJECT])),
|
||||||
|
'error': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
|
||||||
([gobject.TYPE_PYOBJECT]))
|
([gobject.TYPE_PYOBJECT]))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -184,17 +186,19 @@ class GlibURLDownloader(gobject.GObject):
|
|||||||
|
|
||||||
def start(self):
|
def start(self):
|
||||||
self._info = urllib.urlopen(self._url)
|
self._info = urllib.urlopen(self._url)
|
||||||
self._suggested_fname = _get_filename_from_headers(info.headers)
|
self._suggested_fname = self._get_filename_from_headers(self._info.headers)
|
||||||
import tempfile
|
import tempfile
|
||||||
garbage, path = urllib.splittype(url)
|
garbage, path = urllib.splittype(self._url)
|
||||||
garbage, path = urllib.splithost(path or "")
|
garbage, path = urllib.splithost(path or "")
|
||||||
path, garbage = urllib.splitquery(path or "")
|
path, garbage = urllib.splitquery(path or "")
|
||||||
path, garbage = urllib.splitattr(path or "")
|
path, garbage = urllib.splitattr(path or "")
|
||||||
suffix = os.path.splitext(path)[1]
|
suffix = os.path.splitext(path)[1]
|
||||||
(outf, self._fname) = tempfile.mkstemp(suffix=suffix, dir=self._destdir)
|
(self._outf, self._fname) = tempfile.mkstemp(suffix=suffix, dir=self._destdir)
|
||||||
|
|
||||||
fcntl.fcntl(self._info.fp.fileno(), fcntl.F_SETFD, os.O_NDELAY)
|
fcntl.fcntl(self._info.fp.fileno(), fcntl.F_SETFD, os.O_NDELAY)
|
||||||
self._srcid = gobject.io_add_watch(self._info.fp.fileno(), gobject.IO_IN, self._read_next_chunk)
|
self._srcid = gobject.io_add_watch(self._info.fp.fileno(),
|
||||||
|
gobject.IO_IN | gobject.IO_ERR,
|
||||||
|
self._read_next_chunk)
|
||||||
|
|
||||||
def _get_filename_from_headers(self, headers):
|
def _get_filename_from_headers(self, headers):
|
||||||
if not headers.has_key("Content-Disposition"):
|
if not headers.has_key("Content-Disposition"):
|
||||||
@ -213,17 +217,29 @@ class GlibURLDownloader(gobject.GObject):
|
|||||||
return fname
|
return fname
|
||||||
|
|
||||||
def _read_next_chunk(self, source, condition):
|
def _read_next_chunk(self, source, condition):
|
||||||
if not (condition & gobject.IO_IN):
|
if condition & gobject.IO_ERR:
|
||||||
self.cleanup()
|
self.cleanup()
|
||||||
os.remove(self._fname)
|
os.remove(self._fname)
|
||||||
self.emit("finished", None, None)
|
self.emit("error", "Error downloading file.")
|
||||||
return False
|
return False
|
||||||
|
elif not (condition & gobject.IO_IN):
|
||||||
|
# shouldn't get here, but...
|
||||||
|
return True
|
||||||
|
|
||||||
data = info.fp.read(self.CHUNK_SIZE)
|
try:
|
||||||
count = outf.write(data)
|
data = self._info.fp.read(self.CHUNK_SIZE)
|
||||||
if len(data) < self.CHUNK_SIZE:
|
count = os.write(self._outf, data)
|
||||||
|
if len(data) < self.CHUNK_SIZE:
|
||||||
|
self.cleanup()
|
||||||
|
self.emit("finished", self._fname, self._suggested_fname)
|
||||||
|
return False
|
||||||
|
if count < len(data):
|
||||||
|
self.cleanup()
|
||||||
|
self.emit("error", "Error writing to download file.")
|
||||||
|
return False
|
||||||
|
except Exception, err:
|
||||||
self.cleanup()
|
self.cleanup()
|
||||||
self.emit("finished", self._fname, self._suggested_fname)
|
self.emit("error", "Error downloading file: %s" % err)
|
||||||
return False
|
return False
|
||||||
return True
|
return True
|
||||||
|
|
||||||
@ -232,7 +248,9 @@ class GlibURLDownloader(gobject.GObject):
|
|||||||
gobject.source_remove(self._srcid)
|
gobject.source_remove(self._srcid)
|
||||||
self._srcid = 0
|
self._srcid = 0
|
||||||
del self._info
|
del self._info
|
||||||
self._outf.close()
|
self._info = None
|
||||||
|
os.close(self._outf)
|
||||||
|
self._outf = None
|
||||||
|
|
||||||
|
|
||||||
class GlibXMLRPCRequestHandler(SimpleXMLRPCServer.SimpleXMLRPCRequestHandler):
|
class GlibXMLRPCRequestHandler(SimpleXMLRPCServer.SimpleXMLRPCRequestHandler):
|
||||||
@ -381,7 +399,10 @@ class GlibXMLRPCTransport(xmlrpclib.Transport):
|
|||||||
self.verbose = verbose
|
self.verbose = verbose
|
||||||
response = self._parse_response(h.getfile(), h._conn.sock)
|
response = self._parse_response(h.getfile(), h._conn.sock)
|
||||||
if reply_handler:
|
if reply_handler:
|
||||||
|
# Coerce to a list so we can append user data
|
||||||
response = response[0]
|
response = response[0]
|
||||||
|
if not isinstance(response, list):
|
||||||
|
response = [response]
|
||||||
response.append(user_data)
|
response.append(user_data)
|
||||||
gobject.idle_add(reply_handler, *response)
|
gobject.idle_add(reply_handler, *response)
|
||||||
return False
|
return False
|
||||||
|
Loading…
Reference in New Issue
Block a user