Index: head/editors/mousepad/Makefile =================================================================== --- head/editors/mousepad/Makefile (revision 459692) +++ head/editors/mousepad/Makefile (revision 459693) @@ -1,30 +1,30 @@ # Created by: Oliver Lehmann # $FreeBSD$ PORTNAME= mousepad PORTVERSION= 0.4.0 -PORTREVISION= 2 +PORTREVISION= 3 CATEGORIES= editors xfce MASTER_SITES= XFCE/src/apps/${PORTNAME}/${PORTVERSION:R} DIST_SUBDIR= xfce4 MAINTAINER= xfce@FreeBSD.org COMMENT= Simple text editor for the Xfce Desktop LICENSE= GPLv2 LICENSE_FILE= ${WRKSRC}/COPYING LIB_DEPENDS= libdbus-glib-1.so:devel/dbus-glib GNU_CONFIGURE= yes USES= desktop-file-utils gettext gmake libtool perl5 pkgconfig tar:bzip2 USE_GNOME= glib20 intltool intlhack OPTIONS_DEFINE= GTK3 GTK3_CONFIGURE_ENABLE= gtk3 GTK3_USE= gnome=gtk30,gtksourceview3,dconf GTK3_USE_OFF= gnome=gtk20,gtksourceview2 GLIB_SCHEMAS= org.xfce.mousepad.gschema.xml .include Index: head/editors/mousepad/files/patch-mousepad_mousepad-action-group.c =================================================================== --- head/editors/mousepad/files/patch-mousepad_mousepad-action-group.c (revision 459692) +++ head/editors/mousepad/files/patch-mousepad_mousepad-action-group.c (revision 459693) @@ -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; + } + } + Index: head/editors/mousepad/files/patch-mousepad_mousepad-util.c =================================================================== --- head/editors/mousepad/files/patch-mousepad_mousepad-util.c (nonexistent) +++ head/editors/mousepad/files/patch-mousepad_mousepad-util.c (revision 459693) @@ -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); + Property changes on: head/editors/mousepad/files/patch-mousepad_mousepad-util.c ___________________________________________________________________ Added: fbsd:nokeywords ## -0,0 +1 ## +yes \ No newline at end of property Added: svn:eol-style ## -0,0 +1 ## +native \ No newline at end of property Added: svn:mime-type ## -0,0 +1 ## +text/plain \ No newline at end of property Index: head/editors/mousepad/files/patch-mousepad_mousepad-window.c =================================================================== --- head/editors/mousepad/files/patch-mousepad_mousepad-window.c (revision 459692) +++ head/editors/mousepad/files/patch-mousepad_mousepad-window.c (revision 459693) @@ -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; -- const gchar *scheme_id; -+ const gchar *scheme_id = NULL; - gint npages, i; +@@ -712,32 +712,6 @@ mousepad_window_create_languages_menu (MousepadWindow - /* get the new active language */ - scheme = mousepad_action_group_get_active_style_scheme (group); + + static void +-mousepad_window_action_group_style_scheme_changed (MousepadWindow *window, +- GParamSpec *pspec, +- MousepadActionGroup *group) +-{ +- GtkSourceStyleScheme *scheme; +- const gchar *scheme_id; +- 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);