aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSjoerd Simons <sjoerd.simons@collabora.co.uk>2011-03-17 19:35:46 +0800
committerSjoerd Simons <sjoerd.simons@collabora.co.uk>2011-03-17 19:50:39 +0800
commite90884d588a170b130f2f1c4faf2ff14d70bdc10 (patch)
treee3f362d7ac57972455069d24a869fb98faef1898
parent76341ee8710f2510851b904aa145902d5c482f1a (diff)
downloadgsoc2013-empathy-e90884d588a170b130f2f1c4faf2ff14d70bdc10.tar
gsoc2013-empathy-e90884d588a170b130f2f1c4faf2ff14d70bdc10.tar.gz
gsoc2013-empathy-e90884d588a170b130f2f1c4faf2ff14d70bdc10.tar.bz2
gsoc2013-empathy-e90884d588a170b130f2f1c4faf2ff14d70bdc10.tar.lz
gsoc2013-empathy-e90884d588a170b130f2f1c4faf2ff14d70bdc10.tar.xz
gsoc2013-empathy-e90884d588a170b130f2f1c4faf2ff14d70bdc10.tar.zst
gsoc2013-empathy-e90884d588a170b130f2f1c4faf2ff14d70bdc10.zip
Cope with unexpected call channel invalidation
-rw-r--r--src/empathy-call-handler.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/empathy-call-handler.c b/src/empathy-call-handler.c
index 02a5af691..a7aafad64 100644
--- a/src/empathy-call-handler.c
+++ b/src/empathy-call-handler.c
@@ -168,6 +168,24 @@ on_get_contacts_cb (TpConnection *connection,
}
static void
+on_call_invalidated_cb (TpyCallChannel *call,
+ guint domain,
+ gint code,
+ gchar *message,
+ EmpathyCallHandler *self)
+{
+ EmpathyCallHandlerPriv *priv = self->priv;
+
+ if (priv->call == call)
+ {
+ /* Invalidated unexpectedly? Fake call ending */
+ g_signal_emit (self, signals[STATE_CHANGED], 0, TPY_CALL_STATE_ENDED);
+ tp_clear_object (&priv->call);
+ tp_clear_object (&priv->tfchannel);
+ }
+}
+
+static void
on_call_state_changed_cb (TpyCallChannel *call,
TpyCallState state,
TpyCallFlags flags,
@@ -254,6 +272,8 @@ empathy_call_handler_set_property (GObject *object,
tp_g_signal_connect_object (priv->call, "state-changed",
G_CALLBACK (on_call_state_changed_cb), object, 0);
+ tp_g_signal_connect_object (priv->call, "invalidated",
+ G_CALLBACK (on_call_invalidated_cb), object, 0);
break;
case PROP_INITIAL_AUDIO:
priv->initial_audio = g_value_get_boolean (value);