summaryrefslogtreecommitdiff
path: root/pluma/pluma-window.c
diff options
context:
space:
mode:
authormonsta <[email protected]>2016-12-01 21:42:01 +0300
committermonsta <[email protected]>2016-12-05 15:05:10 +0300
commit52fd78ddfcbe35507aee9122fed0f18c99407c89 (patch)
tree6f3dd1b679a503f63ec32d14ef3de383b87904a6 /pluma/pluma-window.c
parent0389542290dc655a68cc352df12bd76ac796bbc7 (diff)
downloadpluma-52fd78ddfcbe35507aee9122fed0f18c99407c89.tar.bz2
pluma-52fd78ddfcbe35507aee9122fed0f18c99407c89.tar.xz
port plugin system to libpeas
backported from gedit with a few changes upstream commits for reference: https://git.gnome.org/browse/gedit/commit/?id=dbc98da7fda69981e61c5764af50c72b756eb2cc https://git.gnome.org/browse/gedit/commit/?id=2ae732a53ef08145c06909dc675134573c8c2e6d https://git.gnome.org/browse/gedit/commit/?id=6cd4936fb3aa6ca44a7c85888c6aad6c02b0f983 https://git.gnome.org/browse/gedit/commit/?id=041399d3d09389f951af8db4f5b83d142a9ebe55 https://git.gnome.org/browse/gedit/commit/?id=da46f5d6cd9b727e23ec0ae79bb0a78419bb1363 https://git.gnome.org/browse/gedit/commit/?id=1d56b827f14096891bb03dbd5e8211fdad1331ad https://git.gnome.org/browse/gedit/commit/?id=e63de5a2396a56eeba46479a54628843538da29e
Diffstat (limited to 'pluma/pluma-window.c')
-rw-r--r--pluma/pluma-window.c76
1 files changed, 55 insertions, 21 deletions
diff --git a/pluma/pluma-window.c b/pluma/pluma-window.c
index d9e36a3a..8bff1509 100644
--- a/pluma/pluma-window.c
+++ b/pluma/pluma-window.c
@@ -40,6 +40,8 @@
#include <gio/gio.h>
#include <gtk/gtk.h>
#include <gtksourceview/gtksource.h>
+#include <libpeas/peas-activatable.h>
+#include <libpeas/peas-extension-set.h>
#include "pluma-ui.h"
#include "pluma-window.h"
@@ -175,7 +177,7 @@ pluma_window_dispose (GObject *object)
/* First of all, force collection so that plugins
* really drop some of the references.
*/
- pluma_plugins_engine_garbage_collect (pluma_plugins_engine_get_default ());
+ peas_engine_garbage_collect (PEAS_ENGINE (pluma_plugins_engine_get_default ()));
/* save the panes position and make sure to deactivate plugins
* for this window, but only once */
@@ -183,8 +185,12 @@ pluma_window_dispose (GObject *object)
{
save_panes_state (window);
- pluma_plugins_engine_deactivate_plugins (pluma_plugins_engine_get_default (),
- window);
+ /* Note that unreffing the extensions will automatically remove
+ all extensions which in turn will deactivate the extension */
+ g_object_unref (window->priv->extensions);
+
+ peas_engine_garbage_collect (PEAS_ENGINE (pluma_plugins_engine_get_default ()));
+
window->priv->dispose_has_run = TRUE;
}
@@ -232,7 +238,7 @@ pluma_window_dispose (GObject *object)
/* Now that there have broken some reference loops,
* force collection again.
*/
- pluma_plugins_engine_garbage_collect (pluma_plugins_engine_get_default ());
+ peas_engine_garbage_collect (PEAS_ENGINE (pluma_plugins_engine_get_default ()));
G_OBJECT_CLASS (pluma_window_parent_class)->dispose (object);
}
@@ -322,7 +328,7 @@ static void
pluma_window_tab_removed (PlumaWindow *window,
PlumaTab *tab)
{
- pluma_plugins_engine_garbage_collect (pluma_plugins_engine_get_default ());
+ peas_engine_garbage_collect (PEAS_ENGINE (pluma_plugins_engine_get_default ()));
}
static void
@@ -824,8 +830,7 @@ set_sensitivity_according_to_tab (PlumaWindow *window,
update_next_prev_doc_sensitivity (window, tab);
- pluma_plugins_engine_update_plugins_ui (pluma_plugins_engine_get_default (),
- window);
+ peas_extension_set_call (window->priv->extensions, "update_state", window);
}
static void
@@ -2685,8 +2690,7 @@ sync_name (PlumaTab *tab,
g_free (escaped_name);
g_free (tip);
- pluma_plugins_engine_update_plugins_ui (pluma_plugins_engine_get_default (),
- window);
+ peas_extension_set_call (window->priv->extensions, "update_state", window);
}
static PlumaWindow *
@@ -3077,8 +3081,7 @@ selection_changed (PlumaDocument *doc,
editable &&
gtk_text_buffer_get_has_selection (GTK_TEXT_BUFFER (doc)));
- pluma_plugins_engine_update_plugins_ui (pluma_plugins_engine_get_default (),
- window);
+ peas_extension_set_call (window->priv->extensions, "update_state", window);
}
static void
@@ -3087,8 +3090,7 @@ sync_languages_menu (PlumaDocument *doc,
PlumaWindow *window)
{
update_languages_menu (window);
- pluma_plugins_engine_update_plugins_ui (pluma_plugins_engine_get_default (),
- window);
+ peas_extension_set_call (window->priv->extensions, "update_state", window);
}
static void
@@ -3100,8 +3102,7 @@ readonly_changed (PlumaDocument *doc,
sync_name (window->priv->active_tab, NULL, window);
- pluma_plugins_engine_update_plugins_ui (pluma_plugins_engine_get_default (),
- window);
+ peas_extension_set_call (window->priv->extensions, "update_state", window);
}
static void
@@ -3109,8 +3110,7 @@ editable_changed (PlumaView *view,
GParamSpec *arg1,
PlumaWindow *window)
{
- pluma_plugins_engine_update_plugins_ui (pluma_plugins_engine_get_default (),
- window);
+ peas_extension_set_call (window->priv->extensions, "update_state", window);
}
static void
@@ -3322,8 +3322,7 @@ notebook_tab_removed (PlumaNotebook *notebook,
if (window->priv->num_tabs == 0)
{
- pluma_plugins_engine_update_plugins_ui (pluma_plugins_engine_get_default (),
- window);
+ peas_extension_set_call (window->priv->extensions, "update_state", window);
}
update_window_state (window);
@@ -3812,6 +3811,30 @@ add_notebook (PlumaWindow *window,
}
static void
+on_extension_added (PeasExtensionSet *extensions,
+ PeasPluginInfo *info,
+ PeasExtension *exten,
+ PlumaWindow *window)
+{
+ peas_extension_call (exten, "activate", window);
+}
+
+static void
+on_extension_removed (PeasExtensionSet *extensions,
+ PeasPluginInfo *info,
+ PeasExtension *exten,
+ PlumaWindow *window)
+{
+ peas_extension_call (exten, "deactivate", window);
+
+ /* Ensure update of ui manager, because we suspect it does something
+ * with expected static strings in the type module (when unloaded the
+ * strings don't exist anymore, and ui manager updates in an idle
+ * func) */
+ gtk_ui_manager_ensure_update (window->priv->manager);
+}
+
+static void
pluma_window_init (PlumaWindow *window)
{
GtkWidget *main_box;
@@ -3936,8 +3959,19 @@ pluma_window_init (PlumaWindow *window)
pluma_debug_message (DEBUG_WINDOW, "Update plugins ui");
- pluma_plugins_engine_activate_plugins (pluma_plugins_engine_get_default (),
- window);
+ window->priv->extensions = peas_extension_set_new (PEAS_ENGINE (pluma_plugins_engine_get_default ()),
+ PEAS_TYPE_ACTIVATABLE, "object", window, NULL);
+
+ peas_extension_set_call (window->priv->extensions, "activate");
+
+ g_signal_connect (window->priv->extensions,
+ "extension-added",
+ G_CALLBACK (on_extension_added),
+ window);
+ g_signal_connect (window->priv->extensions,
+ "extension-removed",
+ G_CALLBACK (on_extension_removed),
+ window);
/* set visibility of panes.
* This needs to be done after plugins activatation */