mirror of
https://gitlab.gnome.org/GNOME/calls.git
synced 2025-01-23 03:55:32 +00:00
main-window: No need to store calls so remove holders here
This commit is contained in:
parent
f4eae98458
commit
1843d72ad1
1 changed files with 2 additions and 151 deletions
|
@ -42,8 +42,6 @@ struct _CallsMainWindow
|
||||||
GtkApplicationWindow parent_instance;
|
GtkApplicationWindow parent_instance;
|
||||||
|
|
||||||
CallsProvider *provider;
|
CallsProvider *provider;
|
||||||
GListStore *call_holders;
|
|
||||||
CallsCallHolder *focus;
|
|
||||||
|
|
||||||
GtkInfoBar *info;
|
GtkInfoBar *info;
|
||||||
GtkLabel *info_label;
|
GtkLabel *info_label;
|
||||||
|
@ -174,156 +172,28 @@ info_response_cb (GtkInfoBar *infobar,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
typedef gboolean (*FindCallHolderFunc) (CallsCallHolder *holder,
|
|
||||||
gpointer user_data);
|
|
||||||
|
|
||||||
|
|
||||||
static gboolean
|
|
||||||
find_call_holder_by_call (CallsCallHolder *holder,
|
|
||||||
gpointer user_data)
|
|
||||||
{
|
|
||||||
CallsCallData *data = calls_call_holder_get_data (holder);
|
|
||||||
|
|
||||||
return calls_call_data_get_call (data) == user_data;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/** Search through the list of call holders, returning the total
|
|
||||||
number of items in the list, the position of the holder within the
|
|
||||||
list and a pointer to the holder itself. */
|
|
||||||
static gboolean
|
|
||||||
find_call_holder (CallsMainWindow *self,
|
|
||||||
guint *n_itemsp,
|
|
||||||
guint *positionp,
|
|
||||||
CallsCallHolder **holderp,
|
|
||||||
FindCallHolderFunc predicate,
|
|
||||||
gpointer user_data)
|
|
||||||
{
|
|
||||||
GListModel * const model = G_LIST_MODEL (self->call_holders);
|
|
||||||
const guint n_items = g_list_model_get_n_items (model);
|
|
||||||
guint position = 0;
|
|
||||||
CallsCallHolder *holder;
|
|
||||||
|
|
||||||
for (position = 0; position < n_items; ++position)
|
|
||||||
{
|
|
||||||
holder = CALLS_CALL_HOLDER (g_list_model_get_item (model, position));
|
|
||||||
|
|
||||||
if (predicate (holder, user_data))
|
|
||||||
{
|
|
||||||
#define out(var) \
|
|
||||||
if (var##p) \
|
|
||||||
{ \
|
|
||||||
*var##p = var ; \
|
|
||||||
}
|
|
||||||
|
|
||||||
out (n_items);
|
|
||||||
out (position);
|
|
||||||
out (holder);
|
|
||||||
|
|
||||||
#undef out
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static void
|
|
||||||
set_focus (CallsMainWindow *self, CallsCallHolder *holder)
|
|
||||||
{
|
|
||||||
if (!holder)
|
|
||||||
{
|
|
||||||
holder = g_list_model_get_item (G_LIST_MODEL (self->call_holders), 0);
|
|
||||||
|
|
||||||
if (!holder)
|
|
||||||
{
|
|
||||||
/* No calls */
|
|
||||||
self->focus = NULL;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
self->focus = holder;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
add_call (CallsMainWindow *self, CallsCall *call)
|
add_call (CallsMainWindow *self, CallsCall *call)
|
||||||
{
|
{
|
||||||
CallsCallHolder *holder;
|
|
||||||
|
|
||||||
g_signal_emit (self, signals[SIGNAL_CALL_ADDED], 0, call);
|
g_signal_emit (self, signals[SIGNAL_CALL_ADDED], 0, call);
|
||||||
|
|
||||||
g_signal_connect_swapped (call, "message",
|
g_signal_connect_swapped (call, "message",
|
||||||
G_CALLBACK (show_message), self);
|
G_CALLBACK (show_message), self);
|
||||||
|
|
||||||
holder = calls_call_holder_new (call);
|
|
||||||
|
|
||||||
g_list_store_append (self->call_holders, holder);
|
|
||||||
|
|
||||||
set_focus (self, holder);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
|
||||||
remove_call_holder (CallsMainWindow *self,
|
|
||||||
guint n_items,
|
|
||||||
guint position,
|
|
||||||
CallsCallHolder *holder)
|
|
||||||
{
|
|
||||||
g_list_store_remove (self->call_holders, position);
|
|
||||||
|
|
||||||
if (self->focus == holder)
|
|
||||||
{
|
|
||||||
set_focus (self, NULL);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
remove_call (CallsMainWindow *self, CallsCall *call, const gchar *reason)
|
remove_call (CallsMainWindow *self, CallsCall *call, const gchar *reason)
|
||||||
{
|
{
|
||||||
guint n_items, position;
|
|
||||||
CallsCallHolder *holder;
|
|
||||||
gboolean found;
|
|
||||||
|
|
||||||
g_return_if_fail (CALLS_IS_MAIN_WINDOW (self));
|
g_return_if_fail (CALLS_IS_MAIN_WINDOW (self));
|
||||||
g_return_if_fail (CALLS_IS_CALL (call));
|
g_return_if_fail (CALLS_IS_CALL (call));
|
||||||
|
|
||||||
g_signal_emit (self, signals[SIGNAL_CALL_REMOVED], 0, call, reason);
|
g_signal_emit (self, signals[SIGNAL_CALL_REMOVED], 0, call, reason);
|
||||||
|
|
||||||
found = find_call_holder (self, &n_items, &position, &holder,
|
|
||||||
find_call_holder_by_call, call);
|
|
||||||
g_return_if_fail (found);
|
|
||||||
|
|
||||||
remove_call_holder (self, n_items, position, holder);
|
|
||||||
|
|
||||||
if (!reason)
|
|
||||||
{
|
|
||||||
reason = "Call ended for unknown reason";
|
|
||||||
}
|
|
||||||
show_message(self, reason, GTK_MESSAGE_INFO);
|
show_message(self, reason, GTK_MESSAGE_INFO);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
|
||||||
remove_calls (CallsMainWindow *self)
|
|
||||||
{
|
|
||||||
GListModel * model = G_LIST_MODEL (self->call_holders);
|
|
||||||
guint n_items = g_list_model_get_n_items (model);
|
|
||||||
gpointer *item;
|
|
||||||
CallsCallHolder *holder;
|
|
||||||
|
|
||||||
while ( (item = g_list_model_get_item (model, 0)) )
|
|
||||||
{
|
|
||||||
holder = CALLS_CALL_HOLDER (item);
|
|
||||||
remove_call_holder (self, n_items--, 0, holder);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
add_origin_calls (CallsMainWindow *self, CallsOrigin *origin)
|
add_origin_calls (CallsMainWindow *self, CallsOrigin *origin)
|
||||||
{
|
{
|
||||||
|
@ -350,7 +220,7 @@ add_origin (CallsMainWindow *self, CallsOrigin *origin)
|
||||||
g_signal_connect_swapped (origin, "call-removed",
|
g_signal_connect_swapped (origin, "call-removed",
|
||||||
G_CALLBACK (remove_call), self);
|
G_CALLBACK (remove_call), self);
|
||||||
|
|
||||||
add_origin_calls(self, origin);
|
add_origin_calls (self, origin);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -390,21 +260,10 @@ set_property (GObject *object,
|
||||||
GParamSpec *pspec)
|
GParamSpec *pspec)
|
||||||
{
|
{
|
||||||
CallsMainWindow *self = CALLS_MAIN_WINDOW (object);
|
CallsMainWindow *self = CALLS_MAIN_WINDOW (object);
|
||||||
GObject *val_obj;
|
|
||||||
|
|
||||||
switch (property_id) {
|
switch (property_id) {
|
||||||
case PROP_PROVIDER:
|
case PROP_PROVIDER:
|
||||||
val_obj = g_value_get_object (value);
|
set_provider (self, CALLS_PROVIDER (g_value_get_object (value)));
|
||||||
if (val_obj == NULL)
|
|
||||||
{
|
|
||||||
g_warning("Null provider");
|
|
||||||
self->provider = NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
g_return_if_fail (CALLS_IS_PROVIDER (val_obj));
|
|
||||||
set_provider (self, CALLS_PROVIDER (val_obj));
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -451,8 +310,6 @@ static void
|
||||||
calls_main_window_init (CallsMainWindow *self)
|
calls_main_window_init (CallsMainWindow *self)
|
||||||
{
|
{
|
||||||
gtk_widget_init_template (GTK_WIDGET (self));
|
gtk_widget_init_template (GTK_WIDGET (self));
|
||||||
|
|
||||||
self->call_holders = g_list_store_new (CALLS_TYPE_CALL_HOLDER);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -462,12 +319,6 @@ dispose (GObject *object)
|
||||||
GObjectClass *parent_class = g_type_class_peek (GTK_TYPE_APPLICATION_WINDOW);
|
GObjectClass *parent_class = g_type_class_peek (GTK_TYPE_APPLICATION_WINDOW);
|
||||||
CallsMainWindow *self = CALLS_MAIN_WINDOW (object);
|
CallsMainWindow *self = CALLS_MAIN_WINDOW (object);
|
||||||
|
|
||||||
if (self->call_holders)
|
|
||||||
{
|
|
||||||
remove_calls (self);
|
|
||||||
}
|
|
||||||
|
|
||||||
g_clear_object (&self->call_holders);
|
|
||||||
g_clear_object (&self->provider);
|
g_clear_object (&self->provider);
|
||||||
|
|
||||||
parent_class->dispose (object);
|
parent_class->dispose (object);
|
||||||
|
|
Loading…
Reference in a new issue