diff options
author | Papoteur <papoteur@mageialinux-online.org> | 2015-01-03 20:34:45 +0100 |
---|---|---|
committer | Papoteur <papoteur@mageialinux-online.org> | 2015-01-03 20:34:45 +0100 |
commit | d49a14bd380b80cd472de9d5a2536a2bdddcba44 (patch) | |
tree | e31e995f7584ff72968df80314fb11b9dfb6461d /lib | |
parent | 79e2c5984aeb28daed218eb5066a995633205244 (diff) | |
download | isodumper-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-x | lib/isodumper.py | 15 |
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") |