about summary refs log tree commit diff stats
path: root/src/window_list.c
diff options
context:
space:
mode:
authorJames Booth <boothj5@gmail.com>2016-07-24 15:14:46 +0100
committerJames Booth <boothj5@gmail.com>2016-07-24 15:14:46 +0100
commit5bc38b6bc2bdf135d7f483c204ce75a51a7126b5 (patch)
tree542f4c60f4c8d1d934ad2f65d0da3f674a15e9ca /src/window_list.c
parent8f213f22e7a9ec761e6f6fd77bd8e582ba7c7280 (diff)
downloadprofani-tty-5bc38b6bc2bdf135d7f483c204ce75a51a7126b5.tar.gz
Moved window_list.c
Diffstat (limited to 'src/window_list.c')
-rw-r--r--src/window_list.c1029
1 files changed, 0 insertions, 1029 deletions
diff --git a/src/window_list.c b/src/window_list.c
deleted file mode 100644
index 1e5ff426..00000000
--- a/src/window_list.c
+++ /dev/null
@@ -1,1029 +0,0 @@
-/*
- * window_list.c
- *
- * Copyright (C) 2012 - 2016 James Booth <boothj5@gmail.com>
- *
- * This file is part of Profanity.
- *
- * Profanity is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * Profanity is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with Profanity.  If not, see <https://www.gnu.org/licenses/>.
- *
- * In addition, as a special exception, the copyright holders give permission to
- * link the code of portions of this program with the OpenSSL library under
- * certain conditions as described in each individual source file, and
- * distribute linked combinations including the two.
- *
- * You must obey the GNU General Public License in all respects for all of the
- * code used other than OpenSSL. If you modify file(s) with this exception, you
- * may extend this exception to your version of the file(s), but you are not
- * obligated to do so. If you do not wish to do so, delete this exception
- * statement from your version. If you delete this exception statement from all
- * source files in the program, then also delete it here.
- *
- */
-
-#include "config.h"
-
-#include <string.h>
-#include <assert.h>
-#include <stdlib.h>
-
-#include <glib.h>
-
-#include "common.h"
-#include "xmpp/roster_list.h"
-#include "config/theme.h"
-#include "ui/ui.h"
-#include "ui/statusbar.h"
-#include "window_list.h"
-#include "plugins/plugins.h"
-#include "xmpp/xmpp.h"
-#include "config/preferences.h"
-
-static GHashTable *windows;
-static int current;
-static Autocomplete wins_ac;
-static Autocomplete wins_close_ac;
-
-void
-wins_init(void)
-{
-    windows = g_hash_table_new_full(g_direct_hash, g_direct_equal, NULL,
-        (GDestroyNotify)win_free);
-
-    ProfWin *console = win_create_console();
-    g_hash_table_insert(windows, GINT_TO_POINTER(1), console);
-
-    current = 1;
-
-    wins_ac = autocomplete_new();
-    autocomplete_add(wins_ac, "console");
-
-    wins_close_ac = autocomplete_new();
-    autocomplete_add(wins_close_ac, "all");
-    autocomplete_add(wins_close_ac, "read");
-}
-
-ProfWin*
-wins_get_console(void)
-{
-    return g_hash_table_lookup(windows, GINT_TO_POINTER(1));
-}
-
-gboolean
-wins_chat_exists(const char *const barejid)
-{
-    ProfChatWin *chatwin = wins_get_chat(barejid);
-    return (chatwin != NULL);
-}
-
-ProfChatWin*
-wins_get_chat(const char *const barejid)
-{
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type == WIN_CHAT) {
-            ProfChatWin *chatwin = (ProfChatWin*)window;
-            if (g_strcmp0(chatwin->barejid, barejid) == 0) {
-                g_list_free(values);
-                return chatwin;
-            }
-        }
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(values);
-    return NULL;
-}
-
-static gint
-_cmp_unsubscribed_wins(ProfChatWin *a, ProfChatWin *b)
-{
-    return g_strcmp0(a->barejid, b->barejid);
-}
-
-GList*
-wins_get_chat_unsubscribed(void)
-{
-    GList *result = NULL;
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type == WIN_CHAT) {
-            ProfChatWin *chatwin = (ProfChatWin*)window;
-            PContact contact = roster_get_contact(chatwin->barejid);
-            if (contact == NULL) {
-                result = g_list_insert_sorted(result, chatwin, (GCompareFunc)_cmp_unsubscribed_wins);
-            }
-        }
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(values);
-    return result;
-}
-
-ProfMucConfWin*
-wins_get_muc_conf(const char *const roomjid)
-{
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type == WIN_MUC_CONFIG) {
-            ProfMucConfWin *confwin = (ProfMucConfWin*)window;
-            if (g_strcmp0(confwin->roomjid, roomjid) == 0) {
-                g_list_free(values);
-                return confwin;
-            }
-        }
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(values);
-    return NULL;
-}
-
-ProfMucWin*
-wins_get_muc(const char *const roomjid)
-{
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type == WIN_MUC) {
-            ProfMucWin *mucwin = (ProfMucWin*)window;
-            if (g_strcmp0(mucwin->roomjid, roomjid) == 0) {
-                g_list_free(values);
-                return mucwin;
-            }
-        }
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(values);
-    return NULL;
-}
-
-ProfPrivateWin*
-wins_get_private(const char *const fulljid)
-{
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type == WIN_PRIVATE) {
-            ProfPrivateWin *privatewin = (ProfPrivateWin*)window;
-            if (g_strcmp0(privatewin->fulljid, fulljid) == 0) {
-                g_list_free(values);
-                return privatewin;
-            }
-        }
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(values);
-    return NULL;
-}
-
-ProfPluginWin*
-wins_get_plugin(const char *const tag)
-{
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type == WIN_PLUGIN) {
-            ProfPluginWin *pluginwin = (ProfPluginWin*)window;
-            if (g_strcmp0(pluginwin->tag, tag) == 0) {
-                g_list_free(values);
-                return pluginwin;
-            }
-        }
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(values);
-    return NULL;
-}
-
-void
-wins_close_plugin(char *tag)
-{
-    ProfWin *toclose = wins_get_by_string(tag);
-    if (toclose == NULL) {
-        return;
-    }
-
-    int index = wins_get_num(toclose);
-    ui_close_win(index);
-
-    if (prefs_get_boolean(PREF_WINS_AUTO_TIDY)) {
-        wins_tidy();
-    }
-}
-
-GList*
-wins_get_private_chats(const char *const roomjid)
-{
-    GList *result = NULL;
-    GString *prefix = g_string_new(roomjid);
-    g_string_append(prefix, "/");
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type == WIN_PRIVATE) {
-            ProfPrivateWin *privatewin = (ProfPrivateWin*)window;
-            if (roomjid == NULL || g_str_has_prefix(privatewin->fulljid, prefix->str)) {
-                result = g_list_append(result, privatewin);
-            }
-        }
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(values);
-    g_string_free(prefix, TRUE);
-    return result;
-}
-
-void
-wins_private_nick_change(const char *const roomjid, const char *const oldnick, const char *const newnick)
-{
-    Jid *oldjid = jid_create_from_bare_and_resource(roomjid, oldnick);
-
-    ProfPrivateWin *privwin = wins_get_private(oldjid->fulljid);
-    if (privwin) {
-        free(privwin->fulljid);
-
-        Jid *newjid = jid_create_from_bare_and_resource(roomjid, newnick);
-        privwin->fulljid = strdup(newjid->fulljid);
-        win_vprint((ProfWin*)privwin, '!', 0, NULL, 0, THEME_THEM, NULL, "** %s is now known as %s.", oldjid->resourcepart, newjid->resourcepart);
-
-        autocomplete_remove(wins_ac, oldjid->fulljid);
-        autocomplete_remove(wins_close_ac, oldjid->fulljid);
-        autocomplete_add(wins_ac, newjid->fulljid);
-        autocomplete_add(wins_close_ac, newjid->fulljid);
-
-        jid_destroy(newjid);
-    }
-
-    jid_destroy(oldjid);
-}
-
-void
-wins_change_nick(const char *const barejid, const char *const oldnick, const char *const newnick)
-{
-    ProfChatWin *chatwin = wins_get_chat(barejid);
-    if (chatwin) {
-        if (oldnick) {
-            autocomplete_remove(wins_ac, oldnick);
-            autocomplete_remove(wins_close_ac, oldnick);
-        }
-        autocomplete_add(wins_ac, newnick);
-        autocomplete_add(wins_close_ac, newnick);
-    }
-}
-
-void
-wins_remove_nick(const char *const barejid, const char *const oldnick)
-{
-    ProfChatWin *chatwin = wins_get_chat(barejid);
-    if (chatwin) {
-        if (oldnick) {
-            autocomplete_remove(wins_ac, oldnick);
-            autocomplete_remove(wins_close_ac, oldnick);
-        }
-    }
-}
-
-ProfWin*
-wins_get_current(void)
-{
-    if (windows) {
-        return g_hash_table_lookup(windows, GINT_TO_POINTER(current));
-    } else {
-        return NULL;
-    }
-}
-
-GList*
-wins_get_nums(void)
-{
-    return g_hash_table_get_keys(windows);
-}
-
-void
-wins_set_current_by_num(int i)
-{
-    ProfWin *window = g_hash_table_lookup(windows, GINT_TO_POINTER(i));
-    if (window) {
-        current = i;
-        if (window->type == WIN_CHAT) {
-            ProfChatWin *chatwin = (ProfChatWin*) window;
-            assert(chatwin->memcheck == PROFCHATWIN_MEMCHECK);
-            chatwin->unread = 0;
-            plugins_on_chat_win_focus(chatwin->barejid);
-        } else if (window->type == WIN_MUC) {
-            ProfMucWin *mucwin = (ProfMucWin*) window;
-            assert(mucwin->memcheck == PROFMUCWIN_MEMCHECK);
-            mucwin->unread = 0;
-            mucwin->unread_mentions = FALSE;
-            mucwin->unread_triggers = FALSE;
-            plugins_on_room_win_focus(mucwin->roomjid);
-        } else if (window->type == WIN_PRIVATE) {
-            ProfPrivateWin *privatewin = (ProfPrivateWin*) window;
-            privatewin->unread = 0;
-        }
-    }
-}
-
-ProfWin*
-wins_get_by_num(int i)
-{
-    return g_hash_table_lookup(windows, GINT_TO_POINTER(i));
-}
-
-ProfWin*
-wins_get_by_string(char *str)
-{
-    if (g_strcmp0(str, "console") == 0) {
-        ProfWin *conswin = wins_get_console();
-        if (conswin) {
-            return conswin;
-        } else {
-            return NULL;
-        }
-    }
-
-    if (g_strcmp0(str, "xmlconsole") == 0) {
-        ProfXMLWin *xmlwin = wins_get_xmlconsole();
-        if (xmlwin) {
-            return (ProfWin*)xmlwin;
-        } else {
-            return NULL;
-        }
-    }
-
-    ProfChatWin *chatwin = wins_get_chat(str);
-    if (chatwin) {
-        return (ProfWin*)chatwin;
-    }
-
-    jabber_conn_status_t conn_status = connection_get_status();
-    if (conn_status == JABBER_CONNECTED) {
-        char *barejid = roster_barejid_from_name(str);
-        if (barejid) {
-            ProfChatWin *chatwin = wins_get_chat(barejid);
-            if (chatwin) {
-                return (ProfWin*)chatwin;
-            }
-        }
-    }
-
-    ProfMucWin *mucwin = wins_get_muc(str);
-    if (mucwin) {
-        return (ProfWin*)mucwin;
-    }
-
-    ProfPrivateWin *privwin = wins_get_private(str);
-    if (privwin) {
-        return (ProfWin*)privwin;
-    }
-
-    ProfPluginWin *pluginwin = wins_get_plugin(str);
-    if (pluginwin) {
-        return (ProfWin*)pluginwin;
-    }
-
-    return NULL;
-}
-
-ProfWin*
-wins_get_next(void)
-{
-    // get and sort win nums
-    GList *keys = g_hash_table_get_keys(windows);
-    keys = g_list_sort(keys, cmp_win_num);
-    GList *curr = keys;
-
-    // find our place in the list
-    while (curr) {
-        if (current == GPOINTER_TO_INT(curr->data)) {
-            break;
-        }
-        curr = g_list_next(curr);
-    }
-
-    // if there is a next window return it
-    curr = g_list_next(curr);
-    if (curr) {
-        int next = GPOINTER_TO_INT(curr->data);
-        g_list_free(keys);
-        return wins_get_by_num(next);
-    // otherwise return the first window (console)
-    } else {
-        g_list_free(keys);
-        return wins_get_console();
-    }
-}
-
-ProfWin*
-wins_get_previous(void)
-{
-    // get and sort win nums
-    GList *keys = g_hash_table_get_keys(windows);
-    keys = g_list_sort(keys, cmp_win_num);
-    GList *curr = keys;
-
-    // find our place in the list
-    while (curr) {
-        if (current == GPOINTER_TO_INT(curr->data)) {
-            break;
-        }
-        curr = g_list_next(curr);
-    }
-
-    // if there is a previous window return it
-    curr = g_list_previous(curr);
-    if (curr) {
-        int previous = GPOINTER_TO_INT(curr->data);
-        g_list_free(keys);
-        return wins_get_by_num(previous);
-    // otherwise return the last window
-    } else {
-        int new_num = GPOINTER_TO_INT(g_list_last(keys)->data);
-        g_list_free(keys);
-        return wins_get_by_num(new_num);
-    }
-}
-
-int
-wins_get_num(ProfWin *window)
-{
-    GList *keys = g_hash_table_get_keys(windows);
-    GList *curr = keys;
-
-    while (curr) {
-        gconstpointer num_p = curr->data;
-        ProfWin *curr_win = g_hash_table_lookup(windows, num_p);
-        if (curr_win == window) {
-            g_list_free(keys);
-            return GPOINTER_TO_INT(num_p);
-        }
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(keys);
-    return -1;
-}
-
-int
-wins_get_current_num(void)
-{
-    return current;
-}
-
-void
-wins_close_current(void)
-{
-    wins_close_by_num(current);
-}
-
-void
-wins_close_by_num(int i)
-{
-    // console cannot be closed
-    if (i != 1) {
-
-        // go to console if closing current window
-        if (i == current) {
-            current = 1;
-            ProfWin *window = wins_get_current();
-            win_update_virtual(window);
-        }
-
-        ProfWin *window = wins_get_by_num(i);
-        if (window) {
-            // cancel upload proccesses of this window
-            GSList *upload_process = upload_processes;
-            while (upload_process) {
-                HTTPUpload *upload = upload_process->data;
-                if (upload->window == window) {
-                    upload->cancel = 1;
-                    break;
-                }
-                upload_process = g_slist_next(upload_process);
-            }
-
-            switch (window->type) {
-            case WIN_CHAT:
-            {
-                ProfChatWin *chatwin = (ProfChatWin*)window;
-                autocomplete_remove(wins_ac, chatwin->barejid);
-                autocomplete_remove(wins_close_ac, chatwin->barejid);
-
-                jabber_conn_status_t conn_status = connection_get_status();
-                if (conn_status == JABBER_CONNECTED) {
-                    PContact contact = roster_get_contact(chatwin->barejid);
-                    if (contact) {
-                        const char* nick = p_contact_name(contact);
-                        if (nick) {
-                            autocomplete_remove(wins_ac, nick);
-                            autocomplete_remove(wins_close_ac, nick);
-                        }
-                    }
-                }
-
-                break;
-            }
-            case WIN_MUC:
-            {
-                ProfMucWin *mucwin = (ProfMucWin*)window;
-                autocomplete_remove(wins_ac, mucwin->roomjid);
-                autocomplete_remove(wins_close_ac, mucwin->roomjid);
-                break;
-            }
-            case WIN_PRIVATE:
-            {
-                ProfPrivateWin *privwin = (ProfPrivateWin*)window;
-                autocomplete_remove(wins_ac, privwin->fulljid);
-                autocomplete_remove(wins_close_ac, privwin->fulljid);
-                break;
-            }
-            case WIN_XML:
-            {
-                autocomplete_remove(wins_ac, "xmlconsole");
-                autocomplete_remove(wins_close_ac, "xmlconsole");
-                break;
-            }
-            case WIN_PLUGIN:
-            {
-                ProfPluginWin *pluginwin = (ProfPluginWin*)window;
-                plugins_close_win(pluginwin->plugin_name, pluginwin->tag);
-                autocomplete_remove(wins_ac, pluginwin->tag);
-                autocomplete_remove(wins_close_ac, pluginwin->tag);
-                break;
-            }
-            case WIN_MUC_CONFIG:
-            default:
-                break;
-            }
-        }
-
-        g_hash_table_remove(windows, GINT_TO_POINTER(i));
-        status_bar_inactive(i);
-    }
-}
-
-gboolean
-wins_is_current(ProfWin *window)
-{
-    ProfWin *current_window = wins_get_current();
-
-    if (current_window == window) {
-        return TRUE;
-    } else {
-        return FALSE;
-    }
-}
-
-ProfWin*
-wins_new_xmlconsole(void)
-{
-    GList *keys = g_hash_table_get_keys(windows);
-    int result = get_next_available_win_num(keys);
-    g_list_free(keys);
-    ProfWin *newwin = win_create_xmlconsole();
-    g_hash_table_insert(windows, GINT_TO_POINTER(result), newwin);
-    autocomplete_add(wins_ac, "xmlconsole");
-    autocomplete_add(wins_close_ac, "xmlconsole");
-    return newwin;
-}
-
-ProfWin*
-wins_new_chat(const char *const barejid)
-{
-    GList *keys = g_hash_table_get_keys(windows);
-    int result = get_next_available_win_num(keys);
-    g_list_free(keys);
-    ProfWin *newwin = win_create_chat(barejid);
-    g_hash_table_insert(windows, GINT_TO_POINTER(result), newwin);
-
-    autocomplete_add(wins_ac, barejid);
-    autocomplete_add(wins_close_ac, barejid);
-    PContact contact = roster_get_contact(barejid);
-    if (contact) {
-        const char* nick = p_contact_name(contact);
-        if (nick) {
-            autocomplete_add(wins_ac, nick);
-            autocomplete_add(wins_close_ac, nick);
-        }
-    }
-
-    return newwin;
-}
-
-ProfWin*
-wins_new_muc(const char *const roomjid)
-{
-    GList *keys = g_hash_table_get_keys(windows);
-    int result = get_next_available_win_num(keys);
-    g_list_free(keys);
-    ProfWin *newwin = win_create_muc(roomjid);
-    g_hash_table_insert(windows, GINT_TO_POINTER(result), newwin);
-    autocomplete_add(wins_ac, roomjid);
-    autocomplete_add(wins_close_ac, roomjid);
-    return newwin;
-}
-
-ProfWin*
-wins_new_muc_config(const char *const roomjid, DataForm *form)
-{
-    GList *keys = g_hash_table_get_keys(windows);
-    int result = get_next_available_win_num(keys);
-    g_list_free(keys);
-    ProfWin *newwin = win_create_muc_config(roomjid, form);
-    g_hash_table_insert(windows, GINT_TO_POINTER(result), newwin);
-    return newwin;
-}
-
-ProfWin*
-wins_new_private(const char *const fulljid)
-{
-    GList *keys = g_hash_table_get_keys(windows);
-    int result = get_next_available_win_num(keys);
-    g_list_free(keys);
-    ProfWin *newwin = win_create_private(fulljid);
-    g_hash_table_insert(windows, GINT_TO_POINTER(result), newwin);
-    autocomplete_add(wins_ac, fulljid);
-    autocomplete_add(wins_close_ac, fulljid);
-    return newwin;
-}
-
-ProfWin *
-wins_new_plugin(const char *const plugin_name, const char * const tag)
-{
-    GList *keys = g_hash_table_get_keys(windows);
-    int result = get_next_available_win_num(keys);
-    g_list_free(keys);
-    ProfWin *newwin = win_create_plugin(plugin_name, tag);
-    g_hash_table_insert(windows, GINT_TO_POINTER(result), newwin);
-    autocomplete_add(wins_ac, tag);
-    autocomplete_add(wins_close_ac, tag);
-    return newwin;
-}
-
-gboolean
-wins_do_notify_remind(void)
-{
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (win_notify_remind(window)) {
-            g_list_free(values);
-            return TRUE;
-        }
-        curr = g_list_next(curr);
-    }
-    g_list_free(values);
-    return FALSE;
-}
-
-int
-wins_get_total_unread(void)
-{
-    int result = 0;
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        result += win_unread(window);
-        curr = g_list_next(curr);
-    }
-    g_list_free(values);
-    return result;
-}
-
-void
-wins_resize_all(void)
-{
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-    while (curr) {
-        ProfWin *window = curr->data;
-        win_resize(window);
-        curr = g_list_next(curr);
-    }
-    g_list_free(values);
-
-    ProfWin *current_win = wins_get_current();
-    win_update_virtual(current_win);
-}
-
-void
-wins_hide_subwin(ProfWin *window)
-{
-    win_hide_subwin(window);
-
-    ProfWin *current_win = wins_get_current();
-    win_refresh_without_subwin(current_win);
-}
-
-void
-wins_show_subwin(ProfWin *window)
-{
-    win_show_subwin(window);
-
-    ProfWin *current_win = wins_get_current();
-    win_refresh_with_subwin(current_win);
-}
-
-ProfXMLWin*
-wins_get_xmlconsole(void)
-{
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type == WIN_XML) {
-            ProfXMLWin *xmlwin = (ProfXMLWin*)window;
-            assert(xmlwin->memcheck == PROFXMLWIN_MEMCHECK);
-            g_list_free(values);
-            return xmlwin;
-        }
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(values);
-    return NULL;
-}
-
-GSList*
-wins_get_chat_recipients(void)
-{
-    GSList *result = NULL;
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type == WIN_CHAT) {
-            ProfChatWin *chatwin = (ProfChatWin*)window;
-            result = g_slist_append(result, chatwin->barejid);
-        }
-        curr = g_list_next(curr);
-    }
-    g_list_free(values);
-    return result;
-}
-
-GSList*
-wins_get_prune_wins(void)
-{
-    GSList *result = NULL;
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (win_unread(window) == 0 &&
-                window->type != WIN_MUC &&
-                window->type != WIN_MUC_CONFIG &&
-                window->type != WIN_XML &&
-                window->type != WIN_CONSOLE) {
-            result = g_slist_append(result, window);
-        }
-        curr = g_list_next(curr);
-    }
-    g_list_free(values);
-    return result;
-}
-
-void
-wins_lost_connection(void)
-{
-    GList *values = g_hash_table_get_values(windows);
-    GList *curr = values;
-
-    while (curr) {
-        ProfWin *window = curr->data;
-        if (window->type != WIN_CONSOLE) {
-            win_print(window, '-', 0, NULL, 0, THEME_ERROR, "", "Lost connection.");
-
-            // if current win, set current_win_dirty
-            if (wins_is_current(window)) {
-                win_update_virtual(window);
-            }
-        }
-        curr = g_list_next(curr);
-    }
-    g_list_free(values);
-}
-
-gboolean
-wins_swap(int source_win, int target_win)
-{
-    ProfWin *source = g_hash_table_lookup(windows, GINT_TO_POINTER(source_win));
-    ProfWin *console = wins_get_console();
-
-    if (source) {
-        ProfWin *target = g_hash_table_lookup(windows, GINT_TO_POINTER(target_win));
-
-        // target window empty
-        if (!target) {
-            g_hash_table_steal(windows, GINT_TO_POINTER(source_win));
-            g_hash_table_insert(windows, GINT_TO_POINTER(target_win), source);
-            status_bar_inactive(source_win);
-            if (win_unread(source) > 0) {
-                status_bar_new(target_win);
-            } else {
-                status_bar_active(target_win);
-            }
-            if (wins_get_current_num() == source_win) {
-                wins_set_current_by_num(target_win);
-                ui_focus_win(console);
-            }
-            return TRUE;
-
-        // target window occupied
-        } else {
-            g_hash_table_steal(windows, GINT_TO_POINTER(source_win));
-            g_hash_table_steal(windows, GINT_TO_POINTER(target_win));
-            g_hash_table_insert(windows, GINT_TO_POINTER(source_win), target);
-            g_hash_table_insert(windows, GINT_TO_POINTER(target_win), source);
-            if (win_unread(source) > 0) {
-                status_bar_new(target_win);
-            } else {
-                status_bar_active(target_win);
-            }
-            if (win_unread(target) > 0) {
-                status_bar_new(source_win);
-            } else {
-                status_bar_active(source_win);
-            }
-            if ((wins_get_current_num() == source_win) || (wins_get_current_num() == target_win)) {
-                ui_focus_win(console);
-            }
-            return TRUE;
-        }
-    } else {
-        return FALSE;
-    }
-}
-
-gboolean
-wins_tidy(void)
-{
-    gboolean tidy_required = FALSE;
-    // check for gaps
-    GList *keys = g_hash_table_get_keys(windows);
-    keys = g_list_sort(keys, cmp_win_num);
-
-    // get last used
-    GList *last = g_list_last(keys);
-    int last_num = GPOINTER_TO_INT(last->data);
-
-    // find first free num TODO - Will sort again
-    int next_available = get_next_available_win_num(keys);
-
-    // found gap (next available before last window)
-    if (cmp_win_num(GINT_TO_POINTER(next_available), GINT_TO_POINTER(last_num)) < 0) {
-        tidy_required = TRUE;
-    }
-
-    if (tidy_required) {
-        status_bar_set_all_inactive();
-        GHashTable *new_windows = g_hash_table_new_full(g_direct_hash,
-            g_direct_equal, NULL, (GDestroyNotify)win_free);
-
-        int num = 1;
-        GList *curr = keys;
-        while (curr) {
-            ProfWin *window = g_hash_table_lookup(windows, curr->data);
-            if (num == 10) {
-                g_hash_table_insert(new_windows, GINT_TO_POINTER(0), window);
-                if (win_unread(window) > 0) {
-                    status_bar_new(0);
-                } else {
-                    status_bar_active(0);
-                }
-            } else {
-                g_hash_table_insert(new_windows, GINT_TO_POINTER(num), window);
-                if (win_unread(window) > 0) {
-                    status_bar_new(num);
-                } else {
-                    status_bar_active(num);
-                }
-            }
-            num++;
-            curr = g_list_next(curr);
-        }
-
-        windows = new_windows;
-        current = 1;
-        ProfWin *console = wins_get_console();
-        ui_focus_win(console);
-        g_list_free(keys);
-        return TRUE;
-    } else {
-        g_list_free(keys);
-        return FALSE;
-    }
-}
-
-GSList*
-wins_create_summary(gboolean unread)
-{
-    if (unread && wins_get_total_unread() == 0) {
-        return NULL;
-    }
-
-    GSList *result = NULL;
-
-    GList *keys = g_hash_table_get_keys(windows);
-    keys = g_list_sort(keys, cmp_win_num);
-    GList *curr = keys;
-
-    while (curr) {
-        ProfWin *window = g_hash_table_lookup(windows, curr->data);
-        if (!unread || (unread && win_unread(window) > 0)) {
-            GString *line = g_string_new("");
-
-            int ui_index = GPOINTER_TO_INT(curr->data);
-            char *winstring = win_get_string(window);
-            if (!winstring) {
-                g_string_free(line, TRUE);
-                continue;
-            }
-
-            g_string_append_printf(line, "%d: %s", ui_index, winstring);
-            free(winstring);
-
-            result = g_slist_append(result, strdup(line->str));
-            g_string_free(line, TRUE);
-        }
-
-        curr = g_list_next(curr);
-    }
-
-    g_list_free(keys);
-
-    return result;
-}
-
-char*
-win_autocomplete(const char *const search_str)
-{
-    return autocomplete_complete(wins_ac, search_str, TRUE);
-}
-
-char*
-win_close_autocomplete(const char *const search_str)
-{
-    return autocomplete_complete(wins_close_ac, search_str, TRUE);
-}
-
-void
-win_reset_search_attempts(void)
-{
-    autocomplete_reset(wins_ac);
-}
-
-void
-win_close_reset_search_attempts(void)
-{
-    autocomplete_reset(wins_close_ac);
-}
-
-void
-wins_destroy(void)
-{
-    g_hash_table_destroy(windows);
-    autocomplete_free(wins_ac);
-    autocomplete_free(wins_close_ac);
-}