diff options
| author | dequis <dx@dxzone.com.ar> | 2015-11-25 23:14:34 -0300 | 
|---|---|---|
| committer | dequis <dx@dxzone.com.ar> | 2015-11-25 23:14:34 -0300 | 
| commit | a3019499665384a3dcbbc11016d256e6d4dcd26c (patch) | |
| tree | a0ea27abac5882c6f22289922ad26644a1b72493 /protocols/oscar/misc.c | |
| parent | 42a418e60fb5d3dfbcd9bdc5251bf4a6047bc3c5 (diff) | |
purple: fix /join #channel, which joined a different channel
When joining named channels, purple_chat_join() returned NULL instead of
a struct groupchat, which was actually created in the conversation
created callback (prplcb_conv_new()).
If the name of this channel turned out to be different to the joined
one, this meant having one empty window in the irc client, and another
one for the other channel.
The fix is to return a mostly-empty struct groupchat immediately, and
pick it up later when the PurpleConversation is created using
bee_chat_by_title(). If that fails, fall back to creating a new one.
This bug also meant there was no proper way to report a join failure.
Future commits will address that, this one just makes that easier.
Thanks to Etan Reisner (deryni) for enlightening me while i was trying
to figure out how to fix this.
Diffstat (limited to 'protocols/oscar/misc.c')
0 files changed, 0 insertions, 0 deletions
