X-Git-Url: http://git.silcnet.org/gitweb/?a=blobdiff_plain;f=apps%2Firssi%2Fsrc%2Ffe-common%2Fsilc%2Ffe-silc-messages.c;fp=apps%2Firssi%2Fsrc%2Ffe-common%2Fsilc%2Ffe-silc-messages.c;h=0000000000000000000000000000000000000000;hb=72c2de619079457f7a68100eb13385275a424a23;hp=5d87ae25d372ed7cbf5b8c0befb26126352c575a;hpb=e7b6c157b80152bf9fb9266e6bdd93f9fb0db776;p=runtime.git diff --git a/apps/irssi/src/fe-common/silc/fe-silc-messages.c b/apps/irssi/src/fe-common/silc/fe-silc-messages.c deleted file mode 100644 index 5d87ae25..00000000 --- a/apps/irssi/src/fe-common/silc/fe-silc-messages.c +++ /dev/null @@ -1,518 +0,0 @@ -/* - - fe-silc-messages.c - - Author: Jochen Eisinger - - Copyright (C) 2002 Jochen Eisinger - - 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. - -*/ - -#include "module.h" -#include "modules.h" -#include "signals.h" -#include "themes.h" -#include "levels.h" -#include "misc.h" -#include "special-vars.h" -#include "settings.h" - -#include "servers.h" -#include "channels.h" -#include "nicklist.h" -#include "ignore.h" - -#include "window-items.h" -#include "fe-queries.h" -#include "fe-messages.h" -#include "hilight-text.h" -#include "printtext.h" -#include "module-formats.h" - -#define VERIFIED_MSG(v,msg) (v == SILC_MSG_SIGNED_VERIFIED ? \ - msg##_SIGNED : (v == SILC_MSG_SIGNED_UNKNOWN ? \ - msg##_UNKNOWN : msg##_FAILED)) - -#define VERIFIED_MSG2(v,msg) (v >= 0 ? VERIFIED_MSG(v,msg) : msg) - -static void sig_signed_message_public(SERVER_REC * server, const char *msg, - const char *nick, - const char *address, - const char *target, - int verified) -{ - CHANNEL_REC *chanrec; - NICK_REC *nickrec = NULL; /* we cheat here a little to keep the limit of - 6 parameters to a signal handler ... */ - const char *nickmode, *printnick; - int for_me, print_channel, level; - char *color, *freemsg = NULL; - HILIGHT_REC *hilight; - - /* NOTE: this may return NULL if some channel is just closed with - /WINDOW CLOSE and server still sends the few last messages */ - chanrec = channel_find(server, target); - if (nickrec == NULL && chanrec != NULL) - nickrec = nicklist_find(chanrec, nick); - - for_me = !settings_get_bool("hilight_nick_matches") ? FALSE : - nick_match_msg(chanrec, msg, server->nick); - hilight = for_me ? NULL : - hilight_match_nick(server, target, nick, address, MSGLEVEL_PUBLIC, msg); - color = (hilight == NULL) ? NULL : hilight_get_color(hilight); - - print_channel = chanrec == NULL || - !window_item_is_active((WI_ITEM_REC *) chanrec); - if (!print_channel && settings_get_bool("print_active_channel") && - window_item_window((WI_ITEM_REC *) chanrec)->items->next != NULL) - print_channel = TRUE; - - level = MSGLEVEL_PUBLIC; - if (for_me) - level |= MSGLEVEL_HILIGHT; - - if (settings_get_bool("emphasis")) - msg = freemsg = expand_emphasis((WI_ITEM_REC *) chanrec, msg); - - /* get nick mode & nick what to print the msg with - (in case there's multiple identical nicks) */ - nickmode = channel_get_nickmode(chanrec, nick); - printnick = nickrec == NULL ? nick : - g_hash_table_lookup(printnicks, nickrec); - if (printnick == NULL) - printnick = nick; - - if (color != NULL) { - /* highlighted nick */ - TEXT_DEST_REC dest; - format_create_dest(&dest, server, target, level, NULL); - hilight_update_text_dest(&dest,hilight); - if (!print_channel) /* message to active channel in windpw */ - printformat_module_dest("fe-common/silc", &dest, - VERIFIED_MSG(verified, SILCTXT_PUBMSG_HILIGHT), - color, printnick, msg, nickmode); - else /* message to not existing/active channel */ - printformat_module_dest("fe-common/silc", &dest, - VERIFIED_MSG(verified, SILCTXT_PUBMSG_HILIGHT_CHANNEL), - color, printnick, target, msg, nickmode); - - } else { - if (!print_channel) - printformat_module("fe-common/silc", server, target, level, - for_me ? VERIFIED_MSG(verified, SILCTXT_PUBMSG_ME) : - VERIFIED_MSG(verified,SILCTXT_PUBMSG), - printnick, msg, nickmode); - else - printformat_module("fe-common/silc", server, target, level, - for_me ? VERIFIED_MSG(verified, SILCTXT_PUBMSG_ME_CHANNEL) : - VERIFIED_MSG(verified, SILCTXT_PUBMSG_CHANNEL), - printnick, target, msg, nickmode); - } - - g_free_not_null(freemsg); - g_free_not_null(color); -} - -static void sig_signed_message_own_public(SERVER_REC * server, - const char *msg, - const char *target) -{ - WINDOW_REC *window; - CHANNEL_REC *channel; - const char *nickmode; - char *freemsg = NULL; - int print_channel; - - channel = channel_find(server, target); - if (channel != NULL) - target = channel->visible_name; - - nickmode = channel_get_nickmode(channel, server->nick); - - window = channel == NULL ? NULL : - window_item_window((WI_ITEM_REC *) channel); - - print_channel = window == NULL || - window->active != (WI_ITEM_REC *) channel; - - if (!print_channel && settings_get_bool("print_active_channel") && - window != NULL && g_slist_length(window->items) > 1) - print_channel = TRUE; - - if (settings_get_bool("emphasis")) - msg = freemsg = expand_emphasis((WI_ITEM_REC *) channel, msg); - - if (!print_channel) { - printformat_module("fe-common/silc", server, target, - MSGLEVEL_PUBLIC | MSGLEVEL_NOHILIGHT | - MSGLEVEL_NO_ACT, SILCTXT_OWN_MSG_SIGNED, server->nick, msg, - nickmode); - } else { - printformat_module("fe-common/silc", server, target, - MSGLEVEL_PUBLIC | MSGLEVEL_NOHILIGHT | - MSGLEVEL_NO_ACT, SILCTXT_OWN_MSG_CHANNEL_SIGNED, - server->nick, target, msg, nickmode); - } - - g_free_not_null(freemsg); -} - -static void sig_signed_message_private(SERVER_REC * server, - const char *msg, const char *nick, - const char *address, int verified) -{ - QUERY_REC *query; - char *freemsg = NULL; - - query = query_find(server, nick); - - if (settings_get_bool("emphasis")) - msg = freemsg = expand_emphasis((WI_ITEM_REC *) query, msg); - - printformat_module("fe-common/silc", server, nick, MSGLEVEL_MSGS, - query == NULL ? VERIFIED_MSG(verified, SILCTXT_MSG_PRIVATE) : - VERIFIED_MSG(verified, SILCTXT_MSG_PRIVATE_QUERY), nick, address, msg); - - g_free_not_null(freemsg); -} - -static void sig_signed_message_own_private(SERVER_REC * server, - const char *msg, - const char *target, - const char *origtarget) -{ - QUERY_REC *query; - char *freemsg = NULL; - - g_return_if_fail(server != NULL); - g_return_if_fail(msg != NULL); - - if (target == NULL) { - /* this should only happen if some special target failed and - we should display some error message. currently the special - targets are only ',' and '.'. */ - g_return_if_fail(strcmp(origtarget, ",") == 0 || - strcmp(origtarget, ".") == 0); - - printformat_module("fe-common/silc", NULL, NULL, MSGLEVEL_CLIENTNOTICE, - *origtarget == ',' ? SILCTXT_NO_MSGS_GOT : - SILCTXT_NO_MSGS_SENT); - signal_stop(); - return; - } - - query = privmsg_get_query(server, target, TRUE, MSGLEVEL_MSGS); - - if (settings_get_bool("emphasis")) - msg = freemsg = expand_emphasis((WI_ITEM_REC *) query, msg); - - printformat_module("fe-common/silc", server, target, - MSGLEVEL_MSGS | MSGLEVEL_NOHILIGHT | MSGLEVEL_NO_ACT, - query == NULL ? SILCTXT_OWN_MSG_PRIVATE_SIGNED : - SILCTXT_OWN_MSG_PRIVATE_QUERY_SIGNED, target, msg, - server->nick); - - g_free_not_null(freemsg); -} - -static void sig_message_own_action_all(SERVER_REC *server, - const char *msg, const char *target, - bool is_channel, bool is_signed) -{ - void *item; - char *freemsg = NULL; - - if (is_channel) - item = channel_find(server, target); - else - item = query_find(server, target); - - if (settings_get_bool("emphasis")) - msg = freemsg = expand_emphasis(item, msg); - - printformat(server, target, - MSGLEVEL_ACTIONS | MSGLEVEL_NOHILIGHT | MSGLEVEL_NO_ACT | - (is_channel ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS), - item != NULL ? - (is_signed ? SILCTXT_OWN_ACTION_SIGNED : SILCTXT_OWN_ACTION) : - (is_signed ? SILCTXT_OWN_ACTION_TARGET_SIGNED : - SILCTXT_OWN_ACTION_TARGET), - server->nick, msg, target); - - g_free_not_null(freemsg); -} - -static void sig_message_own_action(SERVER_REC *server, const char *msg, - const char *target) -{ - sig_message_own_action_all(server, msg, target, TRUE, FALSE); -} - -static void sig_message_own_private_action(SERVER_REC *server, - const char *msg, const char *target) -{ - sig_message_own_action_all(server, msg, target, FALSE, FALSE); -} - -static void sig_message_own_action_signed(SERVER_REC *server, - const char *msg, const char *target) -{ - sig_message_own_action_all(server, msg, target, TRUE, TRUE); -} - -static void sig_message_own_private_action_signed(SERVER_REC *server, - const char *msg, const char *target) -{ - sig_message_own_action_all(server, msg, target, FALSE, TRUE); -} - -static void sig_message_action_all(SERVER_REC *server, const char *msg, - const char *nick, const char *address, - const char *target, int is_channel, - int verified) -{ - void *item; - char *freemsg = NULL; - int level; - - level = MSGLEVEL_ACTIONS | - (is_channel ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS); - - if (ignore_check(server, nick, address, target, msg, level)) - return; - - if (is_channel) - item = channel_find(server, target); - else - item = privmsg_get_query(server, nick, FALSE, level); - - if (settings_get_bool("emphasis")) - msg = freemsg = expand_emphasis(item, msg); - - if (is_channel) { - /* channel action */ - if (window_item_is_active(item)) { - /* message to active channel in window */ - printformat(server, target, level, - VERIFIED_MSG2(verified, SILCTXT_ACTION_PUBLIC), - nick, target, msg); - } else { - /* message to not existing/active channel */ - printformat(server, target, level, - VERIFIED_MSG2(verified, SILCTXT_ACTION_PUBLIC_CHANNEL), - nick, target, msg); - } - } else { - /* private action */ - printformat(server, nick, MSGLEVEL_ACTIONS | MSGLEVEL_MSGS, - item == NULL ? VERIFIED_MSG2(verified, SILCTXT_ACTION_PRIVATE) : - VERIFIED_MSG2(verified, SILCTXT_ACTION_PRIVATE_QUERY), - nick, address == NULL ? "" : address, msg); - } - - g_free_not_null(freemsg); -} - -static void sig_message_action(SERVER_REC *server, const char *msg, - const char *nick, const char *address, - const char *target) -{ - sig_message_action_all(server, msg, nick, address, target, TRUE, -1); -} - -static void sig_message_private_action(SERVER_REC *server, const char *msg, - const char *nick, const char *address, - const char *target) -{ - sig_message_action_all(server, msg, nick, address, target, FALSE, -1); -} - -static void sig_message_action_signed(SERVER_REC *server, const char *msg, - const char *nick, const char *address, - const char *target, int verified) -{ - sig_message_action_all(server, msg, nick, address, target, TRUE, verified); -} - -static void sig_message_private_action_signed(SERVER_REC *server, - const char *msg, const char *nick, - const char *address, const char *target, - int verified) -{ - sig_message_action_all(server, msg, nick, address, target, FALSE, verified); -} - -static void sig_message_own_notice_all(SERVER_REC *server, - const char *msg, const char *target, - bool is_signed) -{ - printformat(server, target, - MSGLEVEL_NOTICES | MSGLEVEL_NOHILIGHT | MSGLEVEL_NO_ACT, - (is_signed ? SILCTXT_OWN_NOTICE_SIGNED : SILCTXT_OWN_NOTICE), - target, msg); -} - -static void sig_message_own_notice(SERVER_REC *server, const char *msg, - const char *target) -{ - sig_message_own_notice_all(server, msg, target, FALSE); -} - -static void sig_message_own_notice_signed(SERVER_REC *server, - const char *msg, const char *target) -{ - sig_message_own_notice_all(server, msg, target, TRUE); -} - -static void sig_message_notice_all(SERVER_REC *server, const char *msg, - const char *nick, const char *address, - const char *target, int is_channel, - int verified) -{ - if (ignore_check(server, nick, address, target, msg, MSGLEVEL_NOTICES)) - return; - - if (is_channel) { - /* channel notice */ - printformat(server, target, MSGLEVEL_NOTICES, - VERIFIED_MSG2(verified, SILCTXT_NOTICE_PUBLIC), - nick, target, msg); - } else { - /* private notice */ - printformat(server, nick, MSGLEVEL_NOTICES, - VERIFIED_MSG2(verified, SILCTXT_NOTICE_PRIVATE), - nick, address == NULL ? "" : address, msg); - } - -} - -static void sig_message_notice(SERVER_REC *server, const char *msg, - const char *nick, const char *address, - const char *target) -{ - sig_message_notice_all(server, msg, nick, address, target, TRUE, -1); -} - -static void sig_message_private_notice(SERVER_REC *server, const char *msg, - const char *nick, const char *address, - const char *target) -{ - sig_message_notice_all(server, msg, nick, address, target, FALSE, -1); -} - -static void sig_message_notice_signed(SERVER_REC *server, const char *msg, - const char *nick, const char *address, - const char *target, int verified) -{ - sig_message_notice_all(server, msg, nick, address, target, TRUE, verified); -} - -static void sig_message_private_notice_signed(SERVER_REC *server, - const char *msg, const char *nick, - const char *address, const char *target, - int verified) -{ - sig_message_notice_all(server, msg, nick, address, target, FALSE, verified); -} - -void fe_silc_messages_init(void) -{ - signal_add_last("message signed_public", - (SIGNAL_FUNC) sig_signed_message_public); - signal_add_last("message signed_own_public", - (SIGNAL_FUNC) sig_signed_message_own_public); - signal_add_last("message signed_private", - (SIGNAL_FUNC) sig_signed_message_private); - signal_add_last("message signed_own_private", - (SIGNAL_FUNC) sig_signed_message_own_private); - - signal_add_last("message silc own_action", - (SIGNAL_FUNC) sig_message_own_action); - signal_add_last("message silc action", - (SIGNAL_FUNC) sig_message_action); - signal_add_last("message silc signed_own_action", - (SIGNAL_FUNC) sig_message_own_action_signed); - signal_add_last("message silc signed_action", - (SIGNAL_FUNC) sig_message_action_signed); - signal_add_last("message silc own_private_action", - (SIGNAL_FUNC) sig_message_own_private_action); - signal_add_last("message silc private_action", - (SIGNAL_FUNC) sig_message_private_action); - signal_add_last("message silc signed_own_private_action", - (SIGNAL_FUNC) sig_message_own_private_action_signed); - signal_add_last("message silc signed_private_action", - (SIGNAL_FUNC) sig_message_private_action_signed); - - signal_add_last("message silc own_notice", - (SIGNAL_FUNC) sig_message_own_notice); - signal_add_last("message silc notice", - (SIGNAL_FUNC) sig_message_notice); - signal_add_last("message silc signed_own_notice", - (SIGNAL_FUNC) sig_message_own_notice_signed); - signal_add_last("message silc signed_notice", - (SIGNAL_FUNC) sig_message_notice_signed); - signal_add_last("message silc own_private_notice", - (SIGNAL_FUNC) sig_message_own_notice); - signal_add_last("message silc private_notice", - (SIGNAL_FUNC) sig_message_private_notice); - signal_add_last("message silc signed_own_private_notice", - (SIGNAL_FUNC) sig_message_own_notice_signed); - signal_add_last("message silc signed_private_notice", - (SIGNAL_FUNC) sig_message_private_notice_signed); -} - -void fe_silc_messages_deinit(void) -{ - signal_remove("message signed_public", - (SIGNAL_FUNC) sig_signed_message_public); - signal_remove("message signed_own_public", - (SIGNAL_FUNC) sig_signed_message_own_public); - signal_remove("message signed_private", - (SIGNAL_FUNC) sig_signed_message_private); - signal_remove("message signed_own_private", - (SIGNAL_FUNC) sig_signed_message_own_private); - - signal_remove("message silc own_action", - (SIGNAL_FUNC) sig_message_own_action); - signal_remove("message silc action", - (SIGNAL_FUNC) sig_message_action); - signal_remove("message silc signed_own_action", - (SIGNAL_FUNC) sig_message_own_action_signed); - signal_remove("message silc signed_action", - (SIGNAL_FUNC) sig_message_action_signed); - signal_remove("message silc own_private_action", - (SIGNAL_FUNC) sig_message_own_private_action); - signal_remove("message silc private_action", - (SIGNAL_FUNC) sig_message_private_action); - signal_remove("message silc signed_own_private_action", - (SIGNAL_FUNC) sig_message_own_private_action_signed); - signal_remove("message silc signed_private_action", - (SIGNAL_FUNC) sig_message_private_action_signed); - - signal_remove("message silc own_notice", - (SIGNAL_FUNC) sig_message_own_notice); - signal_remove("message silc notice", - (SIGNAL_FUNC) sig_message_notice); - signal_remove("message silc signed_own_notice", - (SIGNAL_FUNC) sig_message_own_notice_signed); - signal_remove("message silc signed_notice", - (SIGNAL_FUNC) sig_message_notice_signed); - signal_remove("message silc own_private_notice", - (SIGNAL_FUNC) sig_message_own_notice); - signal_remove("message silc private_notice", - (SIGNAL_FUNC) sig_message_private_notice); - signal_remove("message silc signed_own_private_notice", - (SIGNAL_FUNC) sig_message_own_notice_signed); - signal_remove("message silc signed_private_notice", - (SIGNAL_FUNC) sig_message_private_notice_signed); -}