summaryrefslogtreecommitdiff
path: root/src/fe-common
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>2000-09-02 18:53:58 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>2000-09-02 18:53:58 +0000
commit755a8d40eb5f9e0a12b98e4f84332891a3d63b1a (patch)
treeb96a317a11affdb428a121176836cf48e707c286 /src/fe-common
parent28a7908e7372fe0e81dd439b6559bc2abe3ea6e8 (diff)
downloadirssi-755a8d40eb5f9e0a12b98e4f84332891a3d63b1a.zip
Updates.
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@641 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/fe-common')
-rw-r--r--src/fe-common/core/Makefile.am3
-rw-r--r--src/fe-common/core/fe-channels.c (renamed from src/fe-common/irc/fe-channels.c)54
-rw-r--r--src/fe-common/core/fe-common-core.c8
-rw-r--r--src/fe-common/core/fe-queries.c (renamed from src/fe-common/irc/fe-queries.c)88
-rw-r--r--src/fe-common/core/fe-queries.h12
-rw-r--r--src/fe-common/core/module-formats.c22
-rw-r--r--src/fe-common/core/module-formats.h32
-rw-r--r--src/fe-common/core/window-save.c68
-rw-r--r--src/fe-common/irc/Makefile.am4
-rw-r--r--src/fe-common/irc/fe-common-irc.c13
-rw-r--r--src/fe-common/irc/fe-events.c4
-rw-r--r--src/fe-common/irc/fe-irc-channels.c44
-rw-r--r--src/fe-common/irc/fe-irc-commands.c5
-rw-r--r--src/fe-common/irc/fe-queries.h7
-rw-r--r--src/fe-common/irc/irc-completion.c3
-rw-r--r--src/fe-common/irc/module-formats.c14
-rw-r--r--src/fe-common/irc/module-formats.h14
17 files changed, 238 insertions, 157 deletions
diff --git a/src/fe-common/core/Makefile.am b/src/fe-common/core/Makefile.am
index 90e64d55..d739cdfe 100644
--- a/src/fe-common/core/Makefile.am
+++ b/src/fe-common/core/Makefile.am
@@ -10,10 +10,12 @@ libfe_common_core_a_SOURCES = \
autorun.c \
command-history.c \
completion.c \
+ fe-channels.c \
fe-common-core.c \
fe-core-commands.c \
fe-log.c \
fe-modules.c \
+ fe-queries.c \
fe-server.c \
fe-settings.c \
hilight-text.c \
@@ -32,6 +34,7 @@ noinst_HEADERS = \
command-history.h \
completion.h \
fe-common-core.h \
+ fe-queries.h \
hilight-text.h \
keyboard.h \
module-formats.h \
diff --git a/src/fe-common/irc/fe-channels.c b/src/fe-common/core/fe-channels.c
index 94f56cae..19ad6c84 100644
--- a/src/fe-common/irc/fe-channels.c
+++ b/src/fe-common/core/fe-channels.c
@@ -27,8 +27,6 @@
#include "misc.h"
#include "settings.h"
-#include "irc.h"
-#include "irc-channels.h"
#include "channels-setup.h"
#include "nicklist.h"
@@ -70,22 +68,20 @@ static void signal_channel_destroyed(CHANNEL_REC *channel)
static void signal_window_item_removed(WINDOW_REC *window, WI_ITEM_REC *item)
{
- IRC_CHANNEL_REC *channel;
+ CHANNEL_REC *channel;
g_return_if_fail(window != NULL);
- channel = IRC_CHANNEL(item);
- if (channel != NULL) channel_destroy(CHANNEL(channel));
+ channel = CHANNEL(item);
+ if (channel != NULL) channel_destroy(channel);
}
-static void sig_disconnected(IRC_SERVER_REC *server)
+static void sig_disconnected(SERVER_REC *server)
{
WINDOW_REC *window;
GSList *tmp;
- g_return_if_fail(server != NULL);
- if (!IS_IRC_SERVER(server))
- return;
+ g_return_if_fail(IS_SERVER(server));
for (tmp = server->channels; tmp != NULL; tmp = tmp->next) {
CHANNEL_REC *channel = tmp->data;
@@ -101,7 +97,7 @@ static void signal_window_item_changed(WINDOW_REC *window, WI_ITEM_REC *item)
g_return_if_fail(window != NULL);
if (item == NULL) return;
- if (g_slist_length(window->items) > 1 && IS_IRC_CHANNEL(item)) {
+ if (g_slist_length(window->items) > 1 && IS_CHANNEL(item)) {
printformat(item->server, item->name, MSGLEVEL_CLIENTNOTICE,
IRCTXT_TALKING_IN, item->name);
signal_stop();
@@ -146,7 +142,7 @@ static void cmd_wjoin_post(const char *data)
static void cmd_channel_list_joined(void)
{
- IRC_CHANNEL_REC *channel;
+ CHANNEL_REC *channel;
GString *nicks;
GSList *nicklist, *tmp, *ntmp;
@@ -156,7 +152,7 @@ static void cmd_channel_list_joined(void)
}
/* print active channel */
- channel = IRC_CHANNEL(active_win->active);
+ channel = CHANNEL(active_win->active);
if (channel != NULL)
printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, IRCTXT_CURRENT_CHANNEL, channel->name);
@@ -165,7 +161,7 @@ static void cmd_channel_list_joined(void)
for (tmp = channels; tmp != NULL; tmp = tmp->next) {
channel = tmp->data;
- nicklist = nicklist_getnicks(CHANNEL(channel));
+ nicklist = nicklist_getnicks(channel);
nicks = g_string_new(NULL);
for (ntmp = nicklist; ntmp != NULL; ntmp = ntmp->next) {
NICK_REC *rec = ntmp->data;
@@ -210,39 +206,37 @@ static void cmd_channel_list(void)
printformat(NULL, NULL, MSGLEVEL_CLIENTCRAP, IRCTXT_CHANSETUP_FOOTER);
}
-static void cmd_channel(const char *data, IRC_SERVER_REC *server, WI_ITEM_REC *item)
+static void cmd_channel(const char *data, SERVER_REC *server, WI_ITEM_REC *item)
{
if (*data == '\0')
cmd_channel_list_joined();
- else if (ischannel(*data))
- signal_emit("command join", 2, data, server);
else
command_runsub("channel", data, server, item);
}
/* SYNTAX: CHANNEL ADD [-auto | -noauto] [-bots <masks>] [-botcmd <command>]
- <channel> <ircnet> [<password>] */
+ <channel> <chatnet> [<password>] */
static void cmd_channel_add(const char *data)
{
GHashTable *optlist;
CHANNEL_SETUP_REC *rec;
- char *botarg, *botcmdarg, *ircnet, *channel, *password;
+ char *botarg, *botcmdarg, *chatnet, *channel, *password;
void *free_arg;
if (!cmd_get_params(data, &free_arg, 3 | PARAM_FLAG_OPTIONS,
- "channel add", &optlist, &channel, &ircnet, &password))
+ "channel add", &optlist, &channel, &chatnet, &password))
return;
botarg = g_hash_table_lookup(optlist, "bots");
botcmdarg = g_hash_table_lookup(optlist, "botcmd");
- if (*ircnet == '\0' || *channel == '\0')
+ if (*chatnet == '\0' || *channel == '\0')
cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
- rec = channels_setup_find(channel, ircnet);
+ rec = channels_setup_find(channel, chatnet);
if (rec == NULL) {
rec = g_new0(CHANNEL_SETUP_REC, 1);
rec->name = g_strdup(channel);
- rec->chatnet = g_strdup(ircnet);
+ rec->chatnet = g_strdup(chatnet);
} else {
if (g_hash_table_lookup(optlist, "bots")) g_free_and_null(rec->botmasks);
if (g_hash_table_lookup(optlist, "botcmd")) g_free_and_null(rec->autosendcmd);
@@ -254,28 +248,28 @@ static void cmd_channel_add(const char *data)
if (botcmdarg != NULL && *botcmdarg != '\0') rec->autosendcmd = g_strdup(botcmdarg);
if (*password != '\0' && strcmp(password, "-") != 0) rec->password = g_strdup(password);
channels_setup_create(rec);
- printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, IRCTXT_CHANSETUP_ADDED, channel, ircnet);
+ printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, IRCTXT_CHANSETUP_ADDED, channel, chatnet);
cmd_params_free(free_arg);
}
-/* SYNTAX: CHANNEL REMOVE <channel> <ircnet> */
+/* SYNTAX: CHANNEL REMOVE <channel> <chatnet> */
static void cmd_channel_remove(const char *data)
{
CHANNEL_SETUP_REC *rec;
- char *ircnet, *channel;
+ char *chatnet, *channel;
void *free_arg;
- if (!cmd_get_params(data, &free_arg, 2, &channel, &ircnet))
+ if (!cmd_get_params(data, &free_arg, 2, &channel, &chatnet))
return;
- if (*ircnet == '\0' || *channel == '\0')
+ if (*chatnet == '\0' || *channel == '\0')
cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
- rec = channels_setup_find(channel, ircnet);
+ rec = channels_setup_find(channel, chatnet);
if (rec == NULL)
- printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, IRCTXT_CHANSETUP_NOT_FOUND, channel, ircnet);
+ printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, IRCTXT_CHANSETUP_NOT_FOUND, channel, chatnet);
else {
- printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, IRCTXT_CHANSETUP_REMOVED, channel, ircnet);
+ printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, IRCTXT_CHANSETUP_REMOVED, channel, chatnet);
channels_setup_destroy(rec);
}
cmd_params_free(free_arg);
diff --git a/src/fe-common/core/fe-common-core.c b/src/fe-common/core/fe-common-core.c
index 1a802ace..6d665c68 100644
--- a/src/fe-common/core/fe-common-core.c
+++ b/src/fe-common/core/fe-common-core.c
@@ -23,6 +23,7 @@
#include "levels.h"
#include "settings.h"
+#include "fe-queries.h"
#include "hilight-text.h"
#include "command-history.h"
#include "completion.h"
@@ -39,6 +40,9 @@
void autorun_init(void);
void autorun_deinit(void);
+void fe_channels_init(void);
+void fe_channels_deinit(void);
+
void fe_core_log_init(void);
void fe_core_log_deinit(void);
@@ -92,6 +96,8 @@ void fe_common_core_init(void)
completion_init();
keyboard_init();
printtext_init();
+ fe_channels_init();
+ fe_queries_init();
fe_log_init();
fe_modules_init();
fe_server_init();
@@ -113,6 +119,8 @@ void fe_common_core_deinit(void)
completion_deinit();
keyboard_deinit();
printtext_deinit();
+ fe_channels_deinit();
+ fe_queries_deinit();
fe_log_deinit();
fe_modules_deinit();
fe_server_deinit();
diff --git a/src/fe-common/irc/fe-queries.c b/src/fe-common/core/fe-queries.c
index 20bea852..ffb83eb8 100644
--- a/src/fe-common/irc/fe-queries.c
+++ b/src/fe-common/core/fe-queries.c
@@ -25,10 +25,8 @@
#include "commands.h"
#include "settings.h"
-#include "irc.h"
-#include "irc-commands.h"
#include "levels.h"
-#include "irc-queries.h"
+#include "queries.h"
#include "windows.h"
#include "window-items.h"
@@ -36,14 +34,17 @@
static int queryclose_tag, query_auto_close;
/* Return query where to put the private message. */
-QUERY_REC *privmsg_get_query(IRC_SERVER_REC *server, const char *nick, int own)
+QUERY_REC *privmsg_get_query(SERVER_REC *server, const char *nick, int own)
{
QUERY_REC *query;
- query = irc_query_find(server, nick);
+ g_return_val_if_fail(IS_SERVER(server), NULL);
+ g_return_val_if_fail(nick != NULL, NULL);
+
+ query = query_find(server, nick);
if (query == NULL && settings_get_bool("autocreate_query") &&
(!own || settings_get_bool("autocreate_own_query")))
- query = irc_query_create(server, nick, TRUE);
+ query = query_create(server->chat_type, server, nick, TRUE);
return query;
}
@@ -87,15 +88,15 @@ static void signal_window_item_removed(WINDOW_REC *window, WI_ITEM_REC *item)
g_return_if_fail(window != NULL);
- query = IRC_QUERY(item);
+ query = QUERY(item);
if (query != NULL) query_destroy(query);
}
-static void sig_server_connected(IRC_SERVER_REC *server)
+static void sig_server_connected(SERVER_REC *server)
{
GSList *tmp;
- if (!IS_IRC_SERVER(server))
+ if (!IS_SERVER(server))
return;
/* check if there's any queries without server */
@@ -117,20 +118,24 @@ static void cmd_window_server(const char *data)
g_return_if_fail(data != NULL);
server = server_find_tag(data);
- if (IS_IRC_SERVER(server) && IS_IRC_QUERY(active_win->active)) {
- /* /WINDOW SERVER used in a query window */
- query_change_server((QUERY_REC *) active_win->active, server);
- window_change_server(active_win, server);
+ if (!IS_SERVER(server) || !IS_QUERY(active_win->active))
+ return;
- printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, IRCTXT_QUERY_SERVER_CHANGED, server->tag, server->connrec->address,
- server->connrec->chatnet == NULL ? "" : server->connrec->chatnet);
+ /* /WINDOW SERVER used in a query window */
+ query_change_server(QUERY(active_win->active), server);
+ window_change_server(active_win, server);
- signal_stop();
- }
+ printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE,
+ IRCTXT_QUERY_SERVER_CHANGED,
+ server->tag, server->connrec->address,
+ server->connrec->chatnet == NULL ? "" :
+ server->connrec->chatnet);
+
+ signal_stop();
}
/* SYNTAX: UNQUERY [<nick>] */
-static void cmd_unquery(const char *data, IRC_SERVER_REC *server, WI_ITEM_REC *item)
+static void cmd_unquery(const char *data, SERVER_REC *server, WI_ITEM_REC *item)
{
QUERY_REC *query;
@@ -138,12 +143,13 @@ static void cmd_unquery(const char *data, IRC_SERVER_REC *server, WI_ITEM_REC *i
if (*data == '\0') {
/* remove current query */
- query = IRC_QUERY(item);
+ query = QUERY(item);
if (query == NULL) return;
} else {
- query = irc_query_find(server, data);
+ query = query_find(server, data);
if (query == NULL) {
- printformat(server, NULL, MSGLEVEL_CLIENTERROR, IRCTXT_NO_QUERY, data);
+ printformat(server, NULL, MSGLEVEL_CLIENTERROR,
+ IRCTXT_NO_QUERY, data);
return;
}
}
@@ -152,7 +158,7 @@ static void cmd_unquery(const char *data, IRC_SERVER_REC *server, WI_ITEM_REC *i
}
/* SYNTAX: QUERY [-window] <nick> */
-static void cmd_query(const char *data, IRC_SERVER_REC *server, WI_ITEM_REC *item)
+static void cmd_query(const char *data, SERVER_REC *server, WI_ITEM_REC *item)
{
GHashTable *optlist;
WINDOW_REC *window;
@@ -173,7 +179,8 @@ static void cmd_query(const char *data, IRC_SERVER_REC *server, WI_ITEM_REC *ite
"query", &optlist, &nick))
return;
if (*nick == '\0') cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
- server = irccmd_options_get_server("query", optlist, server);
+
+ server = cmd_options_get_server("query", optlist, server);
if (server == NULL) {
cmd_params_free(free_arg);
return;
@@ -187,9 +194,9 @@ static void cmd_query(const char *data, IRC_SERVER_REC *server, WI_ITEM_REC *ite
(SIGNAL_FUNC) signal_query_created_curwin);
}
- query = irc_query_find(server, nick);
+ query = query_find(server, nick);
if (query == NULL)
- irc_query_create(server, nick, FALSE);
+ query_create(server->chat_type, server, nick, FALSE);
else {
/* query already existed - change to query window */
window = window_item_window((WI_ITEM_REC *) query);
@@ -214,7 +221,7 @@ static int window_has_query(WINDOW_REC *window)
g_return_val_if_fail(window != NULL, FALSE);
for (tmp = window->items; tmp != NULL; tmp = tmp->next) {
- if (IS_IRC_QUERY(tmp->data))
+ if (IS_QUERY(tmp->data))
return TRUE;
}
@@ -235,29 +242,6 @@ static void sig_window_changed(WINDOW_REC *window, WINDOW_REC *old_window)
old_window->last_line = time(NULL);
}
-static void sig_window_restore_item(WINDOW_REC *window, const char *item)
-{
- IRC_SERVER_REC *server;
- QUERY_REC *rec;
- char *tag, *nick;
-
- tag = g_strdup(item);
- nick = strchr(tag, ' ');
- if (nick == NULL || ischannel(*(nick+1))) {
- g_free(tag);
- return;
- }
-
- server = (IRC_SERVER_REC *) server_find_tag(tag);
-
- rec = irc_query_create(server, nick+1, TRUE);
- if (server == NULL)
- rec->server_tag = g_strdup(tag);
-
- g_free(tag);
- signal_stop();
-}
-
static int sig_query_autoclose(void)
{
WINDOW_REC *window;
@@ -288,7 +272,7 @@ static void read_settings(void)
}
}
-void fe_query_init(void)
+void fe_queries_init(void)
{
settings_add_bool("lookandfeel", "autocreate_query", TRUE);
settings_add_bool("lookandfeel", "autocreate_own_query", TRUE);
@@ -302,7 +286,6 @@ void fe_query_init(void)
signal_add("window item remove", (SIGNAL_FUNC) signal_window_item_removed);
signal_add("server connected", (SIGNAL_FUNC) sig_server_connected);
signal_add("window changed", (SIGNAL_FUNC) sig_window_changed);
- signal_add("window restore item", (SIGNAL_FUNC) sig_window_restore_item);
signal_add("setup changed", (SIGNAL_FUNC) read_settings);
command_bind("query", NULL, (SIGNAL_FUNC) cmd_query);
@@ -312,7 +295,7 @@ void fe_query_init(void)
command_set_options("query", "window");
}
-void fe_query_deinit(void)
+void fe_queries_deinit(void)
{
if (queryclose_tag != -1) g_source_remove(queryclose_tag);
@@ -321,7 +304,6 @@ void fe_query_deinit(void)
signal_remove("window item remove", (SIGNAL_FUNC) signal_window_item_removed);
signal_remove("server connected", (SIGNAL_FUNC) sig_server_connected);
signal_remove("window changed", (SIGNAL_FUNC) sig_window_changed);
- signal_remove("window restore item", (SIGNAL_FUNC) sig_window_restore_item);
signal_remove("setup changed", (SIGNAL_FUNC) read_settings);
command_unbind("query", (SIGNAL_FUNC) cmd_query);
diff --git a/src/fe-common/core/fe-queries.h b/src/fe-common/core/fe-queries.h
new file mode 100644
index 00000000..bc58b4e8
--- /dev/null
+++ b/src/fe-common/core/fe-queries.h
@@ -0,0 +1,12 @@
+#ifndef __FE_QUERIES_H
+#define __FE_QUERIES_H
+
+#include "queries.h"
+
+/* Return query where to put the private message. */
+QUERY_REC *privmsg_get_query(SERVER_REC *server, const char *nick, int own);
+
+void fe_queries_init(void);
+void fe_queries_deinit(void);
+
+#endif
diff --git a/src/fe-common/core/module-formats.c b/src/fe-common/core/module-formats.c
index 6d79e2fb..3937b583 100644
--- a/src/fe-common/core/module-formats.c
+++ b/src/fe-common/core/module-formats.c
@@ -51,6 +51,28 @@ FORMAT_REC fecommon_core_formats[] = {
{ "unknown_server_tag", "Unknown server tag %_$0%_", 1, { 0 } },
/* ---- */
+ { NULL, "Channels", 0 },
+
+ { "talking_in", "You are now talking in %_$0%_", 1, { 0 } },
+ { "not_in_channels", "You are not on any channels", 0 },
+ { "current_channel", "Current channel $0", 1, { 0 } },
+ { "chanlist_header", "You are on the following channels:", 0 },
+ { "chanlist_line", "$[-10]0 %|+$1 ($2): $3", 4, { 0, 0, 0, 0 } },
+ { "chansetup_not_found", "Channel $0 not found", 2, { 0, 0 } },
+ { "chansetup_added", "Channel $0 saved", 2, { 0, 0 } },
+ { "chansetup_removed", "Channel $0 removed", 2, { 0, 0 } },
+ { "chansetup_header", "Channel IRC net Password Settings", 0 },
+ { "chansetup_line", "$[15]0 %|$[10]1 $[10]2 $3", 4, { 0, 0, 0, 0 } },
+ { "chansetup_footer", "", 0 },
+
+ /* ---- */
+ { NULL, "Queries", 0 },
+
+ { "query_start", "Starting query with %_$0%_", 1, { 0 } },
+ { "no_query", "No query with %_$0%_", 1, { 0 } },
+ { "query_server_changed", "Query with %_$2%_ changed to server %_$1%_", 3, { 0, 0, 0 } },
+
+ /* ---- */
{ NULL, "Highlighting", 0 },
{ "hilight_header", "Highlights:", 0 },
diff --git a/src/fe-common/core/module-formats.h b/src/fe-common/core/module-formats.h
index 4097caef..86f27baf 100644
--- a/src/fe-common/core/module-formats.h
+++ b/src/fe-common/core/module-formats.h
@@ -29,13 +29,33 @@ enum {
IRCTXT_FILL_3,
+ IRCTXT_TALKING_IN,
+ IRCTXT_NOT_IN_CHANNELS,
+ IRCTXT_CURRENT_CHANNEL,
+ IRCTXT_CHANLIST_HEADER,
+ IRCTXT_CHANLIST_LINE,
+ IRCTXT_CHANSETUP_NOT_FOUND,
+ IRCTXT_CHANSETUP_ADDED,
+ IRCTXT_CHANSETUP_REMOVED,
+ IRCTXT_CHANSETUP_HEADER,
+ IRCTXT_CHANSETUP_LINE,
+ IRCTXT_CHANSETUP_FOOTER,
+
+ IRCTXT_FILL_4,
+
+ IRCTXT_QUERY_STARTED,
+ IRCTXT_NO_QUERY,
+ IRCTXT_QUERY_SERVER_CHANGED,
+
+ IRCTXT_FILL_5,
+
IRCTXT_HILIGHT_HEADER,
IRCTXT_HILIGHT_LINE,
IRCTXT_HILIGHT_FOOTER,
IRCTXT_HILIGHT_NOT_FOUND,
IRCTXT_HILIGHT_REMOVED,
- IRCTXT_FILL_4,
+ IRCTXT_FILL_6,
IRCTXT_ALIAS_ADDED,
IRCTXT_ALIAS_REMOVED,
@@ -44,7 +64,7 @@ enum {
IRCTXT_ALIASLIST_LINE,
IRCTXT_ALIASLIST_FOOTER,
- IRCTXT_FILL_5,
+ IRCTXT_FILL_7,
IRCTXT_LOG_OPENED,
IRCTXT_LOG_CLOSED,
@@ -61,7 +81,7 @@ enum {
IRCTXT_LOG_NO_AWAY_MSGS,
IRCTXT_LOG_AWAY_MSGS,
- IRCTXT_FILL_6,
+ IRCTXT_FILL_8,
IRCTXT_MODULE_ALREADY_LOADED,
IRCTXT_MODULE_LOAD_ERROR,
@@ -69,7 +89,7 @@ enum {
IRCTXT_MODULE_LOADED,
IRCTXT_MODULE_UNLOADED,
- IRCTXT_FILL_7,
+ IRCTXT_FILL_9,
IRCTXT_COMMAND_UNKNOWN,
IRCTXT_COMMAND_AMBIGUOUS,
@@ -83,7 +103,7 @@ enum {
IRCTXT_CHAN_NOT_SYNCED,
IRCTXT_NOT_GOOD_IDEA,
- IRCTXT_FILL_8,
+ IRCTXT_FILL_10,
IRCTXT_THEME_SAVED,
IRCTXT_THEME_SAVE_FAILED,
@@ -93,7 +113,7 @@ enum {
IRCTXT_FORMAT_SUBTITLE,
IRCTXT_FORMAT_ITEM,
- IRCTXT_FILL_9,
+ IRCTXT_FILL_11,
IRCTXT_NOT_TOGGLE,
IRCTXT_PERL_ERROR,
diff --git a/src/fe-common/core/window-save.c b/src/fe-common/core/window-save.c
index 14174168..ba204383 100644
--- a/src/fe-common/core/window-save.c
+++ b/src/fe-common/core/window-save.c
@@ -21,25 +21,55 @@
#include "module.h"
#include "signals.h"
#include "misc.h"
-#include "servers.h"
+#include "levels.h"
#include "lib-config/iconfig.h"
#include "settings.h"
-#include "levels.h"
+#include "chat-protocols.h"
+#include "servers.h"
+#include "queries.h"
#include "themes.h"
#include "windows.h"
#include "window-items.h"
-static void sig_window_restore_item(WINDOW_REC *window, const char *item)
+static void sig_window_restore_item(WINDOW_REC *window, const char *type,
+ CONFIG_NODE *node)
{
- window->waiting_channels =
- g_slist_append(window->waiting_channels, g_strdup(item));
+ char *name, *tag, *chat_type, *str;
+
+ chat_type = config_node_get_str(node, "chat_type", NULL);
+ name = config_node_get_str(node, "name", NULL);
+ tag = config_node_get_str(node, "tag", NULL);
+ if (name == NULL) return;
+
+ if (g_strcasecmp(type, "CHANNEL") == 0) {
+ /* add channel to "waiting channels" list */
+ str = tag == NULL ? g_strdup(name) :
+ g_strdup_printf("%s %s", tag, name);
+
+ window->waiting_channels =
+ g_slist_append(window->waiting_channels, str);
+ } else if (g_strcasecmp(type, "QUERY") == 0) {
+ /* create query immediately */
+ QUERY_REC *query;
+ SERVER_REC *server;
+
+ if (chat_type == NULL)
+ return;
+
+ server = tag == NULL ? NULL : server_find_tag(tag);
+ query = query_create(chat_protocol_lookup(chat_type),
+ server, name, TRUE);
+ if (server == NULL && tag != NULL)
+ query->server_tag = g_strdup(tag);
+ }
}
static void window_add_items(WINDOW_REC *window, CONFIG_NODE *node)
{
GSList *tmp;
+ char *type;
if (node == NULL)
return;
@@ -47,7 +77,11 @@ static void window_add_items(WINDOW_REC *window, CONFIG_NODE *node)
for (tmp = node->value; tmp != NULL; tmp = tmp->next) {
CONFIG_NODE *node = tmp->data;
- signal_emit("window restore item", 2, window, node->value);
+ type = config_node_get_str(node->value, "type", NULL);
+ if (type != NULL) {
+ signal_emit("window restore item", 3,
+ window, type, node->value);
+ }
}
}
@@ -81,21 +115,27 @@ void windows_restore(void)
static void window_save_items(WINDOW_REC *window, CONFIG_NODE *node)
{
+ CONFIG_NODE *subnode;
GSList *tmp;
- char *str;
+ const char *type;
node = config_node_section(node, "items", NODE_TYPE_LIST);
for (tmp = window->items; tmp != NULL; tmp = tmp->next) {
WI_ITEM_REC *rec = tmp->data;
SERVER_REC *server = rec->server;
- if (server == NULL)
- iconfig_node_set_str(node, NULL, rec->name);
- else {
- str = g_strdup_printf("%s %s", server->tag, rec->name);
- iconfig_node_set_str(node, NULL, str);
- g_free(str);
- }
+ type = module_find_id_str("WINDOW ITEM TYPE", rec->type);
+ if (type == NULL) continue;
+
+ subnode = config_node_section(node, NULL, NODE_TYPE_BLOCK);
+
+ iconfig_node_set_str(subnode, "type", type);
+ iconfig_node_set_str(subnode, "chat_type",
+ chat_protocol_get_name(rec->chat_type));
+ iconfig_node_set_str(subnode, "name", rec->name);
+
+ if (server != NULL)
+ iconfig_node_set_str(subnode, "tag", server->tag);
}
}
diff --git a/src/fe-common/irc/Makefile.am b/src/fe-common/irc/Makefile.am
index 1bc23a0d..28196e37 100644
--- a/src/fe-common/irc/Makefile.am
+++ b/src/fe-common/irc/Makefile.am
@@ -12,7 +12,7 @@ INCLUDES = \
-DSYSCONFDIR=\""$(sysconfdir)"\"
libfe_common_irc_a_SOURCES = \
- fe-channels.c \
+ fe-irc-channels.c \
fe-irc-commands.c \
fe-irc-server.c \
fe-ircnet.c \
@@ -22,7 +22,6 @@ libfe_common_irc_a_SOURCES = \
fe-ignore.c \
fe-netjoin.c \
fe-netsplit.c \
- fe-queries.c \
fe-common-irc.c \
irc-completion.c \
irc-window-activity.c \
@@ -32,7 +31,6 @@ libfe_common_irc_a_SOURCES = \
noinst_HEADERS = \
fe-common-irc.h \
- fe-queries.h \
irc-hilight-text.h \
module.h \
module-formats.h
diff --git a/src/fe-common/irc/fe-common-irc.c b/src/fe-common/irc/fe-common-irc.c
index 651266f5..a7dfd74e 100644
--- a/src/fe-common/irc/fe-common-irc.c
+++ b/src/fe-common/irc/fe-common-irc.c
@@ -34,8 +34,8 @@
void fe_irc_modules_init(void);
void fe_irc_modules_deinit(void);
-void fe_channels_init(void);
-void fe_channels_deinit(void);
+void fe_irc_channels_init(void);
+void fe_irc_channels_deinit(void);
void fe_irc_commands_init(void);
void fe_irc_commands_deinit(void);
@@ -58,9 +58,6 @@ void fe_events_numeric_deinit(void);
void fe_ignore_init(void);
void fe_ignore_deinit(void);
-void fe_query_init(void);
-void fe_query_deinit(void);
-
void irc_completion_init(void);
void irc_completion_deinit(void);
@@ -109,7 +106,7 @@ void fe_common_irc_init(void)
theme_register(fecommon_irc_formats);
- fe_channels_init();
+ fe_irc_channels_init();
fe_irc_commands_init();
fe_ircnet_init();
fe_irc_server_init();
@@ -119,7 +116,6 @@ void fe_common_irc_init(void)
fe_ignore_init();
fe_netsplit_init();
fe_netjoin_init();
- fe_query_init();
irc_completion_init();
irc_hilight_text_init();
irc_window_activity_init();
@@ -131,7 +127,7 @@ void fe_common_irc_deinit(void)
{
fe_irc_modules_deinit();
- fe_channels_deinit();
+ fe_irc_channels_deinit();
fe_irc_commands_deinit();
fe_ircnet_deinit();
fe_irc_server_deinit();
@@ -141,7 +137,6 @@ void fe_common_irc_deinit(void)
fe_ignore_deinit();
fe_netsplit_deinit();
fe_netjoin_deinit();
- fe_query_deinit();
irc_completion_deinit();
irc_hilight_text_deinit();
irc_window_activity_deinit();
diff --git a/src/fe-common/irc/fe-events.c b/src/fe-common/irc/fe-events.c
index 4e544ffa..47f9b29f 100644
--- a/src/fe-common/irc/fe-events.c
+++ b/src/fe-common/irc/fe-events.c
@@ -113,7 +113,7 @@ static void event_privmsg(const char *data, IRC_SERVER_REC *server, const char *
print_channel_msg(server, msg, nick, addr, target);
} else {
/* private message */
- item = (WI_ITEM_REC *) privmsg_get_query(server, nick, FALSE);
+ item = (WI_ITEM_REC *) privmsg_get_query(SERVER(server), nick, FALSE);
printformat(server, nick, MSGLEVEL_MSGS,
item == NULL ? IRCTXT_MSG_PRIVATE : IRCTXT_MSG_PRIVATE_QUERY, nick, addr, msg);
}
@@ -156,7 +156,7 @@ static void ctcp_msg_check_action(const char *data, IRC_SERVER_REC *server,
}
} else {
/* private action */
- item = (WI_ITEM_REC *) privmsg_get_query(server, nick, FALSE);
+ item = (WI_ITEM_REC *) privmsg_get_query(SERVER(server), nick, FALSE);
printformat(server, nick, level,
item == NULL ? IRCTXT_ACTION_PRIVATE : IRCTXT_ACTION_PRIVATE_QUERY,
nick, addr == NULL ? "" : addr, data);
diff --git a/src/fe-common/irc/fe-irc-channels.c b/src/fe-common/irc/fe-irc-channels.c
new file mode 100644
index 00000000..bb22e54d
--- /dev/null
+++ b/src/fe-common/irc/fe-irc-channels.c
@@ -0,0 +1,44 @@
+/*
+ fe-irc-channels.c : irssi
+
+ Copyright (C) 1999-2000 Timo Sirainen
+
+ This program 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 2 of the License, or
+ (at your option) any later version.
+
+ This program 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 this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+*/
+
+#include "module.h"
+#include "signals.h"
+#include "commands.h"
+#include "servers.h"
+
+#include "irc.h"
+
+static void cmd_channel(const char *data, SERVER_REC *server)
+{
+ if (ischannel(*data)) {
+ signal_emit("command join", 2, data, server);
+ signal_stop();
+ }
+}
+
+void fe_irc_channels_init(void)
+{
+ command_bind("channel", NULL, (SIGNAL_FUNC) cmd_channel);
+}
+
+void fe_irc_channels_deinit(void)
+{
+ command_unbind("channel", (SIGNAL_FUNC) cmd_channel);
+}
diff --git a/src/fe-common/irc/fe-irc-commands.c b/src/fe-common/irc/fe-irc-commands.c
index 2bd0c761..ce5fa2f6 100644
--- a/src/fe-common/irc/fe-irc-commands.c
+++ b/src/fe-common/irc/fe-irc-commands.c
@@ -27,7 +27,6 @@
#include "levels.h"
#include "irc.h"
-#include "irc-commands.h"
#include "servers.h"
#include "mode-lists.h"
#include "nicklist.h"
@@ -56,7 +55,7 @@ static void cmd_msg(gchar *data, IRC_SERVER_REC *server, WI_ITEM_REC *item)
"msg", &optlist, &target, &msg))
return;
if (*target == '\0' || *msg == '\0') cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
- server = irccmd_options_get_server("msg", optlist, server);
+ server = IRC_SERVER(cmd_options_get_server("msg", optlist, SERVER(server)));
if (*target == '=')
{
@@ -119,7 +118,7 @@ static void cmd_msg(gchar *data, IRC_SERVER_REC *server, WI_ITEM_REC *item)
else
{
/* private message */
- item = (WI_ITEM_REC *) privmsg_get_query(server, target, TRUE);
+ item = (WI_ITEM_REC *) privmsg_get_query(SERVER(server), target, TRUE);
printformat(server, target, MSGLEVEL_MSGS | MSGLEVEL_NOHILIGHT | MSGLEVEL_NO_ACT,
item == NULL ? IRCTXT_OWN_MSG_PRIVATE : IRCTXT_OWN_MSG_PRIVATE_QUERY, target, msg, server->nick);
}
diff --git a/src/fe-common/irc/fe-queries.h b/src/fe-common/irc/fe-queries.h
deleted file mode 100644
index 494e277a..00000000
--- a/src/fe-common/irc/fe-queries.h
+++ /dev/null
@@ -1,7 +0,0 @@
-#ifndef __FE_QUERIES_H
-#define __FE_QUERIES_H
-
-/* Return query where to put the private message. */
-QUERY_REC *privmsg_get_query(IRC_SERVER_REC *server, const char *nick, int own);
-
-#endif
diff --git a/src/fe-common/irc/irc-completion.c b/src/fe-common/irc/irc-completion.c
index 381a09b1..06ec7598 100644
--- a/src/fe-common/irc/irc-completion.c
+++ b/src/fe-common/irc/irc-completion.c
@@ -26,7 +26,6 @@
#include "settings.h"
#include "irc.h"
-#include "irc-commands.h"
#include "servers.h"
#include "irc-channels.h"
#include "irc-queries.h"
@@ -260,7 +259,7 @@ static void cmd_msg(const char *data, IRC_SERVER_REC *server)
PARAM_FLAG_UNKNOWN_OPTIONS | PARAM_FLAG_GETREST,
"msg", &optlist, &target, &msg))
return;
- server = irccmd_options_get_server("msg", optlist, server);
+ server = IRC_SERVER(cmd_options_get_server("msg", optlist, SERVER(server)));
if (*target != '\0' && *msg != '\0') {
if (!ischannel(*target) && *target != '=' && server != NULL)
diff --git a/src/fe-common/irc/module-formats.c b/src/fe-common/irc/module-formats.c
index 2b30bffe..913d3ae9 100644
--- a/src/fe-common/irc/module-formats.c
+++ b/src/fe-common/irc/module-formats.c
@@ -34,7 +34,6 @@ FORMAT_REC fecommon_irc_formats[] = {
{ "server_reconnect_list", "%_$0%_: $1:$2 ($3) ($5 left before reconnecting)", 6, { 0, 0, 1, 0, 0, 0 } },
{ "server_reconnect_removed", "Removed reconnection to server %_$0%_ port %_$1%_", 3, { 0, 1, 0 } },
{ "server_reconnect_not_found", "Reconnection tag %_$0%_ not found", 1, { 0 } },
- { "query_server_changed", "Query with %_$2%_ changed to server %_$1%_", 3, { 0, 0, 0 } },
{ "setupserver_added", "Server $0 saved", 2, { 0, 1 } },
{ "setupserver_removed", "Server $0 removed", 2, { 0, 1 } },
{ "setupserver_not_found", "Server $0 not found", 2, { 0, 1 } },
@@ -95,16 +94,6 @@ FORMAT_REC fecommon_irc_formats[] = {
{ "invitelist", "%_$0%_: invite %c$1", 2, { 0, 0 } },
{ "no_such_channel", "$0: No such channel", 1, { 0 } },
{ "channel_synced", "Join to %_$0%_ was synced in %_$1%_ secs", 2, { 0, 2 } },
- { "not_in_channels", "You are not on any channels", 0 },
- { "current_channel", "Current channel $0", 1, { 0 } },
- { "chanlist_header", "You are on the following channels:", 0 },
- { "chanlist_line", "$[-10]0 %|+$1 ($2): $3", 4, { 0, 0, 0, 0 } },
- { "chansetup_not_found", "Channel $0 not found", 2, { 0, 0 } },
- { "chansetup_added", "Channel $0 saved", 2, { 0, 0 } },
- { "chansetup_removed", "Channel $0 removed", 2, { 0, 0 } },
- { "chansetup_header", "Channel IRC net Password Settings", 0 },
- { "chansetup_line", "$[15]0 %|$[10]1 $[10]2 $3", 4, { 0, 0, 0, 0 } },
- { "chansetup_footer", "", 0 },
/* ---- */
{ NULL, "Nick", 0 },
@@ -201,9 +190,6 @@ FORMAT_REC fecommon_irc_formats[] = {
{ "ignore_header", "Ignorance List:", 0 },
{ "ignore_line", "$[-4]0 $1: $2 $3 $4", 4, { 1, 0, 0, 0 } },
{ "ignore_footer", "", 0 },
- { "talking_in", "You are now talking in %_$0%_", 1, { 0 } },
- { "query_start", "Starting query with %_$0%_", 1, { 0 } },
- { "no_query", "No query with %_$0%_", 1, { 0 } },
{ "no_msgs_got", "You have not received a message from anyone yet", 0 },
{ "no_msgs_sent", "You have not sent a message to anyone yet", 0 },
diff --git a/src/fe-common/irc/module-formats.h b/src/fe-common/irc/module-formats.h
index aa4c87c3..e92757fc 100644
--- a/src/fe-common/irc/module-formats.h
+++ b/src/fe-common/irc/module-formats.h
@@ -12,7 +12,6 @@ enum {
IRCTXT_SERVER_RECONNECT_LIST,
IRCTXT_RECONNECT_REMOVED,
IRCTXT_RECONNECT_NOT_FOUND,
- IRCTXT_QUERY_SERVER_CHANGED,
IRCTXT_SETUPSERVER_ADDED,
IRCTXT_SETUPSERVER_REMOVED,
IRCTXT_SETUPSERVER_NOT_FOUND,
@@ -72,16 +71,6 @@ enum {
IRCTXT_INVITELIST,
IRCTXT_NO_SUCH_CHANNEL,
IRCTXT_CHANNEL_SYNCED,
- IRCTXT_NOT_IN_CHANNELS,
- IRCTXT_CURRENT_CHANNEL,
- IRCTXT_CHANLIST_HEADER,
- IRCTXT_CHANLIST_LINE,
- IRCTXT_CHANSETUP_NOT_FOUND,
- IRCTXT_CHANSETUP_ADDED,
- IRCTXT_CHANSETUP_REMOVED,
- IRCTXT_CHANSETUP_HEADER,
- IRCTXT_CHANSETUP_LINE,
- IRCTXT_CHANSETUP_FOOTER,
IRCTXT_FILL_4,
@@ -171,9 +160,6 @@ enum {
IRCTXT_IGNORE_HEADER,
IRCTXT_IGNORE_LINE,
IRCTXT_IGNORE_FOOTER,
- IRCTXT_TALKING_IN,
- IRCTXT_QUERY_STARTED,
- IRCTXT_NO_QUERY,
IRCTXT_NO_MSGS_GOT,
IRCTXT_NO_MSGS_SENT
};