From 117a5fdb25cf8c322f1280e6d9653b3bb3816ec7 Mon Sep 17 00:00:00 2001 From: hiro Date: Fri, 22 Apr 2005 05:03:27 +0000 Subject: fixed widget refresh problem on rescan/check new. git-svn-id: svn://sylpheed.sraoss.jp/sylpheed/trunk@228 ee746299-78ed-0310-b773-934348b2243d --- src/folderview.c | 67 ++++++++++++++++++++++++++++---------------------------- 1 file changed, 33 insertions(+), 34 deletions(-) (limited to 'src/folderview.c') diff --git a/src/folderview.c b/src/folderview.c index 3277aa68..ad761cc7 100644 --- a/src/folderview.c +++ b/src/folderview.c @@ -803,6 +803,7 @@ static void folderview_rescan_tree(FolderView *folderview, Folder *folder) window = label_window_create(_("Rebuilding folder tree...")); summary_show(folderview->summaryview, NULL, FALSE); + GTK_EVENTS_FLUSH(); folder_set_ui_func(folder, folderview_scan_tree_func, NULL); if (folder->klass->scan_tree(folder) < 0) @@ -819,51 +820,49 @@ static void folderview_rescan_tree(FolderView *folderview, Folder *folder) void folderview_check_new(Folder *folder) { - GList *list; FolderItem *item; FolderView *folderview; GtkTreeModel *model; GtkTreeIter iter; gboolean valid; - for (list = folderview_list; list != NULL; list = list->next) { - folderview = (FolderView *)list->data; - model = GTK_TREE_MODEL(folderview->store); + folderview = (FolderView *)folderview_list->data; + model = GTK_TREE_MODEL(folderview->store); - if (folder && !FOLDER_IS_LOCAL(folder)) { - if (!main_window_toggle_online_if_offline - (folderview->mainwin)) - return; - } + if (folder && !FOLDER_IS_LOCAL(folder)) { + if (!main_window_toggle_online_if_offline + (folderview->mainwin)) + return; + } - inc_lock(); - main_window_lock(folderview->mainwin); - gtk_widget_set_sensitive(folderview->treeview, FALSE); - - for (valid = gtk_tree_model_get_iter_first(model, &iter); - valid; valid = gtkut_tree_model_next(model, &iter)) { - item = NULL; - gtk_tree_model_get(model, &iter, - COL_FOLDER_ITEM, &item, -1); - if (!item || !item->path || !item->folder) continue; - if (item->no_select) continue; - if (folder && folder != item->folder) continue; - if (!folder && !FOLDER_IS_LOCAL(item->folder)) continue; - - folderview_scan_tree_func(item->folder, item, NULL); - if (folder_item_scan(item) < 0) { - if (folder && !FOLDER_IS_LOCAL(folder)) - break; - } - folderview_update_row(folderview, &iter); - } + inc_lock(); + main_window_lock(folderview->mainwin); + gtk_widget_set_sensitive(folderview->treeview, FALSE); + GTK_EVENTS_FLUSH(); - gtk_widget_set_sensitive(folderview->treeview, TRUE); - main_window_unlock(folderview->mainwin); - inc_unlock(); - statusbar_pop_all(); + for (valid = gtk_tree_model_get_iter_first(model, &iter); + valid; valid = gtkut_tree_model_next(model, &iter)) { + item = NULL; + gtk_tree_model_get(model, &iter, + COL_FOLDER_ITEM, &item, -1); + if (!item || !item->path || !item->folder) continue; + if (item->no_select) continue; + if (folder && folder != item->folder) continue; + if (!folder && !FOLDER_IS_LOCAL(item->folder)) continue; + + folderview_scan_tree_func(item->folder, item, NULL); + if (folder_item_scan(item) < 0) { + if (folder && !FOLDER_IS_LOCAL(folder)) + break; + } + folderview_update_row(folderview, &iter); } + gtk_widget_set_sensitive(folderview->treeview, TRUE); + main_window_unlock(folderview->mainwin); + inc_unlock(); + statusbar_pop_all(); + folder_write_list(); } -- cgit v1.2.3