aboutsummaryrefslogtreecommitdiffstats
path: root/mail/message-list.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/message-list.c')
-rw-r--r--mail/message-list.c28
1 files changed, 18 insertions, 10 deletions
diff --git a/mail/message-list.c b/mail/message-list.c
index 91a177ffc4..2a390530e4 100644
--- a/mail/message-list.c
+++ b/mail/message-list.c
@@ -102,7 +102,7 @@ get_message_info (MessageList *message_list, int row)
/**
* message_list_select:
* @message_list: a MessageList
- * @base_row: the row to start from
+ * @base_row: the (model) row to start from
* @direction: the direction to search in
* @flags: a set of flag values
* @mask: a mask for comparing against @flags
@@ -121,19 +121,21 @@ message_list_select (MessageList *message_list, int base_row,
guint32 flags, guint32 mask)
{
const CamelMessageInfo *info;
- int last;
+ int vrow, mrow, last;
+ ETableScrolled *ets = E_TABLE_SCROLLED (message_list->etable);
if (direction == MESSAGE_LIST_SELECT_PREVIOUS)
last = 0;
else
last = e_table_model_row_count (message_list->table_model);
- while (base_row != last) {
- base_row += direction;
- info = get_message_info (message_list, base_row);
+ vrow = e_table_model_to_view_row (ets->table, base_row);
+ while (vrow != last) {
+ vrow += direction;
+ mrow = e_table_view_to_model_row (ets->table, vrow);
+ info = get_message_info (message_list, mrow);
if (info && (info->flags & mask) == flags) {
- e_table_scrolled_set_cursor_row (E_TABLE_SCROLLED (message_list->etable),
- base_row);
+ e_table_scrolled_set_cursor_row (ets, mrow);
return;
}
}
@@ -939,15 +941,21 @@ on_cursor_change_cmd (ETableScrolled *table, int row, gpointer user_data)
info = get_message_info (message_list, row);
message_list->cursor_uid = info ? info->uid : NULL;
- if (!message_list->idle_id)
- message_list->idle_id = g_idle_add_full (G_PRIORITY_LOW, on_cursor_change_idle, message_list, NULL);
+ if (!message_list->idle_id) {
+ message_list->idle_id =
+ g_idle_add_full (G_PRIORITY_LOW, on_cursor_change_idle,
+ message_list, NULL);
+ }
}
/* FIXME: this is all a kludge. */
static gint
idle_select_row (gpointer user_data)
{
- e_table_scrolled_set_cursor_row (user_data, 0);
+ ETableScrolled *ets = user_data;
+ int mrow = e_table_view_to_model_row (ets->table, 0);
+
+ e_table_scrolled_set_cursor_row (ets, mrow);
return FALSE;
}