aboutsummaryrefslogtreecommitdiff
path: root/src/summaryview.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/summaryview.c')
-rw-r--r--src/summaryview.c140
1 files changed, 81 insertions, 59 deletions
diff --git a/src/summaryview.c b/src/summaryview.c
index f29a01a5..b3393709 100644
--- a/src/summaryview.c
+++ b/src/summaryview.c
@@ -2194,10 +2194,8 @@ static void summary_update_status(SummaryView *summaryview)
static void summary_status_show(SummaryView *summaryview)
{
GtkTreeModel *model = GTK_TREE_MODEL(summaryview->store);
- gchar *str;
- gchar *del, *mv, *cp;
- gchar *sel;
- gchar *spc;
+ GString *str;
+ gchar *name;
GList *rowlist, *cur;
guint n_selected = 0;
gint64 sel_size = 0;
@@ -2231,12 +2229,12 @@ static void summary_status_show(SummaryView *summaryview)
group = get_abbrev_newsgroup_name
(g_basename(summaryview->folder_item->path),
prefs_common.ng_abbrev_len);
- str = trim_string_before(group, 32);
+ name = trim_string_before(group, 32);
g_free(group);
} else
- str = trim_string_before(summaryview->folder_item->path, 32);
- gtk_label_set(GTK_LABEL(summaryview->statlabel_folder), str);
- g_free(str);
+ name = trim_string_before(summaryview->folder_item->path, 32);
+ gtk_label_set(GTK_LABEL(summaryview->statlabel_folder), name);
+ g_free(name);
if (summaryview->on_filter) {
deleted = summaryview->flt_deleted;
@@ -2248,62 +2246,61 @@ static void summary_status_show(SummaryView *summaryview)
copied = summaryview->copied;
}
+ str = g_string_sized_new(128);
+
+ if (n_selected)
+ g_string_append_printf(str, "%d%s (%s)", n_selected,
+ _(" item(s) selected"),
+ to_human_readable(sel_size));
+ if (str->len > 0 && (deleted || moved || copied))
+ g_string_append(str, " ");
if (deleted)
- del = g_strdup_printf(_("%d deleted"), deleted);
- else
- del = g_strdup("");
+ g_string_append_printf(str, _("%d deleted"), deleted);
if (moved)
- mv = g_strdup_printf(_("%s%d moved"),
- deleted ? _(", ") : "", moved);
- else
- mv = g_strdup("");
+ g_string_append_printf(str, _("%s%d moved"),
+ deleted ? _(", ") : "", moved);
if (copied)
- cp = g_strdup_printf(_("%s%d copied"),
- deleted || moved ? _(", ") : "", copied);
- else
- cp = g_strdup("");
+ g_string_append_printf(str, _("%s%d copied"),
+ deleted || moved ? _(", ") : "", copied);
- if (deleted || moved || copied)
- spc = " ";
- else
- spc = "";
+ gtk_label_set(GTK_LABEL(summaryview->statlabel_select), str->str);
+ g_string_truncate(str, 0);
- if (n_selected)
- sel = g_strdup_printf(" (%s)", to_human_readable(sel_size));
- else
- sel = g_strdup("");
- str = g_strconcat(n_selected ? itos(n_selected) : "",
- n_selected ? _(" item(s) selected") : "",
- sel, spc, del, mv, cp, NULL);
- gtk_label_set(GTK_LABEL(summaryview->statlabel_select), str);
- g_free(str);
- g_free(sel);
- g_free(del);
- g_free(mv);
- g_free(cp);
+ new = summaryview->folder_item->new;
+ unread = summaryview->folder_item->unread;
+ total = summaryview->folder_item->total;
+ total_size = summaryview->total_size;
if (summaryview->on_filter) {
- new = summaryview->flt_new;
- unread = summaryview->flt_unread;
- total = summaryview->flt_msg_total;
- total_size = summaryview->total_flt_msg_size;
+ gint f_new, f_unread, f_total;
+ gint64 f_total_size;
+ gchar f_ts[16], ts[16];
+
+ f_new = summaryview->flt_new;
+ f_unread = summaryview->flt_unread;
+ f_total = summaryview->flt_msg_total;
+ f_total_size = summaryview->total_flt_msg_size;
+
+ g_string_printf(str, _("%d/%d new, %d/%d unread, %d/%d total"),
+ f_new, new, f_unread, unread, f_total, total);
+ if (FOLDER_IS_LOCAL(summaryview->folder_item->folder)) {
+ g_string_append_printf(str, " (%s/%s)",
+ to_human_readable_buf(f_ts, sizeof(f_ts), f_total_size), to_human_readable_buf(ts, sizeof(ts), total_size));
+ }
} else {
- new = summaryview->folder_item->new;
- unread = summaryview->folder_item->unread;
- total = summaryview->folder_item->total;
- total_size = summaryview->total_size;
+ if (FOLDER_IS_LOCAL(summaryview->folder_item->folder)) {
+ g_string_printf(str,
+ _("%d new, %d unread, %d total (%s)"),
+ new, unread, total,
+ to_human_readable(total_size));
+ } else {
+ g_string_printf(str, _("%d new, %d unread, %d total"),
+ new, unread, total);
+ }
}
- if (FOLDER_IS_LOCAL(summaryview->folder_item->folder)) {
- str = g_strdup_printf(_("%d new, %d unread, %d total (%s)"),
- new, unread, total,
- to_human_readable(total_size));
- } else {
- str = g_strdup_printf(_("%d new, %d unread, %d total"),
- new, unread, total);
- }
- gtk_label_set(GTK_LABEL(summaryview->statlabel_msgs), str);
- g_free(str);
+ gtk_label_set(GTK_LABEL(summaryview->statlabel_msgs), str->str);
+ g_string_free(str, TRUE);
folderview_update_opened_msg_num(summaryview->folderview);
}
@@ -3392,14 +3389,22 @@ static void summary_delete_row(SummaryView *summaryview, GtkTreeIter *iter)
if (MSG_IS_DELETED(msginfo->flags)) return;
msginfo->to_folder = NULL;
- if (MSG_IS_MOVE(msginfo->flags))
+ if (MSG_IS_MOVE(msginfo->flags)) {
summaryview->moved--;
- if (MSG_IS_COPY(msginfo->flags))
+ if (summaryview->on_filter)
+ summaryview->flt_moved--;
+ }
+ if (MSG_IS_COPY(msginfo->flags)) {
summaryview->copied--;
+ if (summaryview->on_filter)
+ summaryview->flt_copied--;
+ }
MSG_UNSET_TMP_FLAGS(msginfo->flags, MSG_MOVE | MSG_COPY);
MSG_SET_PERM_FLAGS(msginfo->flags, MSG_DELETED);
MSG_SET_TMP_FLAGS(msginfo->flags, MSG_FLAG_CHANGED);
summaryview->deleted++;
+ if (summaryview->on_filter)
+ summaryview->flt_deleted++;
summaryview->folder_item->mark_dirty = TRUE;
if (!prefs_common.immediate_exec && summaryview->tmp_flag == 0)
@@ -3542,12 +3547,21 @@ static void summary_unmark_row(SummaryView *summaryview, GtkTreeIter *iter)
GET_MSG_INFO(msginfo, iter);
msginfo->to_folder = NULL;
- if (MSG_IS_DELETED(msginfo->flags))
+ if (MSG_IS_DELETED(msginfo->flags)) {
summaryview->deleted--;
- if (MSG_IS_MOVE(msginfo->flags))
+ if (summaryview->on_filter)
+ summaryview->flt_deleted--;
+ }
+ if (MSG_IS_MOVE(msginfo->flags)) {
summaryview->moved--;
- if (MSG_IS_COPY(msginfo->flags))
+ if (summaryview->on_filter)
+ summaryview->flt_moved--;
+ }
+ if (MSG_IS_COPY(msginfo->flags)) {
summaryview->copied--;
+ if (summaryview->on_filter)
+ summaryview->flt_copied--;
+ }
MSG_UNSET_PERM_FLAGS(msginfo->flags, MSG_MARKED | MSG_DELETED);
MSG_UNSET_TMP_FLAGS(msginfo->flags, MSG_MOVE | MSG_COPY);
MSG_SET_TMP_FLAGS(msginfo->flags, MSG_FLAG_CHANGED);
@@ -3608,6 +3622,8 @@ static void summary_move_row_to(SummaryView *summaryview, GtkTreeIter *iter,
msginfo->to_folder = to_folder;
if (MSG_IS_DELETED(msginfo->flags)) {
summaryview->deleted--;
+ if (summaryview->on_filter)
+ summaryview->flt_deleted--;
MSG_UNSET_PERM_FLAGS(msginfo->flags, MSG_DELETED);
MSG_SET_TMP_FLAGS(msginfo->flags, MSG_FLAG_CHANGED);
}
@@ -3615,6 +3631,8 @@ static void summary_move_row_to(SummaryView *summaryview, GtkTreeIter *iter,
if (!MSG_IS_MOVE(msginfo->flags)) {
MSG_SET_TMP_FLAGS(msginfo->flags, MSG_MOVE);
summaryview->moved++;
+ if (summaryview->on_filter)
+ summaryview->flt_moved++;
}
summaryview->folder_item->mark_dirty = TRUE;
if (!prefs_common.immediate_exec)
@@ -3707,6 +3725,8 @@ static void summary_copy_row_to(SummaryView *summaryview, GtkTreeIter *iter,
msginfo->to_folder = to_folder;
if (MSG_IS_DELETED(msginfo->flags)) {
summaryview->deleted--;
+ if (summaryview->on_filter)
+ summaryview->flt_deleted--;
MSG_UNSET_PERM_FLAGS(msginfo->flags, MSG_DELETED);
MSG_SET_TMP_FLAGS(msginfo->flags, MSG_FLAG_CHANGED);
}
@@ -3714,6 +3734,8 @@ static void summary_copy_row_to(SummaryView *summaryview, GtkTreeIter *iter,
if (!MSG_IS_COPY(msginfo->flags)) {
MSG_SET_TMP_FLAGS(msginfo->flags, MSG_COPY);
summaryview->copied++;
+ if (summaryview->on_filter)
+ summaryview->flt_copied++;
}
summaryview->folder_item->mark_dirty = TRUE;
if (!prefs_common.immediate_exec)