diff options
author | lukefromdc <[email protected]> | 2017-08-20 17:35:56 -0400 |
---|---|---|
committer | raveit65 <[email protected]> | 2017-11-07 21:33:53 +0100 |
commit | 418679a91ff711170754ce4d6ed9105e3ae6449b (patch) | |
tree | 91ae81ad532efdcc553678e3674c3001bddf9f15 | |
parent | b6b89c1e796801d2cbb694a0e4963e4248ac79df (diff) | |
download | mate-panel-418679a91ff711170754ce4d6ed9105e3ae6449b.tar.bz2 mate-panel-418679a91ff711170754ce4d6ed9105e3ae6449b.tar.xz |
Fix crashes on moving/removing applets with glib 2.53.4 or later
*On destroying applet disconnect signals for functions that otherwise segfaults with glib 2.53.4 or later.
*Fish: it's not always enough for a function to return immediately if applet destroyed anymore
*panel-action-button: suppress a warning
-rw-r--r-- | applets/fish/fish.c | 4 | ||||
-rw-r--r-- | mate-panel/applet.c | 2 | ||||
-rw-r--r-- | mate-panel/panel-action-button.c | 3 |
3 files changed, 9 insertions, 0 deletions
diff --git a/applets/fish/fish.c b/applets/fish/fish.c index a9387b88..82d56f22 100644 --- a/applets/fish/fish.c +++ b/applets/fish/fish.c @@ -1757,6 +1757,10 @@ static void fish_applet_dispose (GObject *object) { FishApplet* fish = (FishApplet*) object; + if (fish->settings != NULL) + g_signal_handlers_disconnect_by_data (fish->settings, + fish); + if (fish->timeout) { g_source_remove (fish->timeout); diff --git a/mate-panel/applet.c b/mate-panel/applet.c index 9ed853fd..a76ed9c9 100644 --- a/mate-panel/applet.c +++ b/mate-panel/applet.c @@ -791,6 +791,8 @@ mate_panel_applet_destroy (GtkWidget *widget, { g_return_if_fail (info != NULL); + g_signal_handlers_disconnect_by_data(info->settings,widget); + info->widget = NULL; if (info->settings) { diff --git a/mate-panel/panel-action-button.c b/mate-panel/panel-action-button.c index dc911980..abfe8c22 100644 --- a/mate-panel/panel-action-button.c +++ b/mate-panel/panel-action-button.c @@ -647,6 +647,9 @@ void panel_action_button_set_type (PanelActionButton *button, PanelActionButtonType type) { + if (!type) + return; + g_return_if_fail (type > PANEL_ACTION_NONE && type < PANEL_ACTION_LAST); if (type == button->priv->type) |