#include "prefs_folder_item.h"
#include "compose.h"
#include "manage_window.h"
+#include "stock_pixmap.h"
#include "inc.h"
#include "gtkutils.h"
#include "utils.h"
gint column,
GdkEvent *event,
gpointer data);
+static void account_row_moved (GtkCList *clist,
+ gint source_row,
+ gint dest_row);
static void account_key_pressed (GtkWidget *widget,
GdkEventKey *event,
gpointer data);
GList *cur;
PrefsAccount *ac;
+ g_return_val_if_fail(address != NULL, NULL);
+ g_return_val_if_fail(smtp_server != NULL, NULL);
+
for (cur = account_list; cur != NULL; cur = cur->next) {
ac = (PrefsAccount *)cur->data;
if (!strcmp2(address, ac->address) &&
GList *cur;
PrefsAccount *ac;
+ g_return_val_if_fail(address != NULL, NULL);
+
for (cur = account_list; cur != NULL; cur = cur->next) {
ac = (PrefsAccount *)cur->data;
- if (ac->protocol != A_NNTP && strcasestr(address, ac->address))
+ if (ac->protocol != A_NNTP && ac->address &&
+ strcasestr(address, ac->address))
return ac;
}
gtk_signal_connect (GTK_OBJECT (clist), "select_row",
GTK_SIGNAL_FUNC (account_selected), NULL);
+ gtk_signal_connect (GTK_OBJECT (clist), "row_move",
+ GTK_SIGNAL_FUNC (account_row_moved), NULL);
vbox2 = gtk_vbox_new (FALSE, 0);
gtk_widget_show (vbox2);
GTK_SIGNAL_FUNC (account_edit_close),
NULL);
- PIXMAP_CREATE(clist, markxpm, markxpmmask, mark_xpm);
- PIXMAP_CREATE(clist, checkboxonxpm, checkboxonxpmmask, checkbox_on_xpm);
- PIXMAP_CREATE(clist, checkboxoffxpm, checkboxoffxpmmask,
- checkbox_off_xpm);
+ stock_pixmap_gdk(clist, STOCK_PIXMAP_MARK, &markxpm, &markxpmmask);
+ stock_pixmap_gdk(clist, STOCK_PIXMAP_CHECKBOX_ON,
+ &checkboxonxpm, &checkboxonxpmmask);
+ stock_pixmap_gdk(clist, STOCK_PIXMAP_CHECKBOX_OFF,
+ &checkboxoffxpm, &checkboxoffxpmmask);
edit_account.window = window;
edit_account.clist = clist;
account_clist_set();
}
-static void account_delete_references_recursive(const GNode *node, const gint account)
+static gboolean account_delete_references_func(GNode *node, gpointer data)
{
- /* the son */
- if (node->data) {
- FolderItem *item = node->data;
- if (item->prefs) /* && item->prefs->stype == F_NORMAL */
- if (item->prefs->default_account == account) {
- item->prefs->enable_default_account = FALSE;
- item->prefs->default_account = 0;
- prefs_folder_item_save_config(item);
- }
- }
- /* its children (vertical dive) */
- if (node->children)
- account_delete_references_recursive(node->children, account);
- /* its brothers (horizontal dive) */
- if (node->next)
- account_delete_references_recursive(node->next, account);
+ FolderItem *item;
+ gint account;
+
+ g_return_val_if_fail(node->data != NULL, FALSE);
+
+ item = FOLDER_ITEM(node->data);
+ account = GPOINTER_TO_INT(data);
+
+ if(!item->prefs) /* && item->prefs->stype == F_NORMAL */
+ return FALSE;
+ if(item->prefs->default_account != account)
+ return FALSE;
+
+ item->prefs->enable_default_account = FALSE;
+ item->prefs->default_account = 0;
+ prefs_folder_item_save_config(item);
}
static void account_delete(void)
for (; list != NULL; list = list->next) {
folder = FOLDER(list->data);
if (folder->node) /* && folder->type == F_? */
- account_delete_references_recursive(folder->node, ac_prefs->account_id);
+ g_node_traverse(folder->node, G_PRE_ORDER,
+ G_TRAVERSE_ALL, -1,
+ account_delete_references_func,
+ GINT_TO_POINTER(ac_prefs->account_id));
}
}
if (!clist->selection) return;
row = GPOINTER_TO_INT(clist->selection->data);
- if (row > 0) {
+ if (row > 0)
gtk_clist_row_move(clist, row, row - 1);
- account_list_set();
- }
}
static void account_down(void)
if (!clist->selection) return;
row = GPOINTER_TO_INT(clist->selection->data);
- if (row < clist->rows - 1) {
+ if (row < clist->rows - 1)
gtk_clist_row_move(clist, row, row + 1);
- account_list_set();
- }
}
static void account_set_default(void)
}
}
+static void account_row_moved(GtkCList *clist, gint source_row, gint dest_row)
+{
+ account_list_set();
+ if (gtk_clist_row_is_visible(clist, dest_row) != GTK_VISIBILITY_FULL) {
+ gtk_clist_moveto(clist, dest_row, -1,
+ source_row < dest_row ? 1.0 : 0.0, 0.0);
+ }
+}
+
static void account_key_pressed(GtkWidget *widget, GdkEventKey *event,
gpointer data)
{
{
GtkCList *clist = GTK_CLIST(edit_account.clist);
GList *cur;
- gint prev_row;
+ gint row = -1, prev_row = -1;
if (clist->selection)
prev_row = GPOINTER_TO_INT(clist->selection->data);
- else
- prev_row = -1;
gtk_clist_freeze(clist);
gtk_clist_clear(clist);
for (cur = account_list; cur != NULL; cur = cur->next) {
- gint row;
-
row = account_clist_set_row((PrefsAccount *)cur->data, -1);
if ((PrefsAccount *)cur->data == cur_account) {
gtk_clist_select_row(clist, row, -1);
}
if (prev_row >= 0) {
- gtk_clist_select_row(clist, prev_row, -1);
- gtkut_clist_set_focus_row(clist, prev_row);
+ row = prev_row;
+ gtk_clist_select_row(clist, row, -1);
+ gtkut_clist_set_focus_row(clist, row);
}
+ if (row >= 0 &&
+ gtk_clist_row_is_visible(clist, row) != GTK_VISIBILITY_FULL)
+ gtk_clist_moveto(clist, row, -1, 0.5, 0);
+
gtk_clist_thaw(clist);
}