diff options
Diffstat (limited to 'src/core')
-rw-r--r-- | src/core/chat-commands.c | 9 | ||||
-rw-r--r-- | src/core/expandos.c | 42 | ||||
-rw-r--r-- | src/core/ignore.c | 2 | ||||
-rw-r--r-- | src/core/server-rec.h | 4 |
4 files changed, 28 insertions, 29 deletions
diff --git a/src/core/chat-commands.c b/src/core/chat-commands.c index 969be382..22dc9e4f 100644 --- a/src/core/chat-commands.c +++ b/src/core/chat-commands.c @@ -62,7 +62,7 @@ static void cmd_join(const char *data, SERVER_REC *server) static void cmd_msg(const char *data, SERVER_REC *server, WI_ITEM_REC *item) { GHashTable *optlist; - char *target, *msg; + char *target, *origtarget, *msg; void *free_arg; int free_ret; @@ -78,16 +78,23 @@ static void cmd_msg(const char *data, SERVER_REC *server, WI_ITEM_REC *item) if (server == NULL || !server->connected) cmd_param_error(CMDERR_NOT_CONNECTED); + origtarget = target; free_ret = FALSE; if (strcmp(target, ",") == 0 || strcmp(target, ".") == 0) { target = parse_special(&target, server, item, NULL, &free_ret, NULL, 0); + if (target != NULL && *target == '\0') + target = NULL; } else if (strcmp(target, "*") == 0 && item != NULL) target = item->name; if (target != NULL) server->send_message(server, target, msg); + signal_emit(target != NULL && server->ischannel(target) ? + "message own_public" : "message own_private", 4, + server, msg, target, origtarget); + if (free_ret && target != NULL) g_free(target); cmd_params_free(free_arg); } diff --git a/src/core/expandos.c b/src/core/expandos.c index 006dd443..a0fd3a28 100644 --- a/src/core/expandos.c +++ b/src/core/expandos.c @@ -391,13 +391,6 @@ static char *expando_chatnet(SERVER_REC *server, void *item, int *free_ret) return server == NULL ? "" : server->connrec->chatnet; } -static void sig_message_private(SERVER_REC *server, const char *msg, - const char *nick, const char *address) -{ - g_free_not_null(last_privmsg_from); - last_privmsg_from = g_strdup(nick); -} - static void sig_message_public(SERVER_REC *server, const char *msg, const char *nick, const char *address, const char *target) @@ -406,28 +399,27 @@ static void sig_message_public(SERVER_REC *server, const char *msg, last_public_from = g_strdup(nick); } -static void cmd_msg(const char *data, SERVER_REC *server) +static void sig_message_private(SERVER_REC *server, const char *msg, + const char *nick, const char *address) { - GHashTable *optlist; - char *target, *msg; - void *free_arg; - - g_return_if_fail(data != NULL); + g_free_not_null(last_privmsg_from); + last_privmsg_from = g_strdup(nick); +} - if (!cmd_get_params(data, &free_arg, 2 | PARAM_FLAG_OPTIONS | - PARAM_FLAG_UNKNOWN_OPTIONS | PARAM_FLAG_GETREST, - "msg", &optlist, &target, &msg)) - return; +static void sig_message_own_private(SERVER_REC *server, const char *msg, + const char *target, const char *origtarget) +{ + g_return_if_fail(server != NULL); + g_return_if_fail(msg != NULL); - if (*target != '\0' && *msg != '\0' && - !server->ischannel(*target) && isalpha(*target)) { - g_free_not_null(last_sent_msg); + if (target != NULL) { + if (target != last_sent_msg) { + g_free_not_null(last_sent_msg); + last_sent_msg = g_strdup(target); + } g_free_not_null(last_sent_msg_body); - last_sent_msg = g_strdup(target); last_sent_msg_body = g_strdup(msg); } - - cmd_params_free(free_arg); } static int sig_timer(void) @@ -532,9 +524,9 @@ void expandos_init(void) "window server changed", EXPANDO_ARG_WINDOW, NULL); timer_tag = g_timeout_add(1000, (GSourceFunc) sig_timer, NULL); - signal_add("command msg", (SIGNAL_FUNC) cmd_msg); signal_add("message public", (SIGNAL_FUNC) sig_message_public); signal_add("message private", (SIGNAL_FUNC) sig_message_private); + signal_add("message own_private", (SIGNAL_FUNC) sig_message_own_private); } void expandos_deinit(void) @@ -559,5 +551,5 @@ void expandos_deinit(void) g_source_remove(timer_tag); signal_remove("message public", (SIGNAL_FUNC) sig_message_public); signal_remove("message private", (SIGNAL_FUNC) sig_message_private); - signal_remove("command msg", (SIGNAL_FUNC) cmd_msg); + signal_remove("message own_private", (SIGNAL_FUNC) sig_message_own_private); } diff --git a/src/core/ignore.c b/src/core/ignore.c index 81df32ba..5d94ad15 100644 --- a/src/core/ignore.c +++ b/src/core/ignore.c @@ -65,7 +65,7 @@ int ignore_check(SERVER_REC *server, const char *nick, const char *host, g_return_val_if_fail(server != NULL, 0); chanrec = (channel != NULL && server != NULL && - server->ischannel(*channel)) ? + server->ischannel(channel)) ? channel_find(server, channel) : NULL; best_mask = 0; best_patt = 0; best_ignore = FALSE; diff --git a/src/core/server-rec.h b/src/core/server-rec.h index 53b9f7f0..871cb80a 100644 --- a/src/core/server-rec.h +++ b/src/core/server-rec.h @@ -53,8 +53,8 @@ GSList *queries; void (*channels_join)(SERVER_REC *server, const char *data, int automatic); /* returns true if `flag' indicates a nick flag (op/voice/halfop) */ int (*isnickflag)(char flag); -/* returns true if `flag' indicates a channel */ -int (*ischannel)(char flag); +/* returns true if `data' indicates a channel */ +int (*ischannel)(const char *data); /* returns all nick flag characters in order op, voice, halfop. If some of them aren't supported '\0' can be used. */ const char *(*get_nick_flags)(void); |