mirror of
https://gitlab.gnome.org/GNOME/calls.git
synced 2025-01-07 12:25:31 +00:00
record-store: Don't crash on unexpected call state changes
It has been reported that the BM818 sometimes unexpectedly changes the call state from "active" back to "ringing-in" (as reported by ModemManager) shortly after accepting an incoming call. ModemManager[734]: <info> [modem1/call1] user request to accept call ModemManager[734]: <info> [modem1/call1] call is accepted ModemManager[734]: <info> [modem1/call1] call state changed: ringing-in -> active (accepted) ModemManager[734]: <info> [modem1/call1] call state changed: active -> ringing-in (unknown) This leads to a failed assertion and program termination. Instead of crashing raising a critical warning is more appropriate and may allow the user to pick up the call after all. Closes: #547
This commit is contained in:
parent
c0140b4109
commit
0e6d5d9745
1 changed files with 31 additions and 8 deletions
|
@ -71,6 +71,22 @@ state_to_record_state (CuiCallState call_state)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
record_state_to_string (CallsCallRecordState state)
|
||||||
|
{
|
||||||
|
switch (state) {
|
||||||
|
case STARTED:
|
||||||
|
return "started";
|
||||||
|
case ANSWERED:
|
||||||
|
return "answered";
|
||||||
|
case ENDED:
|
||||||
|
return "ended";
|
||||||
|
default:
|
||||||
|
return "unknown";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
struct _CallsRecordStore {
|
struct _CallsRecordStore {
|
||||||
GtkApplicationWindow parent_instance;
|
GtkApplicationWindow parent_instance;
|
||||||
|
|
||||||
|
@ -528,8 +544,9 @@ state_changed_cb (CallsRecordStore *self,
|
||||||
g_object_get_data (call_obj, "calls-call-record");
|
g_object_get_data (call_obj, "calls-call-record");
|
||||||
CallsCallRecordState new_rec_state, old_rec_state;
|
CallsCallRecordState new_rec_state, old_rec_state;
|
||||||
|
|
||||||
g_debug ("Call state changed from %d to %d",
|
g_debug ("Call state changed from %s (%d) to %s (%d)",
|
||||||
old_state, new_state);
|
cui_call_state_to_string (old_state), old_state,
|
||||||
|
cui_call_state_to_string (new_state), new_state);
|
||||||
|
|
||||||
/* Check whether the call is recorded */
|
/* Check whether the call is recorded */
|
||||||
if (!record) {
|
if (!record) {
|
||||||
|
@ -561,8 +578,7 @@ state_changed_cb (CallsRecordStore *self,
|
||||||
|
|
||||||
case STARTED:
|
case STARTED:
|
||||||
default:
|
default:
|
||||||
g_assert_not_reached ();
|
goto critical_exit;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -575,16 +591,23 @@ state_changed_cb (CallsRecordStore *self,
|
||||||
case STARTED:
|
case STARTED:
|
||||||
case ANSWERED:
|
case ANSWERED:
|
||||||
default:
|
default:
|
||||||
g_assert_not_reached ();
|
goto critical_exit;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ENDED:
|
case ENDED:
|
||||||
default:
|
default:
|
||||||
g_assert_not_reached ();
|
goto critical_exit;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
|
||||||
|
critical_exit:
|
||||||
|
/* XXX Modem's may be buggy; let's print as much information as possible */
|
||||||
|
g_critical ("Unexpected state change occurred!\n"
|
||||||
|
"From %s (%s) to %s (%s)",
|
||||||
|
cui_call_state_to_string (old_state), record_state_to_string (old_rec_state),
|
||||||
|
cui_call_state_to_string (new_state), record_state_to_string (new_rec_state));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue