aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorPapoteur <papoteur@mageialinux-online.org>2015-01-03 20:34:45 +0100
committerPapoteur <papoteur@mageialinux-online.org>2015-01-03 20:34:45 +0100
commitd49a14bd380b80cd472de9d5a2536a2bdddcba44 (patch)
treee31e995f7584ff72968df80314fb11b9dfb6461d /lib
parent79e2c5984aeb28daed218eb5066a995633205244 (diff)
downloadisodumper-d49a14bd380b80cd472de9d5a2536a2bdddcba44.tar
isodumper-d49a14bd380b80cd472de9d5a2536a2bdddcba44.tar.gz
isodumper-d49a14bd380b80cd472de9d5a2536a2bdddcba44.tar.bz2
isodumper-d49a14bd380b80cd472de9d5a2536a2bdddcba44.tar.xz
isodumper-d49a14bd380b80cd472de9d5a2536a2bdddcba44.zip
Better management of error cases
Diffstat (limited to 'lib')
-rwxr-xr-xlib/isodumper.py15
1 files changed, 12 insertions, 3 deletions
diff --git a/lib/isodumper.py b/lib/isodumper.py
index c39386f..92cec26 100755
--- a/lib/isodumper.py
+++ b/lib/isodumper.py
@@ -195,7 +195,7 @@ class IsoDumper:
self.user = user
# get glade tree
- self.gladefile = "../share/isodumper/isodumper.glade"
+ self.gladefile = "/usr/share/isodumper/isodumper.glade"
self.wTree = gtk.glade.XML(self.gladefile)
# get globally needed widgets
@@ -444,7 +444,8 @@ class IsoDumper:
gobject.idle_add(task.next)
while gtk.events_pending():
gtk.main_iteration(True)
- self.success()
+ if self.returncode==0:
+ self.success()
def do_write(self, widget):
write_button = self.wTree.get_widget("write_button")
@@ -478,6 +479,7 @@ class IsoDumper:
else:
self.emergency()
dialog.hide()
+ return
self.chooser.set_sensitive(False)
self.do_umount(target)
dialog.hide()
@@ -542,7 +544,8 @@ class IsoDumper:
gobject.idle_add(task.next)
while gtk.events_pending():
gtk.main_iteration(True)
- self.success()
+ if self.returncode == 0:
+ self.success()
else:
dialog.hide()
combo.set_sensitive(True)
@@ -582,12 +585,14 @@ class IsoDumper:
def raw_write(self, source, target, b):
self.operation=True
+
bs=4096*128
try:
ifc=io.open(source, "rb",1)
except:
self.logger(_('Reading error.')+ source)
self.emergency()
+ return
else:
try:
ofc= io.open(target, 'wb',0)
@@ -616,11 +621,13 @@ class IsoDumper:
except:
self.logger(_("Reading error."))
self.emergency()
+ return
try:
ofc.write(buf)
except:
self.logger(_("Writing error."))
self.emergency()
+ return
written+=len(buf)
if written > steps[indice]:
if indice%1==0:
@@ -634,6 +641,7 @@ class IsoDumper:
except:
self.logger(_("Writing error."))
self.emergency()
+ return
yield True
progress.set_fraction(1.0)
self.logger(_('Image ')+source.split('/')[-1]+_(' successfully written to ')+target)
@@ -713,6 +721,7 @@ class IsoDumper:
def emergency(self):
self.operation=False
+ self.returncode=1
self.final_unsensitive()
dialog = self.wTree.get_widget("emergency_dialog")
expander = self.wTree.get_widget("detail_expander")