#include "partial_download.h"
#include "timing.h"
#include "gedit-print.h"
+#include "log.h"
#define SUMMARY_COL_MARK_WIDTH 10
#define SUMMARY_COL_STATUS_WIDTH 13
static GdkBitmap *ignorethreadxpmmask;
static GdkPixmap *lockedxpm;
static GdkBitmap *lockedxpmmask;
+static GdkPixmap *spamxpm;
+static GdkBitmap *spamxpmmask;
static GdkPixmap *clipxpm;
static GdkBitmap *clipxpmmask;
GtkCTreeNode *node,
gpointer data);
-static void summary_set_menu_sensitive (SummaryView *summaryview);
+void summary_set_menu_sensitive (SummaryView *summaryview);
+guint summary_get_msgnum (SummaryView *summaryview,
+ GtkCTreeNode *node);
+
static void summary_set_hide_read_msgs_menu (SummaryView *summaryview,
guint action);
-static guint summary_get_msgnum (SummaryView *summaryview,
- GtkCTreeNode *node);
-
static GtkCTreeNode *summary_find_prev_msg
(SummaryView *summaryview,
GtkCTreeNode *current_node);
void summary_simplify_subject(SummaryView *summaryview, gchar * rexp,
GSList * mlist);
-#if 0
-void summary_processing(SummaryView *summaryview, GSList * mlist);
-#endif
static void summary_filter_func (MsgInfo *msginfo);
static void summary_colorlabel_menu_item_activate_cb
static void summary_colorlabel_menu_item_activate_item_cb
(GtkMenuItem *label_menu_item,
gpointer data);
-static void summary_colorlabel_menu_create(SummaryView *summaryview);
+static void summary_colorlabel_menu_create(SummaryView *summaryview,
+ gboolean refresh);
static GtkWidget *summary_ctree_create (SummaryView *summaryview);
{N_("/_Mark/Mark all read"), NULL, summary_mark_all_read, 0, NULL},
{N_("/_Mark/Ignore thread"), NULL, summary_ignore_thread, 0, NULL},
{N_("/_Mark/Unignore thread"), NULL, summary_unignore_thread, 0, NULL},
+ {N_("/_Mark/---"), NULL, NULL, 0, "<Separator>"},
+ {N_("/_Mark/Mark as _spam"), NULL, summary_mark_as_spam, 1, NULL},
+ {N_("/_Mark/Mark as _ham"), NULL, summary_mark_as_spam, 0, NULL},
+ {N_("/_Mark/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Mark/Lock"), NULL, summary_msgs_lock, 0, NULL},
{N_("/_Mark/Unlock"), NULL, summary_msgs_unlock, 0, NULL},
{N_("/Color la_bel"), NULL, NULL, 0, NULL},
&gpgsignedxpm, &gpgsignedxpmmask);
stock_pixmap_gdk(summaryview->ctree, STOCK_PIXMAP_CLIP_GPG_SIGNED,
&clipgpgsignedxpm, &clipgpgsignedxpmmask);
+ stock_pixmap_gdk(summaryview->ctree, STOCK_PIXMAP_SPAM,
+ &spamxpm, &spamxpmmask);
summary_set_fonts(summaryview);
summary_clear_list(summaryview);
summary_set_column_titles(summaryview);
- summary_colorlabel_menu_create(summaryview);
+ summary_colorlabel_menu_create(summaryview, FALSE);
+ main_create_mailing_list_menu (summaryview->mainwin, NULL);
summary_set_menu_sensitive(summaryview);
}
-#if 0
-GtkCTreeNode * summary_find_next_important_score(SummaryView *summaryview,
- GtkCTreeNode *current_node)
-{
- GtkCTree *ctree = GTK_CTREE(summaryview->ctree);
- GtkCTreeNode *node;
- MsgInfo *msginfo;
- gint best_score = MIN_SCORE;
- GtkCTreeNode *best_node = NULL;
-
- if (current_node)
- /*node = current_node;*/
- node = GTK_CTREE_NODE_NEXT(current_node);
- else
- node = GTK_CTREE_NODE(GTK_CLIST(ctree)->row_list);
-
- for (; node != NULL; node = GTK_CTREE_NODE_NEXT(node)) {
- msginfo = gtk_ctree_node_get_row_data(ctree, node);
- if (msginfo->score >= summaryview->important_score)
- break;
- if (msginfo->score > best_score) {
- best_score = msginfo->score;
- best_node = node;
- }
- }
-
- if (node != NULL)
- return node;
- else
- return best_node;
-}
-
-GtkCTreeNode * summary_find_prev_important_score(SummaryView *summaryview,
- GtkCTreeNode *current_node)
-{
- GtkCTree *ctree = GTK_CTREE(summaryview->ctree);
- GtkCTreeNode *node;
- MsgInfo *msginfo;
- gint best_score = MIN_SCORE;
- GtkCTreeNode *best_node = NULL;
-
- if (current_node)
- /*node = current_node;*/
- node = GTK_CTREE_NODE_PREV(current_node);
- else
- node = GTK_CTREE_NODE(GTK_CLIST(ctree)->row_list);
-
- for (; node != NULL; node = GTK_CTREE_NODE_PREV(node)) {
- msginfo = gtk_ctree_node_get_row_data(ctree, node);
- if (msginfo->score >= summaryview->important_score)
- break;
- if (msginfo->score > best_score) {
- best_score = msginfo->score;
- best_node = node;
- }
- }
-
- if (node != NULL)
- return node;
- else
- return best_node;
-}
-#endif
-
#define CURRENTLY_DISPLAYED(m) \
( (m->msgnum == displayed_msgnum) \
&& (!g_ascii_strcasecmp(m->folder->name,item->name)) )
+#define FOLDER_SHOWS_TO_HDR(i) \
+( folder_has_parent_of_type(i, F_OUTBOX) \
+ || folder_has_parent_of_type(i, F_DRAFT) \
+ || folder_has_parent_of_type(i, F_QUEUE) )
+
static void summary_switch_from_to(SummaryView *summaryview, FolderItem *item)
{
gboolean show_from = FALSE, show_to = FALSE;
if (!item)
return;
- if (folder_has_parent_of_type(item, F_OUTBOX)
- || folder_has_parent_of_type(item, F_DRAFT)
- || folder_has_parent_of_type(item, F_QUEUE))
+ if(FOLDER_SHOWS_TO_HDR(item))
show_to = TRUE;
else
show_from = TRUE;
inc_lock();
summary_lock(summaryview);
+ is_refresh = (item == summaryview->folder_item) ? TRUE : FALSE;
+
if (!prefs_common.summary_quicksearch_sticky
&& !prefs_common.summary_quicksearch_recurse
- && !quicksearch_is_running(summaryview->quicksearch)) {
+ && !quicksearch_is_running(summaryview->quicksearch)
+ && !is_refresh) {
quicksearch_set(summaryview->quicksearch, prefs_common.summary_quicksearch_type, "");
}
/* STATUSBAR_POP(summaryview->mainwin); */
- is_refresh = (item == summaryview->folder_item) ? TRUE : FALSE;
-
if (is_refresh) {
selected_msgnum = summary_get_msgnum(summaryview,
summaryview->selected);
if (quicksearch_is_active(summaryview->quicksearch)) {
GSList *not_killed;
-
+ gint num = 0, total = summaryview->folder_item->total_msgs;
+ statusbar_print_all(_("Searching in %s... \n"),
+ summaryview->folder_item->path ?
+ summaryview->folder_item->path : "(null)");
not_killed = NULL;
for (cur = mlist ; cur != NULL && cur->data != NULL ; cur = g_slist_next(cur)) {
MsgInfo * msginfo = (MsgInfo *) cur->data;
+ statusbar_progress_all(num++,total, 50);
+
if (!msginfo->hidden && quicksearch_match(summaryview->quicksearch, msginfo))
not_killed = g_slist_prepend(not_killed, msginfo);
else
procmsg_msginfo_free(msginfo);
+ GTK_EVENTS_FLUSH();
+ if (!quicksearch_is_active(summaryview->quicksearch)) {
+ break;
+ }
}
+ statusbar_progress_all(0,0,0);
+ statusbar_pop_all();
+
hidden_removed = TRUE;
if (quicksearch_is_running(summaryview->quicksearch)) {
/* only scan subfolders when quicksearch changed,
summaryview->folder_item);
main_window_cursor_normal(summaryview->mainwin);
}
-
+
+ if (!quicksearch_is_active(summaryview->quicksearch)) {
+ debug_print("search cancelled!\n");
+ gtk_clist_thaw(GTK_CLIST(ctree));
+ STATUSBAR_POP(summaryview->mainwin);
+ main_window_cursor_normal(summaryview->mainwin);
+ summary_unlock(summaryview);
+ inc_unlock();
+ summary_show(summaryview, summaryview->folder_item);
+ return FALSE;
+ }
g_slist_free(mlist);
mlist = not_killed;
}
}
} else {
switch (prefs_common.select_on_entry) {
- case SELECTONENTRY_NEW:
+ case SELECTONENTRY_MNU:
node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_MARKED, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
MSG_NEW, FALSE);
if (node == NULL)
node = summary_find_next_flagged_msg(summaryview, NULL,
MSG_UNREAD, FALSE);
break;
- case SELECTONENTRY_UNREAD:
+ case SELECTONENTRY_MUN:
node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_MARKED, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
MSG_UNREAD, FALSE);
if (node == NULL)
node = summary_find_next_flagged_msg(summaryview, NULL,
MSG_NEW, FALSE);
break;
+ case SELECTONENTRY_NMU:
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_NEW, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_MARKED, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_UNREAD, FALSE);
+ break;
+ case SELECTONENTRY_NUM:
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_NEW, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_UNREAD, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_MARKED, FALSE);
+ break;
+ case SELECTONENTRY_UNM:
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_UNREAD, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_NEW, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_MARKED, FALSE);
+ break;
+ case SELECTONENTRY_UMN:
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_UNREAD, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_MARKED, FALSE);
+ if (node == NULL)
+ node = summary_find_next_flagged_msg(summaryview, NULL,
+ MSG_NEW, FALSE);
+ break;
default:
node = NULL;
}
toolbar_main_set_sensitive(summaryview->mainwin);
gtk_clist_thaw(GTK_CLIST(ctree));
-
debug_print("\n");
STATUSBAR_PUSH(summaryview->mainwin, _("Done."));
STATUSBAR_POP(summaryview->mainwin);
return mlist;
}
-static void summary_set_menu_sensitive(SummaryView *summaryview)
+void summary_set_menu_sensitive(SummaryView *summaryview)
{
GtkItemFactory *ifactory = summaryview->popupfactory;
SensitiveCond state;
{"/Mark/Ignore thread" , M_TARGET_EXIST},
{"/Mark/Lock" , M_TARGET_EXIST},
{"/Mark/Unlock" , M_TARGET_EXIST},
+ {"/Mark/Mark as spam" , M_TARGET_EXIST|M_CAN_LEARN_SPAM},
+ {"/Mark/Mark as ham" , M_TARGET_EXIST|M_CAN_LEARN_SPAM},
{"/Color label" , M_TARGET_EXIST},
{"/Add sender to address book" , M_SINGLE_TARGET_EXIST},
{
GtkCTree *ctree = GTK_CTREE(summaryview->ctree);
+ if (summary_is_locked(summaryview))
+ return;
if (!summaryview->folder_item)
return;
if (node) {
gtkut_ctree_expand_parent_all(ctree, node);
if (do_refresh) {
+ summary_lock(summaryview);
GTK_EVENTS_FLUSH();
+ summary_unlock(summaryview);
gtk_widget_grab_focus(GTK_WIDGET(ctree));
if (GTK_CTREE_ROW(node) == NULL) {
g_warning("crash avoidance hack 1\n");
}
}
-static guint summary_get_msgnum(SummaryView *summaryview, GtkCTreeNode *node)
+guint summary_get_msgnum(SummaryView *summaryview, GtkCTreeNode *node)
{
GtkCTree *ctree =NULL;
MsgInfo *msginfo;
if (!node)
return 0;
msginfo = gtk_ctree_node_get_row_data(ctree, node);
- return msginfo->msgnum;
+ if (msginfo)
+ return msginfo->msgnum;
+ else
+ return -1;
}
static GtkCTreeNode *summary_find_prev_msg(SummaryView *summaryview,
msginfo = gtk_ctree_node_get_row_data(ctree, node);
- if (msginfo->folder && msginfo->folder->folder &&
+ if (msginfo && msginfo->folder && msginfo->folder->folder &&
msginfo->folder->folder->klass->type == F_NEWS)
news_flag_crosspost(msginfo);
static void summary_set_column_titles(SummaryView *summaryview)
{
GtkCList *clist = GTK_CLIST(summaryview->ctree);
+ FolderItem *item = summaryview->folder_item;
GtkWidget *hbox;
GtkWidget *label;
GtkWidget *arrow;
case S_COL_TO:
case S_COL_DATE:
case S_COL_NUMBER:
+ if(type == S_COL_FROM && item != NULL &&
+ FOLDER_SHOWS_TO_HDR(item))
+ type = S_COL_TO;
if (prefs_common.trans_hdr)
title = gettext(col_label[type]);
else
if (last_font && !strcmp(last_font, NORMAL_FONT))
update_font = FALSE;
- if (last_font)
- g_free(last_font);
+ g_free(last_font);
last_font = g_strdup(NORMAL_FONT);
Xstrdup_a(email_addr, addr, return NULL);
extract_address(email_addr);
- g_return_val_if_fail(*email_addr, NULL);
+ if (!*email_addr)
+ return NULL;
/*
* completion stuff must be already initialized
GTK_EVENTS_FLUSH();
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+
+ g_return_if_fail(msginfo);
if (new_window) {
MessageView *msgview;
if (!summaryview->selected) return;
if (!summaryview->folder_item) return;
- if (!folder_has_parent_of_type(summaryview->folder_item, F_OUTBOX)
- && !folder_has_parent_of_type(summaryview->folder_item, F_DRAFT)
- && !folder_has_parent_of_type(summaryview->folder_item, F_QUEUE))
+ if (!FOLDER_SHOWS_TO_HDR(summaryview->folder_item))
return;
msginfo = gtk_ctree_node_get_row_data(GTK_CTREE(summaryview->ctree),
if (MSG_IS_IGNORE_THREAD(flags)) {
gtk_ctree_node_set_pixmap(ctree, row, col_pos[S_COL_STATUS],
ignorethreadxpm, ignorethreadxpmmask);
+ } else if (MSG_IS_SPAM(flags)) {
+ gtk_ctree_node_set_pixmap(ctree, row, col_pos[S_COL_STATUS],
+ spamxpm, spamxpmmask);
} else if (MSG_IS_NEW(flags)) {
gtk_ctree_node_set_pixmap(ctree, row, col_pos[S_COL_STATUS],
newxpm, newxpmmask);
}
gtk_ctree_node_set_foreground
(ctree, row, &summaryview->color_marked);
-#if 0
- } else if ((global_scoring ||
- summaryview->folder_item->prefs->scoring) &&
- (msginfo->score >= summaryview->important_score) &&
- (MSG_IS_MARKED(msginfo->flags) || MSG_IS_MOVE(msginfo->flags) || MSG_IS_COPY(msginfo->flags))) {
- gtk_ctree_node_set_text(ctree, row, S_COL_MARK, "!");
- gtk_ctree_node_set_foreground(ctree, row,
- &summaryview->color_important);
-#endif
} else {
gtk_ctree_node_set_text(ctree, row, col_pos[S_COL_MARK], "");
}
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
if (MSG_IS_DELETED(msginfo->flags))
summaryview->deleted--;
if (MSG_IS_MOVE(msginfo->flags))
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
if (MSG_IS_DELETED(msginfo->flags))
summaryview->deleted--;
if (MSG_IS_MOVE(msginfo->flags)) {
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
if (!MSG_IS_LOCKED(msginfo->flags))
return;
procmsg_msginfo_set_to_folder(msginfo, NULL);
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
if(!(MSG_IS_NEW(msginfo->flags) || MSG_IS_UNREAD(msginfo->flags)))
return;
{
GtkCTree *ctree = GTK_CTREE(summaryview->ctree);
GtkCTreeNode *node;
+ AlertValue val;
+
+ if (prefs_common.ask_mark_all_read) {
+ val = alertpanel_full(_("Mark all as read"),
+ _("Do you really want to mark all mails in this "
+ "folder as read ?"), GTK_STOCK_NO, GTK_STOCK_YES, NULL,
+ TRUE, NULL, ALERT_QUESTION, G_ALERTALTERNATE);
+ if (val == G_ALERTDEFAULT ||
+ val == (G_ALERTDEFAULT|G_ALERTDISABLE))
+ return;
+ else if (val == (G_ALERTALTERNATE|G_ALERTDISABLE))
+ prefs_common.ask_mark_all_read = FALSE;
+ }
+
START_LONG_OPERATION(summaryview);
folder_item_set_batch(summaryview->folder_item, TRUE);
for (node = GTK_CTREE_NODE(GTK_CLIST(ctree)->row_list); node != NULL;
summary_status_show(summaryview);
}
+void summary_mark_as_spam(SummaryView *summaryview, guint action, GtkWidget *widget)
+{
+ GtkCTree *ctree = GTK_CTREE(summaryview->ctree);
+ GList *cur;
+ gboolean is_spam = action;
+ GSList *msgs = NULL;
+ gboolean immediate_exec = prefs_common.immediate_exec;
+ gboolean moved = FALSE;
+ prefs_common.immediate_exec = FALSE;
+
+ START_LONG_OPERATION(summaryview);
+
+ for (cur = GTK_CLIST(ctree)->selection; cur != NULL && cur->data != NULL; cur = cur->next) {
+ GtkCTreeNode *row = GTK_CTREE_NODE(cur->data);
+ MsgInfo *msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ if (msginfo)
+ msgs = g_slist_prepend(msgs, msginfo);
+ }
+
+ if (procmsg_spam_learner_learn(NULL, msgs, is_spam) == 0) {
+ for (cur = GTK_CLIST(ctree)->selection; cur != NULL && cur->data != NULL; cur = cur->next) {
+ GtkCTreeNode *row = GTK_CTREE_NODE(cur->data);
+ MsgInfo *msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ if (!msginfo)
+ continue;
+ if (is_spam) {
+ summary_msginfo_change_flags(msginfo, MSG_SPAM, 0, MSG_NEW|MSG_UNREAD, 0);
+ if (procmsg_spam_get_folder() != summaryview->folder_item) {
+ summary_move_row_to(summaryview, row, procmsg_spam_get_folder());
+ moved = TRUE;
+ }
+ } else {
+ summary_msginfo_unset_flags(msginfo, MSG_SPAM, 0);
+ }
+ }
+ } else {
+ log_error(_("An error happened while learning.\n"));
+ }
+
+ g_slist_free(msgs);
+
+ prefs_common.immediate_exec = immediate_exec;
+
+ END_LONG_OPERATION(summaryview);
+
+ if (prefs_common.immediate_exec && moved) {
+ summary_execute(summaryview);
+ }
+
+ summary_status_show(summaryview);
+}
+
+
static void summary_mark_row_as_unread(SummaryView *summaryview,
GtkCTreeNode *row)
{
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
if (MSG_IS_DELETED(msginfo->flags)) {
procmsg_msginfo_set_to_folder(msginfo, NULL);
summary_msginfo_unset_flags(msginfo, MSG_DELETED, 0);
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
if (MSG_IS_LOCKED(msginfo->flags)) return;
cur = cur->next) {
GtkCTreeNode *row = GTK_CTREE_NODE(cur->data);
msginfo = gtk_ctree_node_get_row_data(ctree, row);
- if (msginfo->total_size != 0 &&
+ if (msginfo && msginfo->total_size != 0 &&
msginfo->size != (off_t)msginfo->total_size)
partial_mark_for_delete(msginfo);
}
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
if (MSG_IS_DELETED(msginfo->flags))
summaryview->deleted--;
if (MSG_IS_MOVE(msginfo->flags))
g_return_if_fail(to_folder != NULL);
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
if (MSG_IS_LOCKED(msginfo->flags))
return;
g_return_if_fail(to_folder != NULL);
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
procmsg_msginfo_set_to_folder(msginfo, to_folder);
if (MSG_IS_DELETED(msginfo->flags))
summaryview->deleted--;
if (GTK_CLIST(ctree)->selection->next) {
GList *item;
for (item = GTK_CLIST(ctree)->selection->next; item != NULL; item=item->next) {
- msginfo = gtk_ctree_node_get_row_data(ctree, (GtkCTreeNode*)item->data);
+ msginfo = gtk_ctree_node_get_row_data(ctree, GTK_CTREE_NODE(item->data));
if (!msginfo) break;
src = procmsg_get_message_file(msginfo);
if (append_file(src, dest, TRUE) < 0)
gtk_clist_freeze(clist);
+ main_window_cursor_wait(summaryview->mainwin);
+
if (summaryview->threaded)
summary_unthread_for_exec(summaryview);
(summaryview, node);
}
- gtk_ctree_remove_node(ctree, node);
+ gtk_sctree_remove_node((GtkSCTree *)ctree, node);
}
folder_item_update_thaw();
gtk_ctree_node_moveto(ctree, summaryview->selected, 0, 0.5, 0);
summary_unlock(summaryview);
-
+
+ main_window_cursor_normal(summaryview->mainwin);
+
if (move_val < 0)
summary_show(summaryview, summaryview->folder_item);
return TRUE;
procmsg_msginfo_free((MsgInfo *)cur->data);
g_slist_free(summaryview->mlist);
summaryview->mlist = NULL;
+ return val;
}
- return val;
+ return 0;
}
static void summary_execute_move_func(GtkCTree *ctree, GtkCTreeNode *node,
}
}
-void summary_unthread(SummaryView *summaryview)
-{
- GtkCTree *ctree = GTK_CTREE(summaryview->ctree);
- GtkCTreeNode *node;
- GtkCTreeNode *child;
- GtkCTreeNode *sibling;
- GtkCTreeNode *next_child;
-
- summary_lock(summaryview);
-
- debug_print("Unthreading...");
- STATUSBAR_PUSH(summaryview->mainwin, _("Unthreading..."));
- main_window_cursor_wait(summaryview->mainwin);
-
- g_signal_handlers_block_by_func(G_OBJECT(ctree),
- summary_tree_collapsed, summaryview);
- gtk_clist_freeze(GTK_CLIST(ctree));
-
- for (node = GTK_CTREE_NODE(GTK_CLIST(ctree)->row_list);
- node != NULL; node = GTK_CTREE_NODE_NEXT(node)) {
- child = GTK_CTREE_ROW(node)->children;
- sibling = GTK_CTREE_ROW(node)->sibling;
-
- while (child != NULL) {
- next_child = GTK_CTREE_ROW(child)->sibling;
- gtk_ctree_move(ctree, child, NULL, sibling);
- child = next_child;
- }
- }
-
- /* CLAWS: and sort it */
- gtk_sctree_sort_recursive(ctree, NULL);
-
- gtk_clist_thaw(GTK_CLIST(ctree));
- g_signal_handlers_unblock_by_func(G_OBJECT(ctree),
- G_CALLBACK(summary_tree_collapsed), summaryview);
-
- debug_print("done.\n");
- STATUSBAR_POP(summaryview->mainwin);
- main_window_cursor_normal(summaryview->mainwin);
-
- summaryview->threaded = FALSE;
-
- summary_unlock(summaryview);
-}
-
static void summary_unthread_for_exec(SummaryView *summaryview)
{
GtkCTreeNode *node;
gint color_index;
msginfo = gtk_ctree_node_get_row_data(ctree, node);
+ g_return_if_fail(msginfo);
color_index = labelcolor == 0 ? -1 : (gint)labelcolor - 1;
ctree_style = gtk_widget_get_style(GTK_WIDGET(ctree));
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
summary_msginfo_change_flags(msginfo, MSG_COLORLABEL_TO_FLAGS(labelcolor), 0,
MSG_CLABEL_FLAG_MASK, 0);
if (!sel) return;
menu = GTK_MENU_SHELL(summaryview->colorlabel_menu);
+
g_return_if_fail(menu != NULL);
Xalloca(items, (N_COLOR_LABELS + 1) * sizeof(GtkWidget *), return);
GINT_TO_POINTER(0));
}
-static void summary_colorlabel_menu_create(SummaryView *summaryview)
+static void summary_colorlabel_menu_create(SummaryView *summaryview, gboolean refresh)
{
GtkWidget *label_menuitem;
GtkWidget *menu;
g_object_set_data(G_OBJECT(item), "summaryview", summaryview);
gtk_widget_show(item);
+ gtk_widget_add_accelerator(item, "activate",
+ summaryview->popupfactory->accel_group,
+ GDK_0, GDK_CONTROL_MASK,
+ GTK_ACCEL_LOCKED | GTK_ACCEL_VISIBLE);
+
item = gtk_menu_item_new();
gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);
gtk_widget_show(item);
/* create pixmap/label menu items */
for (i = 0; i < N_COLOR_LABELS; i++) {
- item = colorlabel_create_check_color_menu_item(i);
+ item = colorlabel_create_check_color_menu_item(
+ i, refresh, SUMMARY_COLORMENU);
gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);
g_signal_connect(G_OBJECT(item), "activate",
G_CALLBACK(summary_colorlabel_menu_item_activate_cb),
summaryview->colorlabel_menu = menu;
}
+static gboolean summary_popup_menu(GtkWidget *widget, gpointer data)
+{
+ SummaryView *summaryview = (SummaryView *)data;
+ summaryview->display_msg = messageview_is_visible(summaryview->messageview);
+
+ gtk_menu_popup(GTK_MENU(summaryview->popupmenu), NULL, NULL,
+ NULL, NULL, 0, gtk_get_current_event_time());
+ return TRUE;
+}
+
static GtkWidget *summary_ctree_create(SummaryView *summaryview)
{
GtkWidget *ctree;
gtk_ctree_set_line_style(GTK_CTREE(ctree), GTK_CTREE_LINES_DOTTED);
gtk_ctree_set_expander_style(GTK_CTREE(ctree),
GTK_CTREE_EXPANDER_SQUARE);
-#if 0
- gtk_ctree_set_line_style(GTK_CTREE(ctree), GTK_CTREE_LINES_NONE);
- gtk_ctree_set_expander_style(GTK_CTREE(ctree),
- GTK_CTREE_EXPANDER_TRIANGLE);
-#endif
gtk_ctree_set_indent(GTK_CTREE(ctree), 12);
g_object_set_data(G_OBJECT(ctree), "summaryview", (gpointer)summaryview);
g_signal_connect(G_OBJECT(ctree), "button_press_event",
G_CALLBACK(summary_button_pressed),
summaryview);
+ g_signal_connect(G_OBJECT(ctree), "popup-menu",
+ G_CALLBACK(summary_popup_menu), summaryview);
g_signal_connect(G_OBJECT(ctree), "button_release_event",
G_CALLBACK(summary_button_released),
summaryview);
return FALSE;
}
-void summary_pass_key_press_event(SummaryView *summaryview, GdkEventKey *event)
+gboolean summary_pass_key_press_event(SummaryView *summaryview, GdkEventKey *event)
{
- summary_key_pressed(summaryview->ctree, event, summaryview);
+ return summary_key_pressed(summaryview->ctree, event, summaryview);
}
#define BREAK_ON_MODIFIER_KEY() \
static void summary_open_row(GtkSCTree *sctree, SummaryView *summaryview)
{
- if (folder_has_parent_of_type(summaryview->folder_item, F_OUTBOX)
- || folder_has_parent_of_type(summaryview->folder_item, F_DRAFT)
- || folder_has_parent_of_type(summaryview->folder_item, F_QUEUE))
+ if (FOLDER_SHOWS_TO_HDR(summaryview->folder_item))
summary_reedit(summaryview);
else
summary_open_msg(summaryview);
msginfo = gtk_ctree_node_get_row_data(ctree, row);
g_return_if_fail(msginfo != NULL);
+ toolbar_set_learn_button
+ (summaryview->mainwin->toolbar,
+ MSG_IS_SPAM(msginfo->flags)?LEARN_HAM:LEARN_SPAM);
+
switch (column < 0 ? column : summaryview->col_state[column].type) {
case S_COL_MARK:
if (!MSG_IS_DELETED(msginfo->flags) &&
if (MSG_IS_UNREAD(msginfo->flags)) {
summary_mark_row_as_read(summaryview, row);
summary_status_show(summaryview);
+ } else if (MSG_IS_SPAM(msginfo->flags)) {
+ if (procmsg_spam_learner_learn(msginfo, NULL, FALSE) == 0)
+ summary_msginfo_unset_flags(msginfo, MSG_SPAM, 0);
+ else
+ log_error(_("An error happened while learning.\n"));
} else if (!MSG_IS_REPLIED(msginfo->flags) &&
!MSG_IS_FORWARDED(msginfo->flags)) {
marked_unread = TRUE;
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
summary_msginfo_change_flags(msginfo, MSG_IGNORE_THREAD, 0, MSG_NEW | MSG_UNREAD, 0);
MsgInfo *msginfo;
msginfo = gtk_ctree_node_get_row_data(ctree, row);
+ g_return_if_fail(msginfo);
summary_msginfo_unset_flags(msginfo, MSG_IGNORE_THREAD, 0);
if (*found_ignore) return;
else {
msginfo = gtk_ctree_node_get_row_data(ctree, row);
- *found_ignore = MSG_IS_IGNORE_THREAD(msginfo->flags);
+ *found_ignore = msginfo && MSG_IS_IGNORE_THREAD(msginfo->flags);
}
}
stock_pixmap_gdk(ctree, STOCK_PIXMAP_KEY, &keyxpm, &keyxpmmask);
stock_pixmap_gdk(ctree, STOCK_PIXMAP_GPG_SIGNED, &gpgsignedxpm, &gpgsignedxpmmask);
stock_pixmap_gdk(ctree, STOCK_PIXMAP_CLIP_GPG_SIGNED, &clipgpgsignedxpm, &clipgpgsignedxpmmask);
+ stock_pixmap_gdk(ctree, STOCK_PIXMAP_SPAM, &spamxpm, &spamxpmmask);
pixmap = stock_pixmap_widget(summaryview->hbox, STOCK_PIXMAP_DIR_OPEN);
gtk_box_pack_start(GTK_BOX(summaryview->hbox), pixmap, FALSE, FALSE, 4);
summary_set_column_titles(summaryview);
}
+void summary_reflect_prefs_custom_colors(SummaryView *summaryview)
+{
+ GtkMenuShell *menu;
+ GList *cur;
+
+ /* re-create colorlabel submenu */
+ menu = GTK_MENU_SHELL(summaryview->colorlabel_menu);
+ g_return_if_fail(menu != NULL);
+
+ /* clear items. get item pointers. */
+ for (cur = menu->children; cur != NULL && cur->data != NULL; cur = cur->next) {
+ gtk_menu_item_remove_submenu(GTK_MENU_ITEM(cur->data));
+ }
+ summary_colorlabel_menu_create(summaryview, TRUE);
+}
+
/*
* Harvest addresses for selected messages in summary view.
*/
msgList = NULL;
for( cur = GTK_CLIST(ctree)->selection; cur != NULL && cur->data != NULL; cur = cur->next ) {
msginfo = gtk_ctree_node_get_row_data( ctree, GTK_CTREE_NODE(cur->data) );
+ if (!msginfo)
+ continue;
msgList = g_list_append( msgList, GUINT_TO_POINTER( msginfo->msgnum ) );
}
addressbook_harvest( summaryview->folder_item, TRUE, msgList );
summaryview->thread_collapsed = item->thread_collapsed;
/* Scoring */
-#if 0
- if (global_scoring || item->prefs->scoring) {
- summaryview->important_score = prefs_common.important_score;
- if (item->prefs->important_score >
- summaryview->important_score)
- summaryview->important_score =
- item->prefs->important_score;
- }
-#endif
}
void summary_save_prefs_to_folderitem(SummaryView *summaryview, FolderItem *item)
summary_select_node(summaryview, node, TRUE, TRUE);
}
-void summaryview_export_mbox_list(SummaryView *summaryview)
+gint summaryview_export_mbox_list(SummaryView *summaryview)
+/* return values: -2 skipped, -1 error, 0 OK */
{
GSList *list = summary_get_selected_msg_list(summaryview);
gchar *mbox = filesel_select_file_save(_("Export to mbox file"), NULL);
+ gint ret;
if (mbox == NULL || list == NULL)
- return;
+ return -1;
- export_list_to_mbox(list, mbox);
+ ret = export_list_to_mbox(list, mbox);
g_slist_free(list);
g_free(mbox);
+ return ret;
}
void summaryview_lock(SummaryView *summaryview, FolderItem *item)