diff options
author | dequis <dx@dxzone.com.ar> | 2017-01-03 03:30:38 -0300 |
---|---|---|
committer | dequis <dx@dxzone.com.ar> | 2017-01-03 03:30:38 -0300 |
commit | 3b8e4be6374cf43d15957ac255ebf2df14fe4c50 (patch) | |
tree | e8050e371a0486ee4fa76a93862e39f0b13bf283 /protocols/purple/purple.c | |
parent | 188b75e113480aa4237d77927e3f53993ac4992a (diff) |
purple: show self-messages in groupchat backlogs (before join)
That is, flagged with PURPLE_MESSAGE_DELAYED. Those are safe to display.
This is similar to what adium does. Thanks EionRobb for the idea.
Diffstat (limited to 'protocols/purple/purple.c')
-rw-r--r-- | protocols/purple/purple.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/protocols/purple/purple.c b/protocols/purple/purple.c index 4333d903..0b74c8d8 100644 --- a/protocols/purple/purple.c +++ b/protocols/purple/purple.c @@ -1196,11 +1196,15 @@ static void handle_conv_msg(PurpleConversation *conv, const char *who, const cha g_free(message); } -/* Handles write_im and write_chat. Removes echoes of locally sent messages */ +/* Handles write_im and write_chat. Removes echoes of locally sent messages. + * + * PURPLE_MESSAGE_DELAYED is used for chat backlogs - if a message has both + * that flag and _SEND, it's a self-message from before joining the channel. + * Those are safe to display. The rest (with just _SEND) may be echoes. */ static void prplcb_conv_msg(PurpleConversation *conv, const char *who, const char *message, PurpleMessageFlags flags, time_t mtime) { - if (!(flags & PURPLE_MESSAGE_SEND)) { - handle_conv_msg(conv, who, message, 0, mtime); + if ((!(flags & PURPLE_MESSAGE_SEND)) || (flags & PURPLE_MESSAGE_DELAYED)) { + handle_conv_msg(conv, who, message, (flags & PURPLE_MESSAGE_SEND) ? OPT_SELFMESSAGE : 0, mtime); } } |