# HG changeset patch # User Nathan Walp # Date 1047957780 0 # Node ID 1c371e4244d6a6c5a6173cb1d151ca8fc327966d # Parent b4ca2cc6bed98277a80042a35052db445aa6336c [gaim-migrate @ 5142] brought to you by the letter T and the number 0, I give you tabless conversation windows. committer: Tailor Script diff -r b4ca2cc6bed9 -r 1c371e4244d6 src/conversation.c --- a/src/conversation.c Tue Mar 18 03:03:58 2003 +0000 +++ b/src/conversation.c Tue Mar 18 03:23:00 2003 +0000 @@ -904,7 +904,9 @@ * Create a window if one does not exist. If it does, use the last * created window. */ - if (windows == NULL) { + if (windows == NULL || + (type == GAIM_CONV_IM && !(im_options & OPT_IM_ONE_WINDOW)) || + (type == GAIM_CONV_CHAT && !(chat_options & OPT_CHAT_ONE_WINDOW))) { struct gaim_window *win; win = gaim_window_new(); diff -r b4ca2cc6bed9 -r 1c371e4244d6 src/gtkconv.c --- a/src/gtkconv.c Tue Mar 18 03:03:58 2003 +0000 +++ b/src/gtkconv.c Tue Mar 18 03:23:00 2003 +0000 @@ -3326,6 +3326,8 @@ gtk_notebook_set_tab_pos(GTK_NOTEBOOK(gtkwin->notebook), pos); gtk_notebook_set_scrollable(GTK_NOTEBOOK(gtkwin->notebook), TRUE); gtk_notebook_popup_enable(GTK_NOTEBOOK(gtkwin->notebook)); + gtk_notebook_set_show_tabs(GTK_NOTEBOOK(gtkwin->notebook), FALSE); + gtk_widget_show(gtkwin->notebook); g_signal_connect_after(G_OBJECT(gtkwin->notebook), "switch_page", @@ -3583,9 +3585,15 @@ gtk_widget_show(tab_cont); - /* Er, bug in notebooks? Switch to the page manually. */ - if (gaim_window_get_conversation_count(win) == 1) + if (gaim_window_get_conversation_count(win) == 1) { + /* Er, bug in notebooks? Switch to the page manually. */ gtk_notebook_set_current_page(GTK_NOTEBOOK(gtkwin->notebook), 0); + gtk_notebook_set_show_tabs(GTK_NOTEBOOK(gtkwin->notebook), + ((conv_type == GAIM_CONV_IM && im_options & OPT_IM_ONE_WINDOW) || + (conv_type == GAIM_CONV_CHAT && im_options & OPT_CHAT_ONE_WINDOW))); + } else { + gtk_notebook_set_show_tabs(GTK_NOTEBOOK(gtkwin->notebook), TRUE); + } if ((gtk_notebook_get_current_page(GTK_NOTEBOOK(gtkwin->notebook)) == 0) || (conv == g_list_nth_data(gaim_window_get_conversations(win), 0))) { @@ -3609,7 +3617,9 @@ struct gaim_gtk_window *gtkwin; struct gaim_gtk_conversation *gtkconv; unsigned int index; - + GaimConversationType conv_type; + + conv_type = gaim_conversation_get_type(conv); index = gaim_conversation_get_index(conv); gtkwin = GAIM_GTK_WINDOW(win); @@ -3620,8 +3630,16 @@ gtk_notebook_remove_page(GTK_NOTEBOOK(gtkwin->notebook), index); + /* go back to tabless if need be */ + if (gaim_window_get_conversation_count(win) <= 2) { + gtk_notebook_set_show_tabs(GTK_NOTEBOOK(gtkwin->notebook), + ((conv_type == GAIM_CONV_IM && im_options & OPT_IM_ONE_WINDOW) || + (conv_type == GAIM_CONV_CHAT && im_options & OPT_CHAT_ONE_WINDOW))); + } + + /* If this window is setup with an inactive gc, regenerate the menu. */ - if (gaim_conversation_get_type(conv) == GAIM_CONV_IM && + if (conv_type == GAIM_CONV_IM && gaim_conversation_get_gc(conv) == NULL) { generate_send_as_items(win, conv);