From 77f10031f1019eb3628e30f5edb3da7699fb0f1f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Bili=C5=84ski?= Date: Tue, 3 Jun 2008 08:25:16 +0000 Subject: [PATCH] Added mechanism to successfully load plugins after GUI extension points have been created, e.g. when we want to modify ChatControl behaviour and objects of this class have already been created. Also: customized IPython console look --- src/gajim.py | 3 +++ src/plugins/pluginmanager.py | 44 ++++++++++++++++++++++++++++-------- 2 files changed, 37 insertions(+), 10 deletions(-) diff --git a/src/gajim.py b/src/gajim.py index d1d746401..19c98d5cd 100755 --- a/src/gajim.py +++ b/src/gajim.py @@ -3208,6 +3208,7 @@ class Interface: font = 'Lucida Console 9' else: font = 'Luxi Mono 10' + font="Terminus 10" window = gtk.Window() window.set_size_request(750,550) @@ -3217,6 +3218,8 @@ class Interface: view = IPythonView() view.modify_font(pango.FontDescription(font)) view.set_wrap_mode(gtk.WRAP_CHAR) + view.modify_base(gtk.STATE_NORMAL, gtk.gdk.color_parse("black")); + view.modify_text(gtk.STATE_NORMAL, gtk.gdk.color_parse("white")); sw.add(view) window.add(sw) window.show_all() diff --git a/src/plugins/pluginmanager.py b/src/plugins/pluginmanager.py index 0498b5fd3..14f174df7 100644 --- a/src/plugins/pluginmanager.py +++ b/src/plugins/pluginmanager.py @@ -52,7 +52,6 @@ class PluginManager(object): after GUI object creation) :todo: implement mechanism to dynamically deactive plugins (call plugin's deactivation handler) - ''' __metaclass__ = Singleton @@ -80,13 +79,18 @@ class PluginManager(object): ''' Registered GUI extension points. ''' + + self.gui_extension_points_handlers = {} + ''' + Registered handlers of GUI extension points. + ''' for path in gajim.PLUGINS_DIRS: self.plugins.extend(PluginManager.scan_dir_for_plugins(path)) log.debug('plugins: %s'%(self.plugins)) - self._activate_all_plugins() + #self._activate_all_plugins() log.debug('active: %s'%(self.active_plugins)) @@ -115,10 +119,17 @@ class PluginManager(object): ''' - log.debug(type(args)) - - if gui_extpoint_name in self.gui_extension_points: - for handlers in self.gui_extension_points[gui_extpoint_name]: + self._add_gui_extension_point_call_to_list(gui_extpoint_name, *args) + self._execute_all_handlers_of_gui_extension_point(gui_extpoint_name, *args) + + @log_calls('PluginManager') + def _add_gui_extension_point_call_to_list(self, gui_extpoint_name, *args): + self.gui_extension_points.setdefault(gui_extpoint_name, []).append(args) + + @log_calls('PluginManager') + def _execute_all_handlers_of_gui_extension_point(self, gui_extpoint_name, *args): + if gui_extpoint_name in self.gui_extension_points_handlers: + for handlers in self.gui_extension_points_handlers[gui_extpoint_name]: handlers[0](*args) @log_calls('PluginManager') @@ -132,15 +143,28 @@ class PluginManager(object): success = True - for gui_extpoint_name, gui_extpoint_handlers in \ - plugin_object.gui_extension_points.iteritems(): - self.gui_extension_points.setdefault(gui_extpoint_name, []).append( - gui_extpoint_handlers) + self._add_gui_extension_points_handlers_from_plugin(plugin_object) + self._handle_all_gui_extension_points_with_plugin(plugin_object) if success: self.active_plugins.append(plugin_object) return success + + @log_calls('PluginManager') + def _add_gui_extension_points_handlers_from_plugin(self, plugin_object): + for gui_extpoint_name, gui_extpoint_handlers in \ + plugin_object.gui_extension_points.iteritems(): + self.gui_extension_points_handlers.setdefault(gui_extpoint_name, []).append( + gui_extpoint_handlers) + + @log_calls('PluginManager') + def _handle_all_gui_extension_points_with_plugin(self, plugin_object): + for gui_extpoint_name, gui_extpoint_handlers in \ + plugin_object.gui_extension_points.iteritems(): + if gui_extpoint_name in self.gui_extension_points: + for gui_extension_point_args in self.gui_extension_points[gui_extpoint_name]: + gui_extpoint_handlers[0](*gui_extension_point_args) @log_calls('PluginManager') def _activate_all_plugins(self):