From 3661b29dc3efab4f62ce386e763e5829b740f572 Mon Sep 17 00:00:00 2001 From: "glatzor@ubuntu.com" <> Date: Thu, 10 Aug 2006 12:36:00 +0200 Subject: * Convert the download size to a nice and well readalbe unit --- UpdateManager/UpdateManager.py | 28 +++++++++++++++++++++++----- 1 file changed, 23 insertions(+), 5 deletions(-) (limited to 'UpdateManager') diff --git a/UpdateManager/UpdateManager.py b/UpdateManager/UpdateManager.py index 7ba9f934..e551d8f4 100644 --- a/UpdateManager/UpdateManager.py +++ b/UpdateManager/UpdateManager.py @@ -43,6 +43,7 @@ import os import os.path import urllib2 import re +import locale import tempfile import pango import subprocess @@ -589,14 +590,31 @@ class UpdateManager(SimpleGladeApp): self.remove_update(pkg) iter = self.store.iter_next(iter) + def humanize_size(self, bytes): + """ + Convert a given size in bytes to a nicer better readable unit + """ + if bytes == 0: + # TRANSLATORS: download size is 0 + return _("None") + elif bytes < 1024: + # TRANSLATORS: download size of very small updates + return _("1 KB") + elif bytes < 1024 * 1024: + # TRANSLATORS: download size of small updates, e.g. "250 KB" + return locale.format(_("%.0f KB"), bytes/1024) + else: + # TRANSLATORS: download size of updates, e.g. "2.3 MB" + return locale.format(_("%.1f MB"), bytes / 1024 / 1024) + def remove_update(self, pkg): name = pkg.name if name in self.packages: self.packages.remove(name) self.dl_size -= pkg.packageSize # TRANSLATORS: b stands for Bytes - self.label_downsize.set_markup(_("Download size: %sb" % \ - apt_pkg.SizeToStr(self.dl_size))) + self.label_downsize.set_markup(_("Download size: %s" % \ + self.humanize_size(self.dl_size))) if len(self.packages) == 0: self.button_install.set_sensitive(False) @@ -606,7 +624,7 @@ class UpdateManager(SimpleGladeApp): self.packages.append(name) self.dl_size += pkg.packageSize self.label_downsize.set_markup(_("Download size: %s" % \ - apt_pkg.SizeToStr(self.dl_size))) + self.humanize_size(self.dl_size))) if len(self.packages) > 0: self.button_install.set_sensitive(True) @@ -629,7 +647,7 @@ class UpdateManager(SimpleGladeApp): "You can install %s updates", self.list.num_updates) % \ self.list.num_updates + "" - text_download = _("Download size: %s") % apt_pkg.SizeToStr(self.dl_size) + text_download = _("Download size: %s") % self.humanize_size(self.dl_size) self.notebook_details.set_sensitive(True) self.treeview_update.set_sensitive(True) self.button_install.grab_default() @@ -781,7 +799,7 @@ class UpdateManager(SimpleGladeApp): else: contents += _("Version %s") % pkg.candidateVersion #TRANSLATORS: the b stands for Bytes - contents += " " + _("(Size: %sb)") % apt.SizeToStr(pkg.packageSize) + contents += " " + _("(Size: %s)") % self.humanize_size(pkg.packageSize) contents += "" iter = self.store.append([True, contents, pkg.name, pkg]) -- cgit v1.2.3 From a53e49c46faae31eccd7e65b8ffbcb91fbcaf18a Mon Sep 17 00:00:00 2001 From: "glatzor@ubuntu.com" <> Date: Fri, 11 Aug 2006 16:47:33 +0200 Subject: * no need to convert the path to a string in call of toggled * support row activation (pressing space) to toggle updates --- UpdateManager/UpdateManager.py | 10 ++++++++-- data/glade/UpdateManager.glade | 1 + 2 files changed, 9 insertions(+), 2 deletions(-) (limited to 'UpdateManager') diff --git a/UpdateManager/UpdateManager.py b/UpdateManager/UpdateManager.py index e551d8f4..78348e60 100644 --- a/UpdateManager/UpdateManager.py +++ b/UpdateManager/UpdateManager.py @@ -730,9 +730,9 @@ class UpdateManager(SimpleGladeApp): self.window_main.set_sensitive(True) self.window_main.window.set_cursor(None) - def toggled(self, renderer, path_string): + def toggled(self, renderer, path): """ a toggle button in the listview was toggled """ - iter = self.store.get_iter_from_string(path_string) + iter = self.store.get_iter(path) if self.store.get_value(iter, LIST_INSTALL): self.store.set_value(iter, LIST_INSTALL, False) self.remove_update(self.store.get_value(iter, LIST_PKG)) @@ -740,6 +740,12 @@ class UpdateManager(SimpleGladeApp): self.store.set_value(iter, LIST_INSTALL, True) self.add_update(self.store.get_value(iter, LIST_PKG)) + def on_treeview_update_row_activated(self, treeview, path, column, *args): + """ + If an update row was activated (by pressing space), toggle the + install check box + """ + self.toggled(None, path) def exit(self): """ exit the application, save the state """ diff --git a/data/glade/UpdateManager.glade b/data/glade/UpdateManager.glade index 1221e78c..372be566 100644 --- a/data/glade/UpdateManager.glade +++ b/data/glade/UpdateManager.glade @@ -233,6 +233,7 @@ updates + -- cgit v1.2.3 From 7f6bff5a191c2bb563198f20d1c2803f5054464b Mon Sep 17 00:00:00 2001 From: Michael Vogt Date: Thu, 24 Aug 2006 12:33:48 +0200 Subject: * merged with the latest upload --- UpdateManager/UpdateManager.py | 33 +++++++++++++++++++++++++++++++-- debian/changelog | 7 ++++++- 2 files changed, 37 insertions(+), 3 deletions(-) (limited to 'UpdateManager') diff --git a/UpdateManager/UpdateManager.py b/UpdateManager/UpdateManager.py index a1eda861..38cffc39 100644 --- a/UpdateManager/UpdateManager.py +++ b/UpdateManager/UpdateManager.py @@ -712,6 +712,9 @@ class UpdateManager(SimpleGladeApp): # don't display apt-listchanges, we already showed the changelog os.environ["APT_LISTCHANGES_FRONTEND"]="none" + # Do not suspend during the update process + (dev, cookie) = self.inhibit_sleep() + # set window to insensitive self.window_main.set_sensitive(False) self.window_main.window.set_cursor(gtk.gdk.Cursor(gtk.gdk.WATCH)) @@ -726,18 +729,44 @@ class UpdateManager(SimpleGladeApp): while gtk.events_pending(): gtk.main_iteration() self.fillstore() + + # Allow suspend after synaptic is finished + if cookie != False: + self.allow_sleep(dev, cookie) self.window_main.set_sensitive(True) self.window_main.window.set_cursor(None) + def inhibit_sleep(self): + """Send a dbus signal to gnome-power-manager to not suspend + the system""" + try: + bus = dbus.Bus(dbus.Bus.TYPE_SESSION) + devobj = bus.get_object('org.gnome.PowerManager', + '/org/gnome/PowerManager') + dev = dbus.Interface(devobj, "org.gnome.PowerManager") + cookie = dev.Inhibit('UpdateManager', 'Updating system') + return (dev, cookie) + except Exception, e: + print "could not send the dbus Inhibit signal: %s" % e + return (False, False) + + def allow_sleep(self, dev, cookie): + """Send a dbus signal to gnome-power-manager to allow a suspending + the system""" + dev.UnInhibit(cookie) + def toggled(self, renderer, path): """ a toggle button in the listview was toggled """ iter = self.store.get_iter(path) + pkg = self.store.get_value(iter, LIST_PKG) + if pkg is None: + return if self.store.get_value(iter, LIST_INSTALL): self.store.set_value(iter, LIST_INSTALL, False) - self.remove_update(self.store.get_value(iter, LIST_PKG)) + self.remove_update(pkg) else: self.store.set_value(iter, LIST_INSTALL, True) - self.add_update(self.store.get_value(iter, LIST_PKG)) + self.add_update(pkg) def on_treeview_update_row_activated(self, treeview, path, column, *args): """ diff --git a/debian/changelog b/debian/changelog index 9de7e07a..f03a4583 100644 --- a/debian/changelog +++ b/debian/changelog @@ -2,8 +2,13 @@ update-manager (0.44.3) edgy; urgency=low * help/C/update-manager-C.omf: - fix url (thanks to daniel holbach, lp: #45548) + * show the units better + * don't jump around on row activation + (thanks to Sebastian Heinlein) + * send "inhibit sleep" to power-manager while applying + updates (lp #40697) - -- + -- Michael Vogt Tue, 15 Aug 2006 18:06:53 +0200 update-manager (0.44.2) edgy; urgency=low -- cgit v1.2.3 From 558f70b24693a1692be2ab79c4047af762f9e010 Mon Sep 17 00:00:00 2001 From: Michael Vogt Date: Thu, 24 Aug 2006 14:23:19 +0200 Subject: * properly added -proposed --- UpdateManager/UpdateManager.py | 5 +++-- data/channels/Ubuntu.info.in | 14 ++++++++++++++ debian/changelog | 9 +++++++++ 3 files changed, 26 insertions(+), 2 deletions(-) (limited to 'UpdateManager') diff --git a/UpdateManager/UpdateManager.py b/UpdateManager/UpdateManager.py index 38cffc39..3e958db0 100644 --- a/UpdateManager/UpdateManager.py +++ b/UpdateManager/UpdateManager.py @@ -219,8 +219,9 @@ class UpdateList: " of Ubuntu"), 10), ("%s-updates" % dist, "Ubuntu", _("Recommended updates of " "Ubuntu"), 9), - ("%s-backports" % dist, "Ubuntu", _("Backports of Ubuntu"), 8), - (dist, "Ubuntu", _("Updates of Ubuntu"), 7)] + ("%s-proposed" % dist, "Ubuntu", _("Proposed updates for Ubuntu"), 8), + ("%s-backports" % dist, "Ubuntu", _("Backports of Ubuntu"), 7), + (dist, "Ubuntu", _("Updates of Ubuntu"), 6)] self.pkgs = {} self.matcher = {} diff --git a/data/channels/Ubuntu.info.in b/data/channels/Ubuntu.info.in index f3eb60d6..5631e93b 100644 --- a/data/channels/Ubuntu.info.in +++ b/data/channels/Ubuntu.info.in @@ -48,6 +48,13 @@ BaseURI: http://archive.ubuntu.com/ubuntu/ MatchURI: archive.ubuntu.com/ubuntu/ _Description: Recommended updates +Suite: edgy-proposed +ParentSuite: edgy +RepositoryType: deb +BaseURI: http://archive.ubuntu.com/ubuntu/ +MatchURI: archive.ubuntu.com/ubuntu/ +_Description: Proposed updates + Suite: edgy-backports ParentSuite: edgy RepositoryType: deb @@ -103,6 +110,13 @@ BaseURI: http://archive.ubuntu.com/ubuntu/ MatchURI: archive.ubuntu.com/ubuntu/ _Description: Recommended updates +Suite: dapper-proposed +ParentSuite: dapper +RepositoryType: deb +BaseURI: http://archive.ubuntu.com/ubuntu/ +MatchURI: archive.ubuntu.com/ubuntu/ +_Description: Proposed updates + Suite: dapper-backports ParentSuite: dapper RepositoryType: deb diff --git a/debian/changelog b/debian/changelog index f03a4583..3f60cb20 100644 --- a/debian/changelog +++ b/debian/changelog @@ -1,3 +1,12 @@ +update-manager (0.44.4) edgy; urgency=low + + * SoftwareProperties/SoftwareProperties.py: + - don't bomb when searching for the mirror (lp: #57015) + * UpdateManager/UpdateManager.py: + - added "%s-proposed" to the list of known origins + + -- Michael Vogt Thu, 24 Aug 2006 13:00:23 +0200 + update-manager (0.44.3) edgy; urgency=low * help/C/update-manager-C.omf: -- cgit v1.2.3