mirror of
https://gitlab.gnome.org/GNOME/calls.git
synced 2025-01-08 12:55:32 +00:00
Let provider plugin decide whether to automatically hang up secondary calls
Revert "manager: hang up secondary calls"
This reverts commit 94345e0916
and moves that
functionality to the ModemManager plugin.
Fixes #290
This commit is contained in:
parent
21eb12e9b1
commit
94d730c3ed
2 changed files with 6 additions and 10 deletions
|
@ -465,6 +465,12 @@ add_call (CallsMMOrigin *self,
|
||||||
}
|
}
|
||||||
|
|
||||||
g_debug ("Call `%s' added", path);
|
g_debug ("Call `%s' added", path);
|
||||||
|
|
||||||
|
/* FIXME: Hang up the call, since accepting a secondary call does not currently work.
|
||||||
|
* CallsMMCall[28822]: WARNING: Error accepting ModemManager call to `+4916XXXXXXXX': GDBus.Error:org.freedesktop.ModemManager1.Error.Core.Failed: This call was not ringing, cannot accept
|
||||||
|
*/
|
||||||
|
if (g_hash_table_size (self->calls) > 1)
|
||||||
|
calls_call_hang_up (CALLS_CALL (call));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -58,7 +58,6 @@ struct _CallsManager
|
||||||
CallsContactsProvider *contacts_provider;
|
CallsContactsProvider *contacts_provider;
|
||||||
|
|
||||||
CallsManagerState state;
|
CallsManagerState state;
|
||||||
CallsCall *primary_call;
|
|
||||||
CallsSettings *settings;
|
CallsSettings *settings;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -200,11 +199,6 @@ add_call (CallsManager *self, CallsCall *call, CallsOrigin *origin)
|
||||||
g_return_if_fail (CALLS_IS_CALL (call));
|
g_return_if_fail (CALLS_IS_CALL (call));
|
||||||
|
|
||||||
g_signal_emit (self, signals[SIGNAL_CALL_ADD], 0, call, origin);
|
g_signal_emit (self, signals[SIGNAL_CALL_ADD], 0, call, origin);
|
||||||
|
|
||||||
if (self->primary_call == NULL)
|
|
||||||
self->primary_call = call;
|
|
||||||
else
|
|
||||||
calls_call_hang_up (call);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -216,9 +210,6 @@ remove_call (CallsManager *self, CallsCall *call, gchar *reason, CallsOrigin *or
|
||||||
|
|
||||||
/* We ignore the reason for now, because it doesn't give any usefull information */
|
/* We ignore the reason for now, because it doesn't give any usefull information */
|
||||||
g_signal_emit (self, signals[SIGNAL_CALL_REMOVE], 0, call, origin);
|
g_signal_emit (self, signals[SIGNAL_CALL_REMOVE], 0, call, origin);
|
||||||
|
|
||||||
if (self->primary_call == call)
|
|
||||||
self->primary_call = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -666,7 +657,6 @@ calls_manager_init (CallsManager *self)
|
||||||
const gchar *dir;
|
const gchar *dir;
|
||||||
|
|
||||||
self->state = CALLS_MANAGER_STATE_NO_PROVIDER;
|
self->state = CALLS_MANAGER_STATE_NO_PROVIDER;
|
||||||
self->primary_call = NULL;
|
|
||||||
self->providers = g_hash_table_new_full (g_str_hash,
|
self->providers = g_hash_table_new_full (g_str_hash,
|
||||||
g_str_equal,
|
g_str_equal,
|
||||||
g_free,
|
g_free,
|
||||||
|
|
Loading…
Reference in a new issue