diff options
Diffstat (limited to 'libempathy-gtk/empathy-log-window.c')
-rw-r--r-- | libempathy-gtk/empathy-log-window.c | 197 |
1 files changed, 92 insertions, 105 deletions
diff --git a/libempathy-gtk/empathy-log-window.c b/libempathy-gtk/empathy-log-window.c index 256b0704c..1bcfb63a7 100644 --- a/libempathy-gtk/empathy-log-window.c +++ b/libempathy-gtk/empathy-log-window.c @@ -105,8 +105,7 @@ static void log_window_chats_accounts_changed_cb (GtkWidget *co static void log_window_chats_set_selected (EmpathyLogWindow *window); static gboolean log_window_chats_get_selected (EmpathyLogWindow *window, TpAccount **account, - gchar **chat_id, - gboolean *is_chatroom); + TplEntity **target); static void log_window_chats_get_messages (EmpathyLogWindow *window, GDate *date_to_show); static void log_window_calendar_chats_day_selected_cb (GtkWidget *calendar, @@ -123,8 +122,7 @@ enum { COL_FIND_ACCOUNT_NAME, COL_FIND_ACCOUNT, COL_FIND_CHAT_NAME, - COL_FIND_CHAT_ID, - COL_FIND_IS_CHATROOM, + COL_FIND_TARGET, COL_FIND_DATE, COL_FIND_DATE_READABLE, COL_FIND_COUNT @@ -134,8 +132,7 @@ enum { COL_CHAT_ICON, COL_CHAT_NAME, COL_CHAT_ACCOUNT, - COL_CHAT_ID, - COL_CHAT_IS_CHATROOM, + COL_CHAT_TARGET, COL_CHAT_COUNT }; @@ -367,7 +364,7 @@ log_window_entry_find_changed_cb (GtkWidget *entry, } static void -got_messages_for_date_cb (GObject *manager, +got_events_for_date_cb (GObject *manager, GAsyncResult *result, gpointer user_data) { @@ -381,7 +378,7 @@ got_messages_for_date_cb (GObject *manager, if (log_window == NULL) return; - if (!tpl_log_manager_get_messages_for_date_finish (TPL_LOG_MANAGER (manager), + if (!tpl_log_manager_get_events_for_date_finish (TPL_LOG_MANAGER (manager), result, &messages, &error)) { DEBUG ("Unable to retrieve messages for the selected date: %s. Aborting", error->message); @@ -394,9 +391,9 @@ got_messages_for_date_cb (GObject *manager, for (l = messages; l; l = l->next) { EmpathyMessage *message; - g_assert (TPL_IS_ENTRY (l->data)); + g_assert (TPL_IS_EVENT (l->data)); - message = empathy_message_from_tpl_log_entry (l->data); + message = empathy_message_from_tpl_log_event (l->data); g_object_unref (l->data); empathy_chat_view_append_message (window->chatview_find, message); g_object_unref (message); @@ -451,8 +448,7 @@ log_window_find_changed_cb (GtkTreeSelection *selection, GtkTreeModel *model; GtkTreeIter iter; TpAccount *account; - gchar *chat_id; - gboolean is_chatroom; + TplEntity *target; gchar *date; GDate *gdate; @@ -474,8 +470,7 @@ log_window_find_changed_cb (GtkTreeSelection *selection, gtk_tree_model_get (model, &iter, COL_FIND_ACCOUNT, &account, - COL_FIND_CHAT_ID, &chat_id, - COL_FIND_IS_CHATROOM, &is_chatroom, + COL_FIND_TARGET, &target, COL_FIND_DATE, &date, -1); @@ -489,20 +484,20 @@ log_window_find_changed_cb (GtkTreeSelection *selection, gdate = gdate_from_str (date); if (gdate != NULL) { - tpl_log_manager_get_messages_for_date_async (window->log_manager, - account, - chat_id, - is_chatroom, - gdate, - got_messages_for_date_cb, - window); + tpl_log_manager_get_events_for_date_async (window->log_manager, + account, + target, + TPL_EVENT_MASK_TEXT, + gdate, + got_events_for_date_cb, + window); g_date_free (gdate); } g_object_unref (account); + g_object_unref (target); g_free (date); - g_free (chat_id); } @@ -537,7 +532,7 @@ log_manager_searched_new_cb (GObject *manager, hit = l->data; /* Protect against invalid data (corrupt or old log files. */ - if (hit->account == NULL || hit->chat_id == NULL) { + if (hit->account == NULL || hit->target == NULL) { continue; } @@ -555,15 +550,14 @@ log_manager_searched_new_cb (GObject *manager, COL_FIND_ACCOUNT_ICON, account_icon, COL_FIND_ACCOUNT_NAME, account_name, COL_FIND_ACCOUNT, hit->account, - COL_FIND_CHAT_NAME, hit->chat_id, /* FIXME */ - COL_FIND_CHAT_ID, hit->chat_id, - COL_FIND_IS_CHATROOM, hit->is_chatroom, + COL_FIND_CHAT_NAME, tpl_entity_get_alias (hit->target), + COL_FIND_TARGET, hit->target, COL_FIND_DATE, tmp, COL_FIND_DATE_READABLE, date_readable, -1); /* FIXME: Update COL_FIND_CHAT_NAME */ - if (hit->is_chatroom) { + if (tpl_entity_get_entity_type (hit->target) == TPL_ENTITY_ROOM) { } else { } } @@ -596,7 +590,8 @@ log_window_find_populate (EmpathyLogWindow *window, return; } - tpl_log_manager_search_async (window->log_manager, search_criteria, + tpl_log_manager_search_async (window->log_manager, + search_criteria, TPL_EVENT_MASK_TEXT, log_manager_searched_new_cb, (gpointer) store); } @@ -621,8 +616,7 @@ log_window_find_setup (EmpathyLogWindow *window) G_TYPE_STRING, /* account name */ TP_TYPE_ACCOUNT, /* account */ G_TYPE_STRING, /* chat name */ - G_TYPE_STRING, /* chat id */ - G_TYPE_BOOLEAN, /* is chatroom */ + TPL_TYPE_ENTITY, /* target */ G_TYPE_STRING, /* date */ G_TYPE_STRING); /* date_readable */ @@ -777,12 +771,14 @@ log_window_chats_changed_cb (GtkTreeSelection *selection, } static void -log_manager_got_chats_cb (GObject *manager, - GAsyncResult *result, - gpointer user_data) +log_manager_got_entities_cb (GObject *manager, + GAsyncResult *result, + gpointer user_data) { EmpathyLogWindow *window = user_data; - GList *chats; + EmpathyAccountChooser *account_chooser; + TpAccount *account; + GList *entities; GList *l; GtkTreeView *view; GtkTreeModel *model; @@ -792,11 +788,16 @@ log_manager_got_chats_cb (GObject *manager, GError *error = NULL; gboolean select_account = FALSE; + account_chooser = EMPATHY_ACCOUNT_CHOOSER (window->account_chooser_chats); + account = empathy_account_chooser_dup_account (account_chooser); + + view = GTK_TREE_VIEW (window->treeview_chats); + if (log_window == NULL) return; - if (!tpl_log_manager_get_chats_finish (TPL_LOG_MANAGER (manager), - result, &chats, &error)) { + if (!tpl_log_manager_get_entities_finish (TPL_LOG_MANAGER (manager), + result, &entities, &error)) { DEBUG ("%s. Aborting", error->message); g_error_free (error); return; @@ -807,34 +808,32 @@ log_manager_got_chats_cb (GObject *manager, selection = gtk_tree_view_get_selection (view); store = GTK_LIST_STORE (model); - for (l = chats; l; l = l->next) { - TplLogSearchHit *hit; - - hit = l->data; + for (l = entities; l; l = l->next) { + TplEntity *entity; - if (hit->account == NULL) - continue; + entity = TPL_ENTITY (l->data); gtk_list_store_append (store, &iter); gtk_list_store_set (store, &iter, COL_CHAT_ICON, "empathy-available", /* FIXME */ - COL_CHAT_NAME, hit->chat_id, - COL_CHAT_ACCOUNT, hit->account, - COL_CHAT_ID, hit->chat_id, - COL_CHAT_IS_CHATROOM, hit->is_chatroom, + COL_CHAT_NAME, tpl_entity_get_alias (entity), + COL_CHAT_ACCOUNT, account, + COL_CHAT_TARGET, entity, -1); if (window->selected_account != NULL && - !tp_strdiff (tp_proxy_get_object_path (hit->account), + !tp_strdiff (tp_proxy_get_object_path (account), tp_proxy_get_object_path (window->selected_account))) select_account = TRUE; /* FIXME: Update COL_CHAT_ICON/NAME */ - if (hit->is_chatroom) { + if (tpl_entity_get_entity_type (entity) == TPL_ENTITY_ROOM) { } else { } + + g_object_unref (entity); } - tpl_log_manager_search_free (chats); + g_list_free (entities); /* Unblock signals */ g_signal_handlers_unblock_by_func (selection, @@ -878,8 +877,8 @@ log_window_chats_populate (EmpathyLogWindow *window) gtk_list_store_clear (store); - tpl_log_manager_get_chats_async (window->log_manager, account, - log_manager_got_chats_cb, (gpointer) window); + tpl_log_manager_get_entities_async (window->log_manager, account, + log_manager_got_entities_cb, (gpointer) window); } static void @@ -901,8 +900,7 @@ log_window_chats_setup (EmpathyLogWindow *window) G_TYPE_STRING, /* icon */ G_TYPE_STRING, /* name */ TP_TYPE_ACCOUNT, /* account */ - G_TYPE_STRING, /* id */ - G_TYPE_BOOLEAN); /* is chatroom */ + TPL_TYPE_ENTITY); /* target */ model = GTK_TREE_MODEL (store); sortable = GTK_TREE_SORTABLE (store); @@ -970,16 +968,19 @@ log_window_chats_set_selected (EmpathyLogWindow *window) } for (ok = TRUE; ok; ok = gtk_tree_model_iter_next (model, &iter)) { - TpAccount *this_account; - gchar *this_chat_id; - gboolean this_is_chatroom; + TpAccount *this_account; + TplEntity *this_target; + const gchar *this_chat_id; + gboolean this_is_chatroom; gtk_tree_model_get (model, &iter, COL_CHAT_ACCOUNT, &this_account, - COL_CHAT_ID, &this_chat_id, - COL_CHAT_IS_CHATROOM, &this_is_chatroom, + COL_CHAT_TARGET, &this_target, -1); + this_chat_id = tpl_entity_get_identifier (this_target); + this_is_chatroom = tpl_entity_get_entity_type (this_target) == TPL_ENTITY_ROOM; + if (this_account == window->selected_account && !tp_strdiff (this_chat_id, window->selected_chat_id) && this_is_chatroom == window->selected_is_chatroom) { @@ -988,12 +989,12 @@ log_window_chats_set_selected (EmpathyLogWindow *window) gtk_tree_view_scroll_to_cell (view, path, NULL, TRUE, 0.5, 0.0); gtk_tree_path_free (path); g_object_unref (this_account); - g_free (this_chat_id); + g_object_unref (this_target); break; } g_object_unref (this_account); - g_free (this_chat_id); + g_object_unref (this_target); } tp_clear_object (&window->selected_account); @@ -1003,16 +1004,14 @@ log_window_chats_set_selected (EmpathyLogWindow *window) static gboolean log_window_chats_get_selected (EmpathyLogWindow *window, TpAccount **account, - gchar **chat_id, - gboolean *is_chatroom) + TplEntity **target) { GtkTreeView *view; GtkTreeModel *model; GtkTreeSelection *selection; GtkTreeIter iter; - gchar *id = NULL; + TplEntity *targ; TpAccount *acc = NULL; - gboolean room = FALSE; view = GTK_TREE_VIEW (window->treeview_chats); model = gtk_tree_view_get_model (view); @@ -1024,24 +1023,20 @@ log_window_chats_get_selected (EmpathyLogWindow *window, gtk_tree_model_get (model, &iter, COL_CHAT_ACCOUNT, &acc, - COL_CHAT_ID, &id, - COL_CHAT_IS_CHATROOM, &room, + COL_CHAT_TARGET, &targ, -1); - if (chat_id != NULL) { - *chat_id = id; - } else { - g_free (id); - } if (account != NULL) { - *account = acc; - } else { - g_object_unref (acc); + *account = g_object_ref (acc); } - if (is_chatroom) { - *is_chatroom = room; + + if (target != NULL) { + *target = g_object_ref (targ); } + g_object_unref (acc); + g_object_unref (targ); + return TRUE; } @@ -1051,15 +1046,15 @@ log_window_got_messages_for_date_cb (GObject *manager, gpointer user_data) { EmpathyLogWindow *window = user_data; - GList *messages; + GList *events; GList *l; GError *error = NULL; if (log_window == NULL) return; - if (!tpl_log_manager_get_messages_for_date_finish (TPL_LOG_MANAGER (manager), - result, &messages, &error)) { + if (!tpl_log_manager_get_events_for_date_finish (TPL_LOG_MANAGER (manager), + result, &events, &error)) { DEBUG ("Unable to retrieve messages for the selected date: %s. Aborting", error->message); empathy_chat_view_append_event (window->chatview_find, @@ -1068,14 +1063,14 @@ log_window_got_messages_for_date_cb (GObject *manager, return; } - for (l = messages; l; l = l->next) { - EmpathyMessage *message = empathy_message_from_tpl_log_entry (l->data); + for (l = events; l; l = l->next) { + EmpathyMessage *message = empathy_message_from_tpl_log_event (l->data); g_object_unref (l->data); empathy_chat_view_append_message (window->chatview_chats, message); g_object_unref (message); } - g_list_free (messages); + g_list_free (events); /* Turn back on scrolling */ empathy_chat_view_scroll (window->chatview_find, TRUE); @@ -1090,11 +1085,9 @@ log_window_get_messages_for_date (EmpathyLogWindow *window, GDate *date) { TpAccount *account; - gchar *chat_id; - gboolean is_chatroom; + TplEntity *target; - if (!log_window_chats_get_selected (window, &account, - &chat_id, &is_chatroom)) { + if (!log_window_chats_get_selected (window, &account, &target)) { return; } @@ -1104,16 +1097,15 @@ log_window_get_messages_for_date (EmpathyLogWindow *window, /* Turn off scrolling temporarily */ empathy_chat_view_scroll (window->chatview_find, FALSE); - /* Get messages */ - tpl_log_manager_get_messages_for_date_async (window->log_manager, - account, chat_id, - is_chatroom, + /* Get events */ + tpl_log_manager_get_events_for_date_async (window->log_manager, + account, target, TPL_EVENT_MASK_TEXT, date, log_window_got_messages_for_date_cb, (gpointer) window); - g_free (chat_id); g_object_unref (account); + g_object_unref (target); } static void @@ -1201,15 +1193,13 @@ log_window_chats_get_messages (EmpathyLogWindow *window, GDate *date) { TpAccount *account; - gchar *chat_id; - gboolean is_chatroom; + TplEntity *target; guint year_selected; guint month_selected; guint day; - if (!log_window_chats_get_selected (window, &account, - &chat_id, &is_chatroom)) { + if (!log_window_chats_get_selected (window, &account, &target)) { return; } @@ -1221,8 +1211,7 @@ log_window_chats_get_messages (EmpathyLogWindow *window, if (date == NULL) { /* Get a list of dates and show them on the calendar */ tpl_log_manager_get_dates_async (window->log_manager, - account, chat_id, - is_chatroom, + account, target, TPL_EVENT_MASK_TEXT, log_manager_got_dates_cb, (gpointer) window); /* signal unblocked at the end of the CB flow */ } else { @@ -1252,7 +1241,7 @@ log_window_chats_get_messages (EmpathyLogWindow *window, } g_object_unref (account); - g_free (chat_id); + g_object_unref (target); } static void @@ -1337,25 +1326,23 @@ log_window_calendar_chats_month_changed_cb (GtkWidget *calendar, EmpathyLogWindow *window) { TpAccount *account; - gchar *chat_id; - gboolean is_chatroom; + TplEntity *target; gtk_calendar_clear_marks (GTK_CALENDAR (calendar)); - if (!log_window_chats_get_selected (window, &account, - &chat_id, &is_chatroom)) { + if (!log_window_chats_get_selected (window, &account, &target)) { DEBUG ("No chat selected to get dates for..."); return; } /* Get the log object for this contact */ - tpl_log_manager_get_dates_async (window->log_manager, account, - chat_id, is_chatroom, + tpl_log_manager_get_dates_async (window->log_manager, account, target, + TPL_EVENT_MASK_TEXT, log_window_updating_calendar_month_cb, (gpointer) window); g_object_unref (account); - g_free (chat_id); + g_object_unref (target); } static void |