Import code from mousepad development repository which fixes a dbus

messages storm causing heavy CPU usage, memory allocation and disk
usage when working with multiple windows.

While here also import a GTK3 specific fix.

Ref.:
https://bugzilla.xfce.org/show_bug.cgi?id=14184
https://bugzilla.xfce.org/show_bug.cgi?id=12134

Reported by:	Erich Dollansky <freebsd.ed.lists@sumeritec.com>
Obtained from:	https://git.xfce.org/apps/mousepad/
MFH:		2018Q1
This commit is contained in:
Guido Falsi 2018-01-22 20:15:09 +00:00
parent aac6f41b92
commit 0163d504d8
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=459693
4 changed files with 112 additions and 32 deletions

View file

@ -3,7 +3,7 @@
PORTNAME= mousepad
PORTVERSION= 0.4.0
PORTREVISION= 2
PORTREVISION= 3
CATEGORIES= editors xfce
MASTER_SITES= XFCE/src/apps/${PORTNAME}/${PORTVERSION:R}
DIST_SUBDIR= xfce4

View file

@ -1,25 +1,48 @@
--- mousepad/mousepad-action-group.c.orig 2014-09-01 20:50:07 UTC
+++ mousepad/mousepad-action-group.c
@@ -283,7 +283,8 @@ void
mousepad_action_group_set_active_style_scheme (MousepadActionGroup *self,
GtkSourceStyleScheme *scheme)
{
- GtkAction *action;
+ GtkAction *action;
+ const gchar *scheme_name = NULL;
@@ -124,7 +124,7 @@ mousepad_action_group_class_init (MousepadActionGroupC
G_SIGNAL_RUN_LAST,
0, NULL, NULL,
g_cclosure_marshal_VOID__OBJECT,
- G_TYPE_NONE, 0,
+ G_TYPE_NONE, 1,
GTK_SOURCE_TYPE_LANGUAGE);
}
g_return_if_fail (MOUSEPAD_IS_ACTION_GROUP (self));
@@ -303,8 +304,11 @@ mousepad_action_group_set_active_style_s
@@ -302,11 +302,6 @@ mousepad_action_group_set_active_style_scheme (Mousepa
gtk_toggle_action_set_active (GTK_TOGGLE_ACTION (action), TRUE);
self->locked = FALSE;
/* update the setting when the active action is changed */
+ if (scheme != NULL)
+ scheme_name = gtk_source_style_scheme_get_id(scheme);
+
self->locked = TRUE;
- /* update the setting when the active action is changed */
- self->locked = TRUE;
- MOUSEPAD_SETTING_SET_STRING (COLOR_SCHEME, gtk_source_style_scheme_get_id (scheme));
+ MOUSEPAD_SETTING_SET_STRING (COLOR_SCHEME, scheme_name);
self->locked = FALSE;
- self->locked = FALSE;
-
g_object_notify (G_OBJECT (self), "active-style-scheme");
}
@@ -473,6 +468,8 @@ static void
mousepad_action_group_style_scheme_action_activate (MousepadActionGroup *self,
MousepadStyleSchemeAction *action)
{
+ const gchar *scheme_name = NULL;
+
/* only update the active action if we're not already in the process of
* setting it and the sender action is actually active */
if (! self->locked &&
@@ -481,7 +478,14 @@ mousepad_action_group_style_scheme_action_activate (Mo
GtkSourceStyleScheme *scheme;
scheme = mousepad_style_scheme_action_get_style_scheme (action);
- mousepad_action_group_set_active_style_scheme (self, scheme);
+
+ /* update the setting when the active action is changed */
+ if (scheme != NULL)
+ scheme_name = gtk_source_style_scheme_get_id(scheme);
+
+ self->locked = TRUE;
+ MOUSEPAD_SETTING_SET_STRING (COLOR_SCHEME, scheme_name);
+ self->locked = FALSE;
}
}

View file

@ -0,0 +1,11 @@
--- mousepad/mousepad-util.c.orig 2014-09-01 20:50:07 UTC
+++ mousepad/mousepad-util.c
@@ -1063,7 +1063,7 @@ mousepad_util_search (GtkTextBuffer *buffer,
GtkAction *
mousepad_util_find_related_action (GtkWidget *widget)
{
- GtkAction *action;
+ GtkAction *action = NULL;
g_return_val_if_fail (GTK_IS_WIDGET (widget), NULL);

View file

@ -1,18 +1,64 @@
--- mousepad/mousepad-window.c.orig 2014-09-01 20:58:02 UTC
+++ mousepad/mousepad-window.c
@@ -717,12 +717,13 @@ mousepad_window_action_group_style_schem
MousepadActionGroup *group)
{
GtkSourceStyleScheme *scheme;
@@ -712,32 +712,6 @@ mousepad_window_create_languages_menu (MousepadWindow
static void
-mousepad_window_action_group_style_scheme_changed (MousepadWindow *window,
- GParamSpec *pspec,
- MousepadActionGroup *group)
-{
- GtkSourceStyleScheme *scheme;
- const gchar *scheme_id;
+ const gchar *scheme_id = NULL;
gint npages, i;
/* get the new active language */
scheme = mousepad_action_group_get_active_style_scheme (group);
- gint npages, i;
-
- /* get the new active language */
- scheme = mousepad_action_group_get_active_style_scheme (group);
- scheme_id = gtk_source_style_scheme_get_id (scheme);
+ if (scheme != NULL)
+ scheme_id = gtk_source_style_scheme_get_id (scheme);
-
- /* update the color scheme on all the documents */
- npages = gtk_notebook_get_n_pages (GTK_NOTEBOOK (window->notebook));
- for (i = 0; i < npages; i++)
- {
- MousepadDocument *document;
-
- document = MOUSEPAD_DOCUMENT (gtk_notebook_get_nth_page (GTK_NOTEBOOK (window->notebook), i));
- mousepad_view_set_color_scheme (document->textview, scheme_id);
- }
-}
-
-
-
-static void
mousepad_window_create_style_schemes_menu (MousepadWindow *window)
{
GtkWidget *menu, *item;
@@ -751,13 +725,6 @@ mousepad_window_create_style_schemes_menu (MousepadWin
gtk_menu_item_set_submenu (GTK_MENU_ITEM (item), menu);
gtk_widget_show_all (menu);
gtk_widget_show (item);
-
- /* watch for activations of the style schemes actions */
- g_signal_connect_object (window->action_group,
- "notify::active-style-scheme",
- G_CALLBACK (mousepad_window_action_group_style_scheme_changed),
- window,
- G_CONNECT_SWAPPED);
}
/* update the color scheme on all the documents */
npages = gtk_notebook_get_n_pages (GTK_NOTEBOOK (window->notebook));
@@ -2122,7 +2089,14 @@ mousepad_window_notebook_create_window (GtkNotebook
g_object_ref (G_OBJECT (document));
/* remove the document from the active window */
+#if GTK_CHECK_VERSION (3, 16, 0)
+ gtk_notebook_detach_tab (GTK_CONTAINER (window->notebook), page);
+#else
+ /* crashes on GTK+ 3 somewhere between 3.10-3.16
+ * Fixed above using new function added in 3.16
+ * See: https://bugzilla.gnome.org/show_bug.cgi?id=744385 */
gtk_container_remove (GTK_CONTAINER (window->notebook), page);
+#endif
/* emit the new window with document signal */
g_signal_emit (G_OBJECT (window), window_signals[NEW_WINDOW_WITH_DOCUMENT], 0, document, x, y);