aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rwxr-xr-xlib/isodumper.py34
1 files changed, 16 insertions, 18 deletions
diff --git a/lib/isodumper.py b/lib/isodumper.py
index 209da2c..a798105 100755
--- a/lib/isodumper.py
+++ b/lib/isodumper.py
@@ -58,7 +58,7 @@ def find_devices():
class IsoDumper:
- def __init__(self,user):
+ def __init__(self):
APP="isodumper"
DIR="/usr/share/locale"
RELEASE="v0.32"
@@ -68,9 +68,6 @@ class IsoDumper:
gtk.glade.bindtextdomain(APP, DIR)
gtk.glade.textdomain(APP)
- # for the localisation of log file
- self.user=user
-
# get glade tree
self.gladefile = "/usr/share/isodumper/isodumper.glade"
self.wTree = gtk.glade.XML(self.gladefile)
@@ -112,7 +109,6 @@ class IsoDumper:
"on_main_dialog_delete_event" : self.confirm_close,
"on_cancel_button_clicked" : self.confirm_close,
"on_emergency_button_clicked" : self.restore,
- "on_success_button_clicked" : self.close,
"on_confirm_cancel_button_clicked": self.restore,
"on_filechooserbutton_file_set" : self.activate_devicelist,
# "on_detail_expander_activate" : self.expander_control,
@@ -162,8 +158,8 @@ class IsoDumper:
def backup_sel(self,widget):
if self.backup_bname.get_current_folder_uri() == None :
- self.backup_bname.set_current_folder_uri('file:///home/'+self.user)
- self.backup_bname.set_current_name(self.device_name+".iso")
+ self.backup_bname.set_current_folder_uri('file:///home/'+os.getlogin())
+ self.backup_bname.set_current_name(self.device_name+".img")
self.choose.run()
def backup_cancel(self,widget):
@@ -384,10 +380,14 @@ class IsoDumper:
while gtk.events_pending():
gtk.main_iteration(True)
steps=range(0, b+1, b/100)
+ steps.append(b)
indice=1
written=0
ncuts=b/bs
- for i in xrange(0,ncuts):
+ while ncuts <= 100:
+ bs=bs/2
+ ncuts=b/bs
+ for i in xrange(0,ncuts+1):
try:
buf=ifc.read(bs)
except:
@@ -398,15 +398,14 @@ class IsoDumper:
except:
self.logger(_("Writing error."))
self.emergency()
- written= written+bs
+ written+=len(buf)
if written > steps[indice]:
if indice%1==0:
self.logger(_('Wrote: ')+str(indice)+'% '+str(written)+' bytes')
mark = self.log.create_mark("end", self.log.get_end_iter(), False)
self.logview.scroll_to_mark(mark, 0.05, True, 0.0, 1.0)
progress.set_fraction(float(indice)/100)
- while (written > steps[indice]):
- indice +=1
+ indice +=1
try:
os.fsync(ofc)
except:
@@ -425,6 +424,7 @@ class IsoDumper:
yield False
def success(self):
+ self.operation=False
dialog = self.wTree.get_widget("success_dialog")
self.final_unsensitive()
resp = dialog.run()
@@ -475,13 +475,13 @@ class IsoDumper:
def write_logfile(self):
start = self.log.get_start_iter()
end = self.log.get_end_iter()
+ user = os.getlogin()
import pwd
- pw = pwd.getpwnam(self.user)
+ pw = pwd.getpwnam(user)
uid = pw.pw_uid
gid=pw.pw_gid
- if (self.user != 'root') and (self.user !=''):
- logpath='/home/'+self.user+'/.isodumper'
- print gid
+ if (user != 'root') and (user !=''):
+ logpath='/home/'+user+'/.isodumper'
os.setgid(gid)
os.setuid(uid)
if not(os.path.isdir(logpath)):
@@ -527,7 +527,5 @@ class IsoDumper:
dialog.hide()
if __name__ == "__main__":
- import sys
- user=sys.argv[1]
- app = IsoDumper(user)
+ app = IsoDumper()
gtk.main()