diff options
author | ouwou <26526779+ouwou@users.noreply.github.com> | 2023-07-06 19:42:08 -0400 |
---|---|---|
committer | ouwou <26526779+ouwou@users.noreply.github.com> | 2023-07-06 19:42:08 -0400 |
commit | 9a3f6b472d4995c0d5619edc185836f7abb3bc15 (patch) | |
tree | 5eaa458965c4b645ec2a97421539b9ffae8c8403 | |
parent | 8a5f23fcb93a8674e394943af148c511165ac153 (diff) | |
download | abaddon-portaudio-9a3f6b472d4995c0d5619edc185836f7abb3bc15.tar.gz abaddon-portaudio-9a3f6b472d4995c0d5619edc185836f7abb3bc15.zip |
fix bad optional access in channel delete (fixes #187)
-rw-r--r-- | src/discord/discord.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/discord/discord.cpp b/src/discord/discord.cpp index 7b05b2d..d97f2c1 100644 --- a/src/discord/discord.cpp +++ b/src/discord/discord.cpp @@ -1826,9 +1826,12 @@ void DiscordClient::HandleGatewayPresenceUpdate(const GatewayMessage &msg) { void DiscordClient::HandleGatewayChannelDelete(const GatewayMessage &msg) { const auto id = msg.Data.at("id").get<Snowflake>(); const auto channel = GetChannel(id); - auto it = m_guild_to_channels.find(*channel->GuildID); - if (it != m_guild_to_channels.end()) - it->second.erase(id); + if (channel.has_value() && channel->GuildID.has_value()) { + auto it = m_guild_to_channels.find(*channel->GuildID); + if (it != m_guild_to_channels.end()) { + it->second.erase(id); + } + } m_store.ClearChannel(id); m_signal_channel_delete.emit(id); m_signal_channel_accessibility_changed.emit(id, false); |