summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>2000-07-30 17:32:55 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>2000-07-30 17:32:55 +0000
commit18bdc77b88f46c1e0cf914451633cc80b67f00a0 (patch)
tree295cfb62287da0134a6a38ca89b6495f6ea702e9
parentc8706013f8c170dd5483658c7cdc7f84a69ea6de (diff)
downloadirssi-18bdc77b88f46c1e0cf914451633cc80b67f00a0.zip
/SET beep_on_msg handling moved to printtext() where it catches all the
levels, not just the IRC levels. git-svn-id: http://svn.irssi.org/repos/irssi/trunk@552 dbcabf3a-b0e7-0310-adc4-f8d773084564
-rw-r--r--src/fe-common/core/printtext.c25
-rw-r--r--src/fe-common/irc/fe-events.c31
2 files changed, 22 insertions, 34 deletions
diff --git a/src/fe-common/core/printtext.c b/src/fe-common/core/printtext.c
index 0bc4dd60..3fb0a439 100644
--- a/src/fe-common/core/printtext.c
+++ b/src/fe-common/core/printtext.c
@@ -40,6 +40,7 @@ typedef struct {
int level;
} TEXT_DEST_REC;
+static int beep_msg_level, beep_when_away;
static int timestamps, msgs_timestamps, hide_text_style;
static int timestamp_timeout;
@@ -687,12 +688,22 @@ static char *get_server_tag(TEXT_DEST_REC *dest)
return output_format_text(dest, IRCTXT_SERVERTAG, server->tag);
}
-static void sig_print_text(WINDOW_REC *window, SERVER_REC *server, const char *target, gpointer level, const char *text)
+static void msg_beep_check(SERVER_REC *server, int level)
+{
+ if (level != 0 && (beep_msg_level & level) &&
+ (beep_when_away || (server != NULL && !server->usermode_away))) {
+ printbeep();
+ }
+}
+
+static void sig_print_text(WINDOW_REC *window, SERVER_REC *server,
+ const char *target, gpointer level,
+ const char *text)
{
TEXT_DEST_REC dest;
- gchar *dup, *ptr, type, *str, *timestamp, *servertag;
- gint fgcolor, bgcolor;
- gint flags;
+ char *dup, *ptr, type, *str, *timestamp, *servertag;
+ int fgcolor, bgcolor;
+ int flags;
g_return_if_fail(text != NULL);
g_return_if_fail(window != NULL);
@@ -702,6 +713,8 @@ static void sig_print_text(WINDOW_REC *window, SERVER_REC *server, const char *t
dest.channel = target;
dest.level = GPOINTER_TO_INT(level);
+ msg_beep_check(server, dest.level);
+
flags = 0; fgcolor = -1; bgcolor = -1; type = '\0';
window->last_line = time(NULL);
newline(window);
@@ -726,7 +739,7 @@ static void sig_print_text(WINDOW_REC *window, SERVER_REC *server, const char *t
break;
}
- *ptr = (gchar) translation_in[(gint) (guchar) *ptr];
+ *ptr = (char) translation_in[(gint) (guchar) *ptr];
}
if (type == 7)
@@ -906,6 +919,8 @@ static void read_settings(void)
timestamp_timeout = settings_get_int("timestamp_timeout");
msgs_timestamps = settings_get_bool("msgs_timestamps");
hide_text_style = settings_get_bool("hide_text_style");
+ beep_msg_level = level2bits(settings_get_str("beep_on_msg"));
+ beep_when_away = settings_get_bool("beep_when_away");
}
void printtext_init(void)
diff --git a/src/fe-common/irc/fe-events.c b/src/fe-common/irc/fe-events.c
index a8548afe..ff37ff69 100644
--- a/src/fe-common/irc/fe-events.c
+++ b/src/fe-common/irc/fe-events.c
@@ -43,16 +43,6 @@
#define target_level(target) \
(ischannel((target)[0]) ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS)
-static int beep_msg_level, beep_when_away;
-
-static void msg_beep_check(IRC_SERVER_REC *server, int level)
-{
- if (level != 0 && (beep_msg_level & level) &&
- (!server->usermode_away || beep_when_away)) {
- printbeep();
- }
-}
-
static void print_channel_msg(IRC_SERVER_REC *server, const char *msg,
const char *nick, const char *addr,
const char *target)
@@ -123,7 +113,6 @@ static void event_privmsg(const char *data, IRC_SERVER_REC *server, const char *
printformat(server, nick, MSGLEVEL_MSGS,
item == NULL ? IRCTXT_MSG_PRIVATE : IRCTXT_MSG_PRIVATE_QUERY, nick, addr, msg);
}
- msg_beep_check(server, target_level(target));
}
g_free(params);
@@ -131,7 +120,8 @@ static void event_privmsg(const char *data, IRC_SERVER_REC *server, const char *
/* we use "ctcp msg" here because "ctcp msg action" can be ignored with
/IGNORE * CTCPS, and we don't want that.. */
-static void ctcp_msg_check_action(gchar *data, IRC_SERVER_REC *server, gchar *nick, gchar *addr, gchar *target)
+static void ctcp_msg_check_action(const char *data, IRC_SERVER_REC *server,
+ const char *nick, const char *addr, const char *target)
{
WI_ITEM_REC *item;
int level;
@@ -167,8 +157,6 @@ static void ctcp_msg_check_action(gchar *data, IRC_SERVER_REC *server, gchar *ni
item == NULL ? IRCTXT_ACTION_PRIVATE : IRCTXT_ACTION_PRIVATE_QUERY,
nick, addr == NULL ? "" : addr, data);
}
-
- msg_beep_check(server, target_level(target));
}
static void event_notice(const char *data, IRC_SERVER_REC *server, const char *nick, const char *addr)
@@ -206,7 +194,6 @@ static void event_notice(const char *data, IRC_SERVER_REC *server, const char *n
}
}
- msg_beep_check(server, addr == NULL ? MSGLEVEL_SNOTES : MSGLEVEL_NOTICES);
g_free(params);
}
@@ -465,7 +452,6 @@ static void event_wallops(const char *data, IRC_SERVER_REC *server, const char *
printformat(server, NULL, MSGLEVEL_WALLOPS, IRCTXT_ACTION_WALLOPS, nick, tmp);
g_free(tmp);
}
- msg_beep_check(server, MSGLEVEL_WALLOPS);
}
static void channel_sync(CHANNEL_REC *channel)
@@ -609,17 +595,8 @@ static void sig_empty(void)
{
}
-static void read_settings(void)
-{
- beep_msg_level = level2bits(settings_get_str("beep_on_msg"));
- beep_when_away = settings_get_bool("beep_when_away");
-}
-
void fe_events_init(void)
{
- beep_msg_level = 0;
-
- read_settings();
signal_add("event privmsg", (SIGNAL_FUNC) event_privmsg);
signal_add("ctcp msg", (SIGNAL_FUNC) ctcp_msg_check_action);
signal_add("ctcp msg action", (SIGNAL_FUNC) sig_empty);
@@ -647,8 +624,6 @@ void fe_events_init(void)
signal_add("server lag disconnect", (SIGNAL_FUNC) sig_server_lag_disconnected);
signal_add("server reconnect remove", (SIGNAL_FUNC) sig_server_reconnect_removed);
signal_add("server reconnect not found", (SIGNAL_FUNC) sig_server_reconnect_not_found);
-
- signal_add("setup changed", (SIGNAL_FUNC) read_settings);
}
void fe_events_deinit(void)
@@ -680,6 +655,4 @@ void fe_events_deinit(void)
signal_remove("server lag disconnect", (SIGNAL_FUNC) sig_server_lag_disconnected);
signal_remove("server reconnect remove", (SIGNAL_FUNC) sig_server_reconnect_removed);
signal_remove("server reconnect not found", (SIGNAL_FUNC) sig_server_reconnect_not_found);
-
- signal_remove("setup changed", (SIGNAL_FUNC) read_settings);
}