summaryrefslogtreecommitdiff
path: root/UpdateManager/UpdateManager.py
diff options
context:
space:
mode:
authorglatzor@ubuntu.com <>2006-08-16 17:18:33 +0200
committerglatzor@ubuntu.com <>2006-08-16 17:18:33 +0200
commit7310859fbcb57e2e9fdf6b9ea39ab20d7eabfc52 (patch)
treeecc4137e926b86c31101562386b41eec742e8354 /UpdateManager/UpdateManager.py
parent6610fc16d211497195a02783ab52b3216bacce3c (diff)
parent141d62c9fdbd18027d79869ddf1ab54ad67e3b15 (diff)
downloadpython-apt-7310859fbcb57e2e9fdf6b9ea39ab20d7eabfc52.tar.gz
*merge with mvo
Diffstat (limited to 'UpdateManager/UpdateManager.py')
-rw-r--r--UpdateManager/UpdateManager.py49
1 files changed, 47 insertions, 2 deletions
diff --git a/UpdateManager/UpdateManager.py b/UpdateManager/UpdateManager.py
index 0962c6c8..5bdea61a 100644
--- a/UpdateManager/UpdateManager.py
+++ b/UpdateManager/UpdateManager.py
@@ -363,7 +363,8 @@ class UpdateManager(SimpleGladeApp):
self.treeview_update.append_column(column_install)
column_install.set_visible(True)
self.treeview_update.append_column(column)
- self.treeview_update.set_search_column(LIST_NAME)
+ self.treeview_update.set_search_column(LIST_NAME)
+ self.treeview_update.connect("button-press-event", self.show_context_menu)
# proxy stuff
@@ -543,6 +544,51 @@ class UpdateManager(SimpleGladeApp):
changes = self.cache.all_changes[name]
self.set_changes_buffer(changes_buffer, changes[0], name, changes[1])
+ def show_context_menu(self, widget, event):
+ """
+ Show a context menu if a right click was performed on an update entry
+ """
+ if event.type == gtk.gdk.BUTTON_PRESS and event.button == 3:
+ menu = gtk.Menu()
+ item_select_none = gtk.MenuItem(_("Select _None"))
+ item_select_none.connect("activate", self.select_none_updgrades)
+ menu.add(item_select_none)
+ if self.list.num_updates == 0 or len(self.packages) == 0:
+ item_select_none.set_property("sensitive", False)
+ item_select_all = gtk.MenuItem(_("Select _All"))
+ item_select_all.connect("activate", self.select_all_updgrades)
+ menu.add(item_select_all)
+ if self.list.num_updates == len(self.packages) or\
+ self.list.num_updates == 0:
+ item_select_all.set_property("sensitive", False)
+ menu.popup(None, None, None, 0, event.time)
+ menu.show_all()
+ return True
+
+ def select_all_updgrades(self, widget):
+ """
+ Select all updates
+ """
+ iter = self.store.get_iter_first()
+ while iter != None:
+ pkg = self.store.get_value(iter, LIST_PKG)
+ if pkg != None:
+ self.store.set_value(iter, LIST_INSTALL, True)
+ self.add_update(pkg)
+ iter = self.store.iter_next(iter)
+
+ def select_none_updgrades(self, widget):
+ """
+ Select none updates
+ """
+ iter = self.store.get_iter_first()
+ while iter != None:
+ pkg = self.store.get_value(iter, LIST_PKG)
+ if pkg != None:
+ self.store.set_value(iter, LIST_INSTALL, False)
+ self.remove_update(pkg)
+ iter = self.store.iter_next(iter)
+
def remove_update(self, pkg):
name = pkg.name
if name in self.packages:
@@ -607,7 +653,6 @@ class UpdateManager(SimpleGladeApp):
apt_pkg.PkgSystemUnLock()
except SystemError:
pass
-# cmd = ["gksu","--",
cmd = ["gksu", "--desktop", "/usr/share/applications/synaptic.desktop",
"--", "/usr/sbin/synaptic", "--hide-main-window",
"--non-interactive", "--parent-window-id", "%s" % (id) ]