diff options
author | Sjoerd Simons <sjoerd.simons@collabora.co.uk> | 2011-03-17 19:35:46 +0800 |
---|---|---|
committer | Sjoerd Simons <sjoerd.simons@collabora.co.uk> | 2011-03-17 19:50:39 +0800 |
commit | e90884d588a170b130f2f1c4faf2ff14d70bdc10 (patch) | |
tree | e3f362d7ac57972455069d24a869fb98faef1898 /src/empathy-call-handler.c | |
parent | 76341ee8710f2510851b904aa145902d5c482f1a (diff) | |
download | gsoc2013-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
Diffstat (limited to 'src/empathy-call-handler.c')
-rw-r--r-- | src/empathy-call-handler.c | 20 |
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); |