diff options
Diffstat (limited to 'portato/gui')
-rw-r--r-- | portato/gui/slots.py | 42 | ||||
-rw-r--r-- | portato/gui/windows/main.py | 36 |
2 files changed, 49 insertions, 29 deletions
diff --git a/portato/gui/slots.py b/portato/gui/slots.py new file mode 100644 index 0000000..2ad4c01 --- /dev/null +++ b/portato/gui/slots.py @@ -0,0 +1,42 @@ +# -*- coding: utf-8 -*- +# +# File: portato/gui/slots.py +# This file is part of the Portato-Project, a graphical portage-frontend. +# +# Copyright (C) 2006-2009 René 'Necoro' Neumann +# This is free software. You may redistribute copies of it under the terms of +# the GNU General Public License version 2. +# There is NO WARRANTY, to the extent permitted by law. +# +# Written by René 'Necoro' Neumann <necoro@necoro.net> + +from __future__ import absolute_import, with_statement + +import gtk +from ...plugin import WidgetSlot # other modules might import WidgetSlot from here + +class PluginMenuSlot (WidgetSlot): + + def __init__ (self, tree): + WidgetSlot.__init__(self, self.create_action, "Plugin Menu") + + self.ctr = 0 # counter for the plugin actions + self.uim = tree.get_widget("uimanager") + self.ag = tree.get_widget("pluginActionGroup") + + def create_action (self, label): + aname = "plugin%d" % self.ctr + a = gtk.Action(aname, label, None, None) + self.ctr += 1 + + return a + + def add (self, widget): + action = widget.widget + self.ag.add_action(action) + + # add to UI + mid = self.uim.new_merge_id() + self.uim.add_ui(mid, "ui/menubar/pluginMenu", action.get_name(), action.get_name(), gtk.UI_MANAGER_MENUITEM, False) + + self.uim.ensure_update() diff --git a/portato/gui/windows/main.py b/portato/gui/windows/main.py index 290fe6a..1758033 100644 --- a/portato/gui/windows/main.py +++ b/portato/gui/windows/main.py @@ -23,13 +23,17 @@ from collections import defaultdict # our backend stuff from ...backend import flags, system # must be the first to avoid circular deps -from ... import get_listener, plugin +from ... import get_listener from ...helper import debug, warning, error, info from ...session import Session from ...db import Database from ...constants import CONFIG_LOCATION, VERSION, APP_ICON from ...backend.exceptions import PackageNotFoundException, BlockedException, VersionsNotFoundException +# plugin stuff +from ... import plugin +from .. import slots + # more GUI stuff from ..utils import Config, GtkThread, get_color from ..queue import EmergeQueue @@ -50,32 +54,6 @@ from .preference import PreferenceWindow from .search import SearchWindow from .update import UpdateWindow -class PluginMenuSlot (plugin.WidgetSlot): - - def __init__ (self, tree): - plugin.WidgetSlot.__init__(self, self.create_action, "Plugin Menu") - - self.ctr = 0 # counter for the plugin actions - self.uim = tree.get_widget("uimanager") - self.ag = tree.get_widget("pluginActionGroup") - - def create_action (self, label): - aname = "plugin%d" % self.ctr - a = gtk.Action(aname, label, None, None) - self.ctr += 1 - - return a - - def add (self, widget): - action = widget.widget - self.ag.add_action(action) - - # add to UI - mid = self.uim.new_merge_id() - self.uim.add_ui(mid, "ui/menubar/pluginMenu", action.get_name(), action.get_name(), gtk.UI_MANAGER_MENUITEM, False) - - self.uim.ensure_update() - class PackageTable: """A window with data about a specfic package.""" @@ -586,9 +564,9 @@ class MainWindow (Window): splash(_("Loading Plugins")) optionsHB = self.tree.get_widget("optionsHB") - plugin.WidgetSlot(gtk.CheckButton, "Emerge Options", add = lambda w: optionsHB.pack_end(w.widget)) + slots.WidgetSlot(gtk.CheckButton, "Emerge Options", add = lambda w: optionsHB.pack_end(w.widget)) - PluginMenuSlot(self.tree) + slots.PluginMenuSlot(self.tree) plugin.load_plugins() # session |