+2003-04-05 [christoph] 0.8.11claws72
+
+ * src/account.c
+ * src/folder.[ch]
+ * src/folderview.c
+ * src/imap.c
+ * src/inc.c
+ * src/main.c
+ * src/mainwindow.c
+ * src/mbox_folder.c
+ * src/mh.c
+ * src/mimeview.h
+ * src/msgcache.[ch]
+ * src/news.c
+ * src/procmime.h
+ * src/procmsg.[ch]
+ * src/setup.c
+ * src/gtk/gtkutils.c
+ o rename structure field names class and new to klass and
+ new_msgs, to allow including files in C++
+ o add 'extern "C"' block to some header files
+ o add MsgInfoList and MsgNumberList as alias for GSList for
+ developers to know what type of list is expected
+
+ * src/plugins/image_viewer/plugin.c
+ * src/plugins/image_viewer/viewer.[ch]
+ * src/plugins/image_viewer/viewerprefs.[ch]
+ rename function names to prevent conflicts
+
2003-04-05 [paul] 0.8.11claws71
* sync with 0.8.11cvs18
MICRO_VERSION=11
INTERFACE_AGE=0
BINARY_AGE=0
-EXTRA_VERSION=claws71
+EXTRA_VERSION=claws72
VERSION=$MAJOR_VERSION.$MINOR_VERSION.$MICRO_VERSION$EXTRA_VERSION
dnl set $target
ac_prefs->folder = REMOTE_FOLDER(folder);
folder_add(folder);
if (ac_prefs->protocol == A_IMAP4)
- folder->class->create_tree(folder);
+ folder->klass->create_tree(folder);
folderview_set_all();
}
}
ap->folder = REMOTE_FOLDER(folder);
folder_add(folder);
if (ap->protocol == A_IMAP4)
- folder->class->create_tree(folder);
+ folder->klass->create_tree(folder);
}
}
}
return classlist;
}
-void folder_register_class(FolderClass *class)
+void folder_register_class(FolderClass *klass)
{
- debug_print("registering folder class %s\n", class->idstr);
- classlist = g_slist_append(classlist, class);
+ debug_print("registering folder class %s\n", klass->idstr);
+ classlist = g_slist_append(classlist, klass);
}
-Folder *folder_new(FolderClass *class, const gchar *name, const gchar *path)
+Folder *folder_new(FolderClass *klass, const gchar *name, const gchar *path)
{
Folder *folder = NULL;
FolderItem *item;
- g_return_val_if_fail(class != NULL, NULL);
+ g_return_val_if_fail(klass != NULL, NULL);
name = name ? name : path;
- folder = class->new(name, path);
+ folder = klass->new_folder(name, path);
/* Create root folder item */
item = folder_item_new(folder, name, NULL);
void folder_destroy(Folder *folder)
{
g_return_if_fail(folder != NULL);
- g_return_if_fail(folder->class->destroy != NULL);
+ g_return_if_fail(folder->klass->destroy_folder != NULL);
folder_list = g_list_remove(folder_list, folder);
g_free(folder->name);
g_free(folder);
- folder->class->destroy(folder);
+ folder->klass->destroy_folder(folder);
}
void folder_local_folder_destroy(LocalFolder *lfolder)
{
FolderItem *item = NULL;
- if (folder->class->item_new) {
- item = folder->class->item_new(folder);
+ if (folder->klass->item_new) {
+ item = folder->klass->item_new(folder);
} else {
item = g_new0(FolderItem, 1);
}
item->name = g_strdup(name);
item->path = g_strdup(path);
item->mtime = 0;
- item->new = 0;
- item->unread = 0;
- item->unreadmarked = 0;
- item->total = 0;
+ item->new_msgs = 0;
+ item->unread_msgs = 0;
+ item->unreadmarked_msgs = 0;
+ item->total_msgs = 0;
item->last_num = -1;
item->cache = NULL;
item->no_sub = FALSE;
g_free(item->path);
if (item->folder != NULL) {
- if(item->folder->class->item_destroy) {
- item->folder->class->item_destroy(item->folder, item);
+ if(item->folder->klass->item_destroy) {
+ item->folder->klass->item_destroy(item->folder, item);
} else {
g_free(item);
}
{
GHashTable *pptable;
- if (!folder->class->scan_tree)
+ if (!folder->klass->scan_tree)
return;
pptable = folder_persist_prefs_new(folder);
folder_tree_destroy(folder);
- folder->class->scan_tree(folder);
+ folder->klass->scan_tree(folder);
g_node_traverse(folder->node, G_POST_ORDER, G_TRAVERSE_ALL, -1, folder_scan_tree_func, pptable);
folder_persist_prefs_free(pptable);
{
FolderItem *new_item;
- new_item = parent->folder->class->create_folder(parent->folder, parent, name);
+ new_item = parent->folder->klass->create_folder(parent->folder, parent, name);
if (new_item)
new_item->cache = msgcache_new();
struct TotalMsgCount
{
- guint new;
- guint unread;
- guint unreadmarked;
- guint total;
+ guint new_msgs;
+ guint unread_msgs;
+ guint unreadmarked_msgs;
+ guint total_msgs;
};
struct FuncToAllFoldersData
{
struct TotalMsgCount *count = (struct TotalMsgCount *)data;
- count->new += item->new;
- count->unread += item->unread;
- count->unreadmarked += item->unreadmarked;
- count->total += item->total;
+ count->new_msgs += item->new_msgs;
+ count->unread_msgs += item->unread_msgs;
+ count->unreadmarked_msgs += item->unreadmarked_msgs;
+ count->total_msgs += item->total_msgs;
}
-void folder_count_total_msgs(guint *new, guint *unread, guint *unreadmarked, guint *total)
+void folder_count_total_msgs(guint *new_msgs, guint *unread_msgs, guint *unreadmarked_msgs, guint *total_msgs)
{
struct TotalMsgCount count;
- count.new = count.unread = count.unreadmarked = count.total = 0;
+ count.new_msgs = count.unread_msgs = count.unreadmarked_msgs = count.total_msgs = 0;
debug_print("Counting total number of messages...\n");
folder_func_to_all_folders(folder_count_total_msgs_func, &count);
- *new = count.new;
- *unread = count.unread;
- *unreadmarked = count.unreadmarked;
- *total = count.total;
+ *new_msgs = count.new_msgs;
+ *unread_msgs = count.unread_msgs;
+ *unreadmarked_msgs = count.unreadmarked_msgs;
+ *total_msgs = count.total_msgs;
}
Folder *folder_find_from_path(const gchar *path)
return NULL;
}
-Folder *folder_find_from_name(const gchar *name, FolderClass *class)
+Folder *folder_find_from_name(const gchar *name, FolderClass *klass)
{
GList *list;
Folder *folder;
for (list = folder_list; list != NULL; list = list->next) {
folder = list->data;
- if (folder->class == class && strcmp2(name, folder->name) == 0)
+ if (folder->klass == klass && strcmp2(name, folder->name) == 0)
return folder;
}
g_return_val_if_fail(folder != NULL, NULL);
- type_str = folder->class->idstr;
+ type_str = folder->klass->idstr;
return g_strconcat("#", type_str, "/", folder->name, NULL);
}
* the folder knows the ui string and how to abbrev
*/
if (!item->parent) {
- name = g_strconcat(item->name, " (", item->folder->class->uistr, ")", NULL);
+ name = g_strconcat(item->name, " (", item->folder->klass->uistr, ")", NULL);
} else {
if (FOLDER_CLASS(item->folder) == news_get_class() &&
item->path && !strcmp2(item->name, item->path))
folder->queue && folder->trash)
continue;
- if (folder->class->create_tree(folder) < 0) {
+ if (folder->klass->create_tree(folder) < 0) {
g_warning("%s: can't create the folder tree.\n",
LOCAL_FOLDER(folder)->rootpath);
continue;
g_return_if_fail(item != NULL);
- if (item->new) {
+ if (item->new_msgs) {
mlist = folder_item_get_msg_list(item);
for (cur = mlist ; cur != NULL ; cur = cur->next) {
MsgInfo * msginfo;
folder = item->folder;
g_return_val_if_fail(folder != NULL, -1);
- g_return_val_if_fail(folder->class->get_num_list != NULL, -1);
+ g_return_val_if_fail(folder->klass->get_num_list != NULL, -1);
debug_print("Scanning folder %s for cache changes.\n", item->path);
/* Get list of messages for folder and cache */
- if (folder->class->get_num_list(item->folder, item, &folder_list) < 0) {
+ if (folder->klass->get_num_list(item->folder, item, &folder_list) < 0) {
debug_print("Error fetching list of message numbers\n");
return(-1);
}
- if (!folder->class->check_msgnum_validity ||
- folder->class->check_msgnum_validity(folder, item)) {
+ if (!folder->klass->check_msgnum_validity ||
+ folder->klass->check_msgnum_validity(folder, item)) {
if (!item->cache)
folder_item_read_cache(item);
cache_list = msgcache_get_msg_list(item->cache);
MsgInfo *msginfo;
msginfo = msgcache_get_msg(item->cache, folder_cur_num);
- if (folder->class->is_msg_changed && folder->class->is_msg_changed(folder, item, msginfo)) {
+ if (folder->klass->is_msg_changed && folder->klass->is_msg_changed(folder, item, msginfo)) {
msgcache_remove_msg(item->cache, msginfo->msgnum);
new_list = g_slist_prepend(new_list, GINT_TO_POINTER(msginfo->msgnum));
procmsg_msginfo_free(msginfo);
g_slist_free(folder_list);
if (new_list != NULL) {
- if (folder->class->get_msginfos) {
- newmsg_list = folder->class->get_msginfos(folder, item, new_list);
- } else if (folder->class->get_msginfo) {
+ if (folder->klass->get_msginfos) {
+ newmsg_list = folder->klass->get_msginfos(folder, item, new_list);
+ } else if (folder->klass->get_msginfo) {
GSList *elem;
for (elem = new_list; elem != NULL; elem = g_slist_next(elem)) {
guint num;
num = GPOINTER_TO_INT(elem->data);
- msginfo = folder->class->get_msginfo(folder, item, num);
+ msginfo = folder->klass->get_msginfo(folder, item, num);
if (msginfo != NULL) {
newmsg_list = g_slist_prepend(newmsg_list, msginfo);
debug_print("Added newly found message %d to cache.\n", num);
}
g_slist_free(exists_list);
- item->new = newcnt;
- item->unread = unreadcnt;
- item->total = totalcnt;
- item->unreadmarked = unreadmarkedcnt;
+ item->new_msgs = newcnt;
+ item->unread_msgs = unreadcnt;
+ item->total_msgs = totalcnt;
+ item->unreadmarked_msgs = unreadmarkedcnt;
update_flags |= F_ITEM_UPDATE_MSGCNT;
if ((msginfo = msgcache_get_msg(item->cache, num)) != NULL)
return msginfo;
- g_return_val_if_fail(folder->class->get_msginfo, NULL);
- if ((msginfo = folder->class->get_msginfo(folder, item, num)) != NULL) {
+ g_return_val_if_fail(folder->klass->get_msginfo, NULL);
+ if ((msginfo = folder->klass->get_msginfo(folder, item, num)) != NULL) {
msgcache_add_msg(item->cache, msginfo);
return msginfo;
}
folder = item->folder;
- g_return_val_if_fail(folder->class->fetch_msg != NULL, NULL);
+ g_return_val_if_fail(folder->klass->fetch_msg != NULL, NULL);
- return folder->class->fetch_msg(folder, item, num);
+ return folder->klass->fetch_msg(folder, item, num);
}
static gint folder_item_get_msg_num_by_file(FolderItem *dest, const gchar *file)
{
/* update folder stats */
if (MSG_IS_NEW(newmsginfo->flags))
- item->new++;
+ item->new_msgs++;
if (MSG_IS_UNREAD(newmsginfo->flags))
- item->unread++;
+ item->unread_msgs++;
if (MSG_IS_UNREAD(newmsginfo->flags) && procmsg_msg_has_marked_parent(newmsginfo))
- item->unreadmarked++;
- item->total++;
+ item->unreadmarked_msgs++;
+ item->total_msgs++;
copy_msginfo_flags(flagsource, newmsginfo);
folder_item_read_cache(item);
if (MSG_IS_NEW(msginfo->flags) && !MSG_IS_IGNORE_THREAD(msginfo->flags))
- msginfo->folder->new--;
+ msginfo->folder->new_msgs--;
if (MSG_IS_UNREAD(msginfo->flags) && !MSG_IS_IGNORE_THREAD(msginfo->flags))
- msginfo->folder->unread--;
+ msginfo->folder->unread_msgs--;
if (MSG_IS_UNREAD(msginfo->flags) && procmsg_msg_has_marked_parent(msginfo))
- msginfo->folder->unreadmarked--;
- msginfo->folder->total--;
+ msginfo->folder->unreadmarked_msgs--;
+ msginfo->folder->total_msgs--;
msgcache_remove_msg(item->cache, msginfo->msgnum);
folder_item_update(msginfo->folder, F_ITEM_UPDATE_MSGCNT | F_ITEM_UPDATE_CONTENT);
folder = dest->folder;
- g_return_val_if_fail(folder->class->add_msg != NULL, -1);
+ g_return_val_if_fail(folder->klass->add_msg != NULL, -1);
if (!dest->cache)
folder_item_read_cache(dest);
- num = folder->class->add_msg(folder, dest, file, FALSE);
+ num = folder->klass->add_msg(folder, dest, file, FALSE);
if (num > 0) {
- msginfo = folder->class->get_msginfo(folder, dest, num);
+ msginfo = folder->klass->get_msginfo(folder, dest, num);
if (msginfo != NULL) {
add_msginfo_to_cache(dest, msginfo, NULL);
new_id = folder_item_get_identifier(new_item);
debug_print("updating rules : %s => %s\n", old_id, new_id);
- src->folder->class->remove_folder(src->folder, src);
+ src->folder->klass->remove_folder(src->folder, src);
folder_write_list();
if (old_id != NULL && new_id != NULL)
folder = dest->folder;
- g_return_val_if_fail(folder->class->copy_msg != NULL, -1);
- g_return_val_if_fail(folder->class->remove_msg != NULL, -1);
+ g_return_val_if_fail(folder->klass->copy_msg != NULL, -1);
+ g_return_val_if_fail(folder->klass->remove_msg != NULL, -1);
/*
* Copy messages to destination folder and
if (!item && msginfo->folder != NULL)
item = msginfo->folder;
- num = folder->class->copy_msg(folder, dest, msginfo);
+ num = folder->klass->copy_msg(folder, dest, msginfo);
newmsgnums = g_slist_append(newmsgnums, GINT_TO_POINTER(num));
}
continue;
if (!folderscan &&
- ((newmsginfo = folder->class->get_msginfo(folder, dest, num)) != NULL)) {
- newmsginfo = folder->class->get_msginfo(folder, dest, num);
+ ((newmsginfo = folder->klass->get_msginfo(folder, dest, num)) != NULL)) {
+ newmsginfo = folder->klass->get_msginfo(folder, dest, num);
add_msginfo_to_cache(dest, newmsginfo, msginfo);
procmsg_msginfo_free(newmsginfo);
} else if ((newmsginfo = msgcache_get_msg(dest->cache, num)) != NULL) {
l2 = g_slist_next(l2);
if (num >= 0) {
- item->folder->class->remove_msg(item->folder,
+ item->folder->klass->remove_msg(item->folder,
msginfo->folder,
msginfo->msgnum);
remove_msginfo_from_cache(item, msginfo);
}
- if (folder->class->finished_copy)
- folder->class->finished_copy(folder, dest);
+ if (folder->klass->finished_copy)
+ folder->klass->finished_copy(folder, dest);
g_slist_free(newmsgnums);
return lastnum;
folder = dest->folder;
- g_return_val_if_fail(folder->class->copy_msg != NULL, -1);
+ g_return_val_if_fail(folder->klass->copy_msg != NULL, -1);
/*
* Copy messages to destination folder and
for (l = msglist ; l != NULL ; l = g_slist_next(l)) {
MsgInfo * msginfo = (MsgInfo *) l->data;
- num = folder->class->copy_msg(folder, dest, msginfo);
+ num = folder->klass->copy_msg(folder, dest, msginfo);
newmsgnums = g_slist_append(newmsgnums, GINT_TO_POINTER(num));
}
continue;
if (!folderscan &&
- ((newmsginfo = folder->class->get_msginfo(folder, dest, num)) != NULL)) {
- newmsginfo = folder->class->get_msginfo(folder, dest, num);
+ ((newmsginfo = folder->klass->get_msginfo(folder, dest, num)) != NULL)) {
+ newmsginfo = folder->klass->get_msginfo(folder, dest, num);
add_msginfo_to_cache(dest, newmsginfo, msginfo);
procmsg_msginfo_free(newmsginfo);
} else if ((newmsginfo = msgcache_get_msg(dest->cache, num)) != NULL) {
}
}
- if (folder->class->finished_copy)
- folder->class->finished_copy(folder, dest);
+ if (folder->klass->finished_copy)
+ folder->klass->finished_copy(folder, dest);
g_slist_free(newmsgnums);
return lastnum;
folder = item->folder;
if (!item->cache) folder_item_read_cache(item);
- ret = folder->class->remove_msg(folder, item, num);
+ ret = folder->klass->remove_msg(folder, item, num);
msginfo = msgcache_get_msg(item->cache, num);
if (msginfo != NULL) {
folder = item->folder;
- g_return_val_if_fail(folder->class->remove_all_msg != NULL, -1);
+ g_return_val_if_fail(folder->klass->remove_all_msg != NULL, -1);
- result = folder->class->remove_all_msg(folder, item);
+ result = folder->klass->remove_all_msg(folder, item);
if (result == 0) {
- if (folder->class->finished_remove)
- folder->class->finished_remove(folder, item);
+ if (folder->klass->finished_remove)
+ folder->klass->finished_remove(folder, item);
folder_item_free_cache(item);
item->cache = msgcache_new();
- item->new = 0;
- item->unread = 0;
- item->unreadmarked = 0;
- item->total = 0;
+ item->new_msgs = 0;
+ item->unread_msgs = 0;
+ item->unreadmarked_msgs = 0;
+ item->total_msgs = 0;
folder_item_update(item, F_ITEM_UPDATE_MSGCNT | F_ITEM_UPDATE_CONTENT);
}
g_return_if_fail(item != NULL);
g_return_if_fail(msginfo != NULL);
- if (item->folder->class->change_flags != NULL) {
- item->folder->class->change_flags(item->folder, item, msginfo, newflags);
+ if (item->folder->klass->change_flags != NULL) {
+ item->folder->klass->change_flags(item->folder, item, msginfo, newflags);
} else {
msginfo->flags.perm_flags = newflags;
}
folder = item->folder;
- g_return_val_if_fail(folder->class->is_msg_changed != NULL, -1);
+ g_return_val_if_fail(folder->klass->is_msg_changed != NULL, -1);
- return folder->class->is_msg_changed(folder, item, msginfo);
+ return folder->klass->is_msg_changed(folder, item, msginfo);
}
gchar *folder_item_get_cache_file(FolderItem *item)
item = folder_item_new(folder, name, path);
item->stype = stype;
item->mtime = mtime;
- item->new = new;
- item->unread = unread;
- item->unreadmarked = unreadmarked;
- item->total = total;
+ item->new_msgs = new;
+ item->unread_msgs = unread;
+ item->unreadmarked_msgs = unreadmarked;
+ item->total_msgs = total;
item->no_sub = no_sub;
item->no_select = no_select;
item->collapsed = collapsed;
if (depth == 1) {
Folder *folder = item->folder;
- fprintf(fp, "<folder type=\"%s\"", folder->class->idstr);
+ fprintf(fp, "<folder type=\"%s\"", folder->klass->idstr);
if (folder->name)
PUT_ESCAPE_STR(fp, "name", folder->name);
if (FOLDER_TYPE(folder) == F_MH || FOLDER_TYPE(folder) == F_MBOX)
fprintf(fp,
" mtime=\"%lu\" new=\"%d\" unread=\"%d\" unreadmarked=\"%d\" total=\"%d\"",
- item->mtime, item->new, item->unread, item->unreadmarked, item->total);
+ item->mtime, item->new_msgs, item->unread_msgs, item->unreadmarked_msgs, item->total_msgs);
if (item->account)
fprintf(fp, " account_id=\"%d\"",
if (!is_dir_exist(tmpname)) {
debug_print("*TMP* creating %s\n", tmpname);
- processing_folder_item = processing_folder->class->create_folder(processing_folder,
+ processing_folder_item = processing_folder->klass->create_folder(processing_folder,
processing_folder->node->data,
PROCESSING_FOLDER_ITEM);
} else {
typedef struct _FolderItemUpdateData FolderItemUpdateData;
#define FOLDER(obj) ((Folder *)obj)
-#define FOLDER_TYPE(obj) (FOLDER(obj)->class->type)
+#define FOLDER_TYPE(obj) (FOLDER(obj)->klass->type)
-#define FOLDER_CLASS(obj) (FOLDER(obj)->class)
+#define FOLDER_CLASS(obj) (FOLDER(obj)->klass)
#define LOCAL_FOLDER(obj) ((LocalFolder *)obj)
#define REMOTE_FOLDER(obj) ((RemoteFolder *)obj)
struct _Folder
{
- FolderClass *class;
+ FolderClass *klass;
gchar *name;
PrefsAccount *account;
/* virtual functions */
/* Folder funtions */
- Folder *(*new) (const gchar *name,
+ Folder *(*new_folder) (const gchar *name,
const gchar *path);
- void (*destroy) (Folder *folder);
+ void (*destroy_folder) (Folder *folder);
void (*scan_tree) (Folder *folder);
gint (*create_tree) (Folder *folder);
gint num);
GSList *(*get_msginfos) (Folder *folder,
FolderItem *item,
- GSList *msgnum_list);
+ MsgNumberList *msgnum_list);
gchar *(*fetch_msg) (Folder *folder,
FolderItem *item,
gint num);
time_t mtime;
- gint new;
- gint unread;
- gint total;
- gint unreadmarked;
+ gint new_msgs;
+ gint unread_msgs;
+ gint total_msgs;
+ gint unreadmarked_msgs;
gint last_num;
};
void folder_system_init ();
-void folder_register_class (FolderClass *class);
+void folder_register_class (FolderClass *klass);
Folder *folder_new (FolderClass *type,
const gchar *name,
const gchar *path);
void folder_update_op_count (void);
void folder_func_to_all_folders (FolderItemFunc function,
gpointer data);
-void folder_count_total_msgs (guint *new,
- guint *unread,
- guint *unreadmarked,
- guint *total);
+void folder_count_total_msgs (guint *new_msgs,
+ guint *unread_msgs,
+ guint *unreadmarked_msgs,
+ guint *total_msgs);
Folder *folder_find_from_path (const gchar *path);
Folder *folder_find_from_name (const gchar *name,
- FolderClass *class);
+ FolderClass *klass);
FolderItem *folder_find_item_from_path (const gchar *path);
FolderClass *folder_get_class_from_string (const gchar *str);
gchar *folder_get_identifier (Folder *folder);
for (; node != NULL; node = gtkut_ctree_node_next(ctree, node)) {
item = gtk_ctree_node_get_row_data(ctree, node);
- if (item && item->unread > 0 && item->stype != F_TRASH)
+ if (item && item->unread_msgs > 0 && item->stype != F_TRASH)
return node;
}
unread = atoi(unread_str);
total = atoi(total_str);
- /* CLAWS: don't know why but this always seems to be true
- * when deleting messages. Somewhere claws does a folder
- * scan which sets all new, unread & total to the correct
- * values. It then enters this function, but leaves it
- * because new, unread and total are the same... */
-#ifndef CLAWS
- if (prev_row == row &&
- item->new == new &&
- item->unread == unread &&
- item->total == total)
- return;
-#endif
-
prev_row = row;
folderview_update_node(folderview, row);
g_return_if_fail(folder != NULL);
- if (!folder->class->scan_tree) return;
+ if (!folder->klass->scan_tree) return;
inc_lock();
window = label_window_create(_("Rebuilding folder tree..."));
if (!folder && !FOLDER_IS_LOCAL(item->folder)) continue;
folderview_scan_tree_func(item->folder, item, NULL);
- former_new = item->new;
+ former_new = item->new_msgs;
if (folder_item_scan(item) < 0) {
if (folder && !FOLDER_IS_LOCAL(folder))
break;
}
folderview_update_node(folderview, node);
- new_msgs += item->new;
+ new_msgs += item->new_msgs;
former_new_msgs += former_new;
}
if (node) {
item = gtk_ctree_node_get_row_data(ctree, node);
if (item) {
- if (item->new > 0 ||
- (item->stype == F_QUEUE && item->total > 0))
+ if (item->new_msgs > 0 ||
+ (item->stype == F_QUEUE && item->total_msgs > 0))
return TRUE;
}
node = GTK_CTREE_ROW(node)->children;
if (node) {
item = gtk_ctree_node_get_row_data(ctree, node);
if (item) {
- if (item->unread > 0 ||
- (item->stype == F_QUEUE && item->total > 0))
+ if (item->unread_msgs > 0 ||
+ (item->stype == F_QUEUE && item->total_msgs > 0))
return TRUE;
}
node = GTK_CTREE_ROW(node)->children;
else
add_unread_mark = FALSE;
- if (item->stype == F_QUEUE && item->total > 0 &&
+ if (item->stype == F_QUEUE && item->total_msgs > 0 &&
prefs_common.display_folder_unread) {
- str = g_strdup_printf("%s (%d%s)", name, item->total,
+ str = g_strdup_printf("%s (%d%s)", name, item->total_msgs,
add_unread_mark ? "+" : "");
gtk_ctree_set_node_info(ctree, node, str, FOLDER_SPACING,
xpm, mask, openxpm, openmask,
FALSE, GTK_CTREE_ROW(node)->expanded);
g_free(str);
- } else if ((item->unread > 0 || add_unread_mark) &&
+ } else if ((item->unread_msgs > 0 || add_unread_mark) &&
prefs_common.display_folder_unread) {
- if (item->unread > 0)
- str = g_strdup_printf("%s (%d%s%s)", name, item->unread,
+ if (item->unread_msgs > 0)
+ str = g_strdup_printf("%s (%d%s%s)", name, item->unread_msgs,
add_unread_mark ? "+" : "",
- item->unreadmarked > 0 ? "!":"");
+ item->unreadmarked_msgs > 0 ? "!":"");
else
str = g_strdup_printf("%s (+)", name);
gtk_ctree_set_node_info(ctree, node, str, FOLDER_SPACING,
g_free(str);
} else {
str = g_strdup_printf("%s%s", name,
- item->unreadmarked > 0 ? " (!)":"");
+ item->unreadmarked_msgs > 0 ? " (!)":"");
gtk_ctree_set_node_info(ctree, node, str, FOLDER_SPACING,
xpm, mask, openxpm, openmask,
gtk_ctree_node_set_text(ctree, node, COL_UNREAD, "-");
gtk_ctree_node_set_text(ctree, node, COL_TOTAL, "-");
} else {
- gtk_ctree_node_set_text(ctree, node, COL_NEW, itos(item->new));
- gtk_ctree_node_set_text(ctree, node, COL_UNREAD, itos(item->unread));
- gtk_ctree_node_set_text(ctree, node, COL_TOTAL, itos(item->total));
+ gtk_ctree_node_set_text(ctree, node, COL_NEW, itos(item->new_msgs));
+ gtk_ctree_node_set_text(ctree, node, COL_UNREAD, itos(item->unread_msgs));
+ gtk_ctree_node_set_text(ctree, node, COL_TOTAL, itos(item->total_msgs));
}
if (item->stype == F_OUTBOX || item->stype == F_DRAFT ||
use_bold = use_color = FALSE;
} else if (item->stype == F_QUEUE) {
/* highlight queue folder if there are any messages */
- use_bold = use_color = (item->total > 0);
+ use_bold = use_color = (item->total_msgs > 0);
} else {
/* if unread messages exist, print with bold font */
- use_bold = (item->unread > 0) || add_unread_mark;
+ use_bold = (item->unread_msgs > 0) || add_unread_mark;
/* if new messages exist, print with colored letter */
use_color =
- (item->new > 0) ||
+ (item->new_msgs > 0) ||
(add_unread_mark &&
folderview_have_new_children(folderview, node));
}
if (item->parent != NULL)
delete_folder = folder_scoring = folder_processing = TRUE;
}
- if (item->unread < 1)
+ if (item->unread_msgs < 1)
mark_all_read = FALSE;
}
Xstrdup_a(old_path, item->path, {g_free(new_folder); return;});
old_id = folder_item_get_identifier(item);
- if (item->folder->class->rename_folder(item->folder, item, new_folder) < 0) {
+ if (item->folder->klass->rename_folder(item->folder, item, new_folder) < 0) {
g_free(old_id);
g_free(new_folder);
return;
return;
}
- if (item->folder->class->rename_folder(item->folder, item, new_folder) < 0) {
+ if (item->folder->klass->rename_folder(item->folder, item, new_folder) < 0) {
g_free(new_folder);
return;
}
Xstrdup_a(old_path, item->path, return);
old_id = folder_item_get_identifier(item);
- if (item->folder->class->remove_folder(item->folder, item) < 0) {
+ if (item->folder->klass->remove_folder(item->folder, item) < 0) {
alertpanel_error(_("Can't remove the folder `%s'."), name);
if (folderview->opened == folderview->selected)
summary_show(folderview->summaryview,
{
gboolean flag = FALSE;
- if (!GTK_WIDGET_VISIBLE(widget) || !GTK_WIDGET_MAPPED(widget)) return;
+ if (!GTK_WIDGET_DRAWABLE(widget)) return;
gtk_signal_connect(GTK_OBJECT(widget), "draw",
GTK_SIGNAL_FUNC(gtkut_widget_draw_cb), &flag);
Folder *folder;
folder = (Folder *)g_new0(IMAPFolder, 1);
- folder->class = &imap_class;
+ folder->klass = &imap_class;
imap_folder_init(folder, name, path);
return folder;
&messages, &recent, &uid_next, &uid_validity, &unseen);
if (ok != IMAP_SUCCESS) return -1;
- item->new = unseen > 0 ? recent : 0;
- item->unread = unseen;
- item->total = messages;
+ item->new_msgs = unseen > 0 ? recent : 0;
+ item->unread_msgs = unseen;
+ item->total_msgs = messages;
item->last_num = (messages > 0 && uid_next > 0) ? uid_next - 1 : 0;
/* item->mtime = uid_validity; */
gint ok = IMAP_SUCCESS;
g_return_if_fail(folder != NULL);
- g_return_if_fail(folder->class == &imap_class);
+ g_return_if_fail(folder->klass == &imap_class);
g_return_if_fail(item != NULL);
g_return_if_fail(item->folder == folder);
g_return_if_fail(msginfo != NULL);
gboolean notify);
#define FOLDER_SUMMARY_MISMATCH(f, s) \
- (f) && (s) ? ((s)->newmsgs != (f)->new) || ((f)->unread != (s)->unread) || ((f)->total != (s)->messages) \
+ (f) && (s) ? ((s)->newmsgs != (f)->new_msgs) || ((f)->unread_msgs != (s)->unread) || ((f)->total_msgs != (s)->messages) \
: FALSE
/**
if (!queue) return -1;
folder_item_scan(queue);
- return queue->total;
+ return queue->total_msgs;
}
static void save_all_caches(FolderItem *item, gpointer data)
for (has_trash = 0, list = folder_get_list(); list != NULL; list = list->next) {
folder = FOLDER(list->data);
- if (folder && folder->trash && folder->trash->total > 0)
+ if (folder && folder->trash && folder->trash->total_msgs > 0)
has_trash++;
}
path);
g_free(path);
- if (folder->class->create_tree(folder) < 0) {
+ if (folder->klass->create_tree(folder) < 0) {
alertpanel_error(_("Creation of the mailbox failed.\n"
"Maybe some files already exist, or you don't have the permission to write there."));
folder_destroy(folder);
g_basename(path), path);
g_free(path);
- if (folder->class->create_tree(folder) < 0) {
+ if (folder->klass->create_tree(folder) < 0) {
alertpanel_error(_("Creation of the mailbox failed."));
folder_destroy(folder);
return;
if (selection == SUMMARY_SELECTED_SINGLE)
state |= M_SINGLE_TARGET_EXIST;
if (mainwin->summaryview->folder_item &&
- mainwin->summaryview->folder_item->folder->class->type == F_NEWS)
+ mainwin->summaryview->folder_item->folder->klass->type == F_NEWS)
state |= M_NEWS;
else
state |= M_NOT_NEWS;
Folder *folder;
folder = (Folder *)g_new0(MBOXFolder, 1);
- folder->class = &mbox_class;
+ folder->klass = &mbox_class;
mbox_folder_init(folder, name, path);
return folder;
cached = mbox_cache_get_mbox(mbox_path);
if (cached == NULL) {
- item->new = 0;
- item->unread = 0;
- item->total = 0;
+ item->new_msgs = 0;
+ item->unread_msgs = 0;
+ item->total_msgs = 0;
item->last_num = 0;
g_free(mbox_path);
return;
n_msg = mbox_cache_get_count(mbox_path);
if (n_msg == 0) {
- item->new = item->unread = item->total = 0;
+ item->new_msgs = item->unread_msgs = item->total_msgs = 0;
}
else {
gint new = 0;
unread ++;
}
- item->new = new;
- item->unread = unread;
- item->total = total;
+ item->new_msgs = new;
+ item->unread_msgs = unread;
+ item->total_msgs = total;
}
debug_print("Last number in dir %s = %d\n", mbox_path,
- item->total);
+ item->total_msgs);
item->last_num = n_msg;
g_free(mbox_path);
}
Folder *folder;
folder = (Folder *)g_new0(MHFolder, 1);
- folder->class = &mh_class;
+ folder->klass = &mh_class;
mh_folder_init(folder, name, path);
return folder;
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
-#ifndef __MIMEVIEW_H__
-#define __MIMEVIEW_H__
+#ifndef MIMEVIEW_H
+#define MIMEVIEW_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
#include <glib.h>
#include <gdk/gdk.h>
void mimeview_register_viewer_factory (MimeViewerFactory *factory);
void mimeview_unregister_viewer_factory (MimeViewerFactory *factory);
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
#endif /* __MIMEVIEW_H__ */
static void msgcache_get_msg_list_func(gpointer key, gpointer value, gpointer user_data)
{
- GSList **listptr = user_data;
+ MsgInfoList **listptr = user_data;
MsgInfo *msginfo = value;
*listptr = g_slist_prepend(*listptr, procmsg_msginfo_new_ref(msginfo));
}
-GSList *msgcache_get_msg_list(MsgCache *cache)
+MsgInfoList *msgcache_get_msg_list(MsgCache *cache)
{
- GSList *msg_list = NULL;
+ MsgInfoList *msg_list = NULL;
g_return_val_if_fail(cache != NULL, NULL);
#include "procmsg.h"
#include "folder.h"
-MsgCache *msgcache_new ();
-void msgcache_destroy (MsgCache *cache);
-MsgCache *msgcache_read_cache (FolderItem *item, const gchar *cache_file);
-void msgcache_read_mark (MsgCache *cache, const gchar *mark_file);
-gint msgcache_write (const gchar *cache_file, const gchar *mark_file, MsgCache *cache);
-void msgcache_add_msg (MsgCache *cache, MsgInfo *msginfo);
-void msgcache_remove_msg (MsgCache *cache, guint num);
-void msgcache_update_msg (MsgCache *cache, MsgInfo *msginfo);
-MsgInfo *msgcache_get_msg (MsgCache *cache, guint num);
-MsgInfo *msgcache_get_msg_by_id (MsgCache *cache, const gchar *msgid);
-GSList *msgcache_get_msg_list (MsgCache *cache);
-time_t msgcache_get_last_access_time (MsgCache *cache);
-gint msgcache_get_memory_usage (MsgCache *cache);
+MsgCache *msgcache_new ();
+void msgcache_destroy (MsgCache *cache);
+MsgCache *msgcache_read_cache (FolderItem *item,
+ const gchar *cache_file);
+void msgcache_read_mark (MsgCache *cache,
+ const gchar *mark_file);
+gint msgcache_write (const gchar *cache_file,
+ const gchar *mark_file,
+ MsgCache *cache);
+void msgcache_add_msg (MsgCache *cache,
+ MsgInfo *msginfo);
+void msgcache_remove_msg (MsgCache *cache,
+ guint num);
+void msgcache_update_msg (MsgCache *cache,
+ MsgInfo *msginfo);
+MsgInfo *msgcache_get_msg (MsgCache *cache,
+ guint num);
+MsgInfo *msgcache_get_msg_by_id (MsgCache *cache,
+ const gchar *msgid);
+MsgInfoList *msgcache_get_msg_list (MsgCache *cache);
+time_t msgcache_get_last_access_time (MsgCache *cache);
+gint msgcache_get_memory_usage (MsgCache *cache);
#endif
Folder *folder;
folder = (Folder *)g_new0(NewsFolder, 1);
- folder->class = &news_class;
+ folder->klass = &news_class;
news_folder_init(folder, name, path);
return folder;
}
if (num == 0) {
- item->new = item->unread = item->total = item->last_num = 0;
+ item->new_msgs = item->unread_msgs = item->total_msgs = item->last_num = 0;
return 0;
}
gint plugin_init(gchar **error)
{
- prefs_init();
- viewer_init();
+ image_viewer_prefs_init();
+ image_viewer_init();
return 0;
}
void plugin_done()
{
- viewer_done();
- prefs_done();
+ image_viewer_done();
+ image_viewer_prefs_done();
}
const gchar *plugin_name()
image_viewer_create,
};
-void viewer_init()
+void image_viewer_init()
{
mimeview_register_viewer_factory(&image_viewer_factory);
}
-void viewer_done()
+void image_viewer_done()
{
mimeview_unregister_viewer_factory(&image_viewer_factory);
}
#include "mimeview.h"
-void viewer_init();
-void viewer_done();
+void image_viewer_init();
+void image_viewer_done();
#endif
static struct ImageViewerPage imageviewer_page;
-void prefs_init()
+void image_viewer_prefs_init()
{
prefs_set_default(param);
prefs_read_config(param, PREFS_BLOCK_NAME, COMMON_RC);
prefs_gtk_register_page((PrefsPage *) &imageviewer_page);
}
-void prefs_done()
+void image_viewer_prefs_done()
{
prefs_gtk_unregister_page((PrefsPage *) &imageviewer_page);
}
extern ImageViewerPrefs imageviewerprefs;
-void prefs_init();
-void prefs_done();
+void image_viewer_prefs_init();
+void image_viewer_prefs_done();
#endif
static gboolean click_cb(GtkWidget * widget,
GdkEventButton * event, gpointer user_data)
{
-/*
MainWindow *mainwin;
+/*
mainwin = mainwindow_get_mainwindow();
- if (mainwin_hidden) {
- gtk_widget_show(mainwin->window);
- mainwin_hidden = FALSE;
+ if (GTK_WIDGET_VISIBLE(GTK_WIDGET(mainwin->window))) {
+ gtk_widget_hide_all(mainwin->window);
} else {
- gtk_widget_hide(mainwin->window);
- mainwin_hidden = TRUE;
+ gtk_widget_show_all(mainwin->window);
}
*/
-
return TRUE;
}
#ifndef __PROCMIME_H__
#define __PROCMIME_H__
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
MimeInfo *procmime_mimeinfo_insert (MimeInfo *parent,
MimeInfo *mimeinfo);
-void procmime_mimeinfo_replace (MimeInfo *old,
- MimeInfo *new);
+void procmime_mimeinfo_replace (MimeInfo *old_mimeinfo,
+ MimeInfo *new_mimeinfo);
MimeInfo *procmime_mimeinfo_next (MimeInfo *mimeinfo);
void renderer_read_config(void);
void renderer_write_config(void);
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
#endif /* __PROCMIME_H__ */
}
struct MarkSum {
- gint *new;
- gint *unread;
- gint *total;
+ gint *new_msgs;
+ gint *unread_msgs;
+ gint *total_msgs;
gint *min;
gint *max;
gint first;
for (cur = folder_get_list(); cur != NULL; cur = cur->next) {
trash = FOLDER(cur->data)->trash;
- if (trash && trash->total > 0)
+ if (trash && trash->total_msgs > 0)
folder_item_remove_all_msg(trash);
}
}
return (newsval != 0 ? newsval : mailval);
}
-static void update_folder_msg_counts(FolderItem *item, MsgInfo *msginfo, MsgPermFlags old)
+static void update_folder_msg_counts(FolderItem *item, MsgInfo *msginfo, MsgPermFlags old_flags)
{
- MsgPermFlags new = msginfo->flags.perm_flags;
+ MsgPermFlags new_flags = msginfo->flags.perm_flags;
/* NEW flag */
- if (!(old & MSG_NEW) && (new & MSG_NEW)) {
- item->new++;
+ if (!(old_flags & MSG_NEW) && (new_flags & MSG_NEW)) {
+ item->new_msgs++;
}
- if ((old & MSG_NEW) && !(new & MSG_NEW)) {
- item->new--;
+ if ((old_flags & MSG_NEW) && !(new_flags & MSG_NEW)) {
+ item->new_msgs--;
}
/* UNREAD flag */
- if (!(old & MSG_UNREAD) && (new & MSG_UNREAD)) {
- item->unread++;
+ if (!(old_flags & MSG_UNREAD) && (new_flags & MSG_UNREAD)) {
+ item->unread_msgs++;
if (procmsg_msg_has_marked_parent(msginfo))
- item->unreadmarked++;
+ item->unreadmarked_msgs++;
}
- if ((old & MSG_UNREAD) && !(new & MSG_UNREAD)) {
- item->unread--;
+ if ((old_flags & MSG_UNREAD) && !(new_flags & MSG_UNREAD)) {
+ item->unread_msgs--;
if (procmsg_msg_has_marked_parent(msginfo))
- item->unreadmarked--;
+ item->unreadmarked_msgs--;
}
/* MARK flag */
- if (!(old & MSG_MARKED) && (new & MSG_MARKED)) {
+ if (!(old_flags & MSG_MARKED) && (new_flags & MSG_MARKED)) {
procmsg_update_unread_children(msginfo, TRUE);
}
- if ((old & MSG_MARKED) && !(new & MSG_MARKED)) {
+ if ((old_flags & MSG_MARKED) && !(new_flags & MSG_MARKED)) {
procmsg_update_unread_children(msginfo, FALSE);
}
}
MsgInfo *tmp = (MsgInfo *)cur->data;
if(MSG_IS_UNREAD(tmp->flags) && !MSG_IS_IGNORE_THREAD(tmp->flags)) {
if(newly_marked)
- info->folder->unreadmarked++;
+ info->folder->unreadmarked_msgs++;
else
- info->folder->unreadmarked--;
+ info->folder->unreadmarked_msgs--;
folder_item_update(info->folder, F_ITEM_UPDATE_MSGCNT);
}
procmsg_msginfo_free(tmp);
typedef struct _MsgFlags MsgFlags;
typedef struct _MsgInfoUpdate MsgInfoUpdate;
+typedef GSList MsgInfoList;
+typedef GSList MsgNumberList;
+
typedef enum
{
MSG_NEW = 1 << 0,
gint procmsg_get_last_num_in_msg_list(GSList *mlist);
void procmsg_msg_list_free (GSList *mlist);
void procmsg_get_mark_sum (const gchar *folder,
- gint *new,
- gint *unread,
- gint *total,
+ gint *new_msgs,
+ gint *unread_msgs,
+ gint *total_msgs,
gint *min,
gint *max,
gint first);
folder = folder_new(mh_get_class(), !strcmp(path, "Mail") ? _("Mailbox") : g_basename(path), path);
g_free(path);
- if (folder->class->create_tree(folder) < 0) {
+ if (folder->klass->create_tree(folder) < 0) {
alertpanel_error(_("Creation of the mailbox failed.\n"
"Maybe some files already exist, or you don't have the permission to write there."));
folder_destroy(folder);