summaryrefslogtreecommitdiff
path: root/portato/gui
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--portato/gui/slots.py42
-rw-r--r--portato/gui/windows/main.py36
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