From 55ae2c7f2f5729346e28425f84a28b810b33efed Mon Sep 17 00:00:00 2001 From: Marco Bascetta Date: Wed, 6 May 2015 16:21:17 +0200 Subject: huawei: handle voice call state changes --- src/mm-call-list.c | 54 +++++++++++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 51 insertions(+), 3 deletions(-) (limited to 'src/mm-call-list.c') diff --git a/src/mm-call-list.c b/src/mm-call-list.c index aa650058..c241a0be 100644 --- a/src/mm-call-list.c +++ b/src/mm-call-list.c @@ -114,7 +114,32 @@ MMBaseCall* mm_call_list_get_new_incoming(MMCallList *self) return call; } -MMBaseCall* mm_call_list_get_first_non_terminated_call(MMCallList *self) +MMBaseCall* mm_call_list_get_first_ringing_call(MMCallList *self) +{ + MMBaseCall *call = NULL; + GList *l; + guint i; + + for (i = 0, l = self->priv->list; l && !call; l = g_list_next (l)) { + + MMCallState state; + + g_object_get (MM_BASE_CALL (l->data), + "state" , &state, + NULL); + + if( state == MM_CALL_STATE_RINGING_IN || + state == MM_CALL_STATE_RINGING_OUT ) { + + call = MM_BASE_CALL (l->data); + break; + } + } + + return call; +} + +MMBaseCall* mm_call_list_get_first_outgoing_dialing_call(MMCallList *self) { MMBaseCall *call = NULL; GList *l; @@ -123,15 +148,38 @@ MMBaseCall* mm_call_list_get_first_non_terminated_call(MMCallList *self) for (i = 0, l = self->priv->list; l && !call; l = g_list_next (l)) { MMCallState state; - MMCallStateReason reason; MMCallDirection direct; g_object_get (MM_BASE_CALL (l->data), "state" , &state, - "state-reason", &reason, "direction" , &direct, NULL); + if( direct == MM_CALL_DIRECTION_OUTGOING && + state == MM_CALL_STATE_DIALING ) { + + call = MM_BASE_CALL (l->data); + break; + } + } + + return call; +} + +MMBaseCall* mm_call_list_get_first_non_terminated_call(MMCallList *self) +{ + MMBaseCall *call = NULL; + GList *l; + guint i; + + for (i = 0, l = self->priv->list; l && !call; l = g_list_next (l)) { + + MMCallState state; + + g_object_get (MM_BASE_CALL (l->data), + "state" , &state, + NULL); + if( state != MM_CALL_STATE_TERMINATED ) { call = MM_BASE_CALL (l->data); break; -- cgit v1.2.3-70-g09d2