aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2009-12-01 23:53:58 +0800
committerGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2009-12-21 19:39:08 +0800
commitc80fb17f32ce997a631e228a7b6fd89d2120a09d (patch)
tree0ca8491fe78fe57f2f3d376fbea2c4f5c8c5f27b /src
parent4d26e574b71c760e752a70eb5f2eb448b63f93e4 (diff)
downloadgsoc2013-empathy-c80fb17f32ce997a631e228a7b6fd89d2120a09d.tar.gz
gsoc2013-empathy-c80fb17f32ce997a631e228a7b6fd89d2120a09d.tar.zst
gsoc2013-empathy-c80fb17f32ce997a631e228a7b6fd89d2120a09d.zip
event-manager: remove the auto-remove timer when the event is destroyed
This avoid to crash when trying to re-remove an old event (#603485).
Diffstat (limited to 'src')
-rw-r--r--src/empathy-event-manager.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/src/empathy-event-manager.c b/src/empathy-event-manager.c
index 72708b6b5..c9e925d21 100644
--- a/src/empathy-event-manager.c
+++ b/src/empathy-event-manager.c
@@ -96,6 +96,7 @@ struct _EventPriv {
EventFunc func;
gboolean inhibit;
gpointer user_data;
+ guint autoremove_timeout_id;
};
enum {
@@ -160,6 +161,9 @@ event_free (EventPriv *event)
g_free (event->public.header);
g_free (event->public.message);
+ if (event->autoremove_timeout_id != 0)
+ g_source_remove (event->autoremove_timeout_id);
+
if (event->public.contact)
{
g_object_unref (event->public.contact);
@@ -174,6 +178,7 @@ event_remove (EventPriv *event)
EmpathyEventManagerPriv *priv = GET_PRIV (event->manager);
DEBUG ("Removing event %p", event);
+
priv->events = g_slist_remove (priv->events, event);
g_signal_emit (event->manager, signals[EVENT_REMOVED], 0, event);
event_free (event);
@@ -182,6 +187,7 @@ event_remove (EventPriv *event)
static gboolean
autoremove_event_timeout_cb (EventPriv *event)
{
+ event->autoremove_timeout_id = 0;
event_remove (event);
return FALSE;
}
@@ -219,8 +225,9 @@ event_manager_add (EmpathyEventManager *manager,
if (!event->public.must_ack)
{
- g_timeout_add_seconds (NOTIFICATION_TIMEOUT,
- (GSourceFunc) autoremove_event_timeout_cb, event);
+ event->autoremove_timeout_id = g_timeout_add_seconds (
+ NOTIFICATION_TIMEOUT, (GSourceFunc) autoremove_event_timeout_cb,
+ event);
}
}