# HG changeset patch # User Mark Doliner # Date 1074145314 0 # Node ID 24159041e8f488dd0f690a127173cce7adc505f7 # Parent c0ee65d9453c0ca2573c2cd5ff505946f807fddb [gaim-migrate @ 8809] Make ctrl+[, ], pgup and pgdown wrap around when switching tabs. Removed a silly function. Got ready to clean the pan in the sink from dinner. committer: Tailor Script diff -r c0ee65d9453c -r 24159041e8f4 src/gtkconv.c --- a/src/gtkconv.c Thu Jan 15 04:21:06 2004 +0000 +++ b/src/gtkconv.c Thu Jan 15 05:41:54 2004 +0000 @@ -124,7 +124,6 @@ /* Prototypes. <-- because Paco-Paco hates this comment. */ static void set_toggle(GtkWidget *tb, gboolean active); -static void move_next_tab(GaimConversation *conv); static void do_bold(GtkWidget *bold, GaimGtkConversation *gtkconv); static void do_italic(GtkWidget *italic, GaimGtkConversation *gtkconv); static void do_underline(GtkWidget *underline, GaimGtkConversation *gtkconv); @@ -1322,16 +1321,30 @@ return TRUE; break; - case GDK_Page_Up: - if (curconv > 0) - gaim_conv_window_switch_conversation(win, curconv - 1); + case GDK_Page_Down: + case '[': + gaim_conv_window_switch_conversation(win, (curconv + numconvs - 1) % numconvs); return TRUE; break; - case GDK_Page_Down: - if (curconv + 1 < numconvs) - gaim_conv_window_switch_conversation(win, curconv + 1); + case GDK_Page_Up: + case ']': + case GDK_Tab: + gaim_conv_window_switch_conversation(win, (curconv + 1) % numconvs); + + return TRUE; + break; + + case 'l': + gtk_imhtml_clear(GTK_IMHTML(gtkconv->imhtml)); + g_string_free(conv->history, TRUE); + + return TRUE; + break; + + case 'z': + gtk_window_iconify(GTK_WINDOW(gtkwin->window)); return TRUE; break; @@ -1340,6 +1353,24 @@ if (gaim_prefs_get_bool("/gaim/gtk/conversations/html_shortcuts")) { switch (event->keyval) { + case 'b': /* ctrl-b is GDK_Left, which moves backwards. */ + case 'B': + set_toggle(gtkconv->toolbar.bold, + !gtk_toggle_button_get_active( + GTK_TOGGLE_BUTTON(gtkconv->toolbar.bold))); + + return TRUE; + break; + + case 'f': + case 'F': + set_toggle(gtkconv->toolbar.font, + !gtk_toggle_button_get_active( + GTK_TOGGLE_BUTTON(gtkconv->toolbar.font))); + + return TRUE; + break; + case 'i': case 'I': set_toggle(gtkconv->toolbar.italic, @@ -1358,15 +1389,6 @@ return TRUE; break; - case 'b': /* ctrl-b is GDK_Left, which moves backwards. */ - case 'B': - set_toggle(gtkconv->toolbar.bold, - !gtk_toggle_button_get_active( - GTK_TOGGLE_BUTTON(gtkconv->toolbar.bold))); - - return TRUE; - break; - case '-': set_toggle(gtkconv->toolbar.smaller_size, !gtk_toggle_button_get_active( @@ -1393,15 +1415,6 @@ return TRUE; break; #endif - - case 'f': - case 'F': - set_toggle(gtkconv->toolbar.font, - !gtk_toggle_button_get_active( - GTK_TOGGLE_BUTTON(gtkconv->toolbar.font))); - - return TRUE; - break; } } /* End of switch */ @@ -1435,38 +1448,7 @@ } } - if (event->keyval == 'l') { - gtk_imhtml_clear(GTK_IMHTML(gtkconv->imhtml)); - g_string_free(conv->history, TRUE); - conv->history = g_string_new(""); - - return TRUE; - } - else if (event->keyval == 'z') { - gtk_window_iconify(GTK_WINDOW(gtkwin->window)); - - return TRUE; - } - else if (event->keyval == '[') { - gaim_conv_window_switch_conversation(win, - gaim_conversation_get_index(conv) - 1); - - return TRUE; - } - else if (event->keyval == ']') { - gaim_conv_window_switch_conversation(win, - gaim_conversation_get_index(conv) + 1); - - return TRUE; - } - else if (event->keyval == GDK_Tab) { - move_next_tab(conv); - - return TRUE; - } - - return FALSE; - } + } else /* If ALT (or whatever) was held down... */ if (event->state & GDK_MOD1_MASK) { @@ -1478,9 +1460,7 @@ return TRUE; } - - return FALSE; - } + } else /* If neither CTRL nor ALT were held down... */ switch (event->keyval) { @@ -3863,60 +3843,6 @@ } static void -move_next_tab(GaimConversation *conv) -{ - GaimConversation *next_conv = NULL; - GaimConvWindow *win; - GList *l; - int index, i; - - win = gaim_conversation_get_window(conv); - index = gaim_conversation_get_index(conv); - - /* First check the tabs after this position. */ - for (l = g_list_nth(gaim_conv_window_get_conversations(win), index); - l != NULL; - l = l->next) { - - next_conv = (GaimConversation *)l->data; - - if (gaim_conversation_get_unseen(next_conv) > 0) - break; - - next_conv = NULL; - } - - if (next_conv == NULL) { - - /* Now check before this position. */ - for (l = gaim_conv_window_get_conversations(win), i = 0; - l != NULL && i < index; - l = l->next) { - - next_conv = (GaimConversation *)l->data; - - if (gaim_conversation_get_unseen(next_conv) > 0) - break; - - next_conv = NULL; - } - - if (next_conv == NULL) { - /* Okay, just grab the next conversation tab. */ - if (index == gaim_conv_window_get_conversation_count(win) - 1) - next_conv = gaim_conv_window_get_conversation_at(win, 0); - else - next_conv = gaim_conv_window_get_conversation_at(win, index + 1); - } - } - - if (next_conv != NULL && next_conv != conv) { - gaim_conv_window_switch_conversation(win, - gaim_conversation_get_index(next_conv)); - } -} - -static void conv_dnd_recv(GtkWidget *widget, GdkDragContext *dc, guint x, guint y, GtkSelectionData *sd, guint info, guint t, GaimConversation *conv)