From f3e5dcbe6521413344091004641feaa2906efb0f Mon Sep 17 00:00:00 2001
From: ouwou <26526779+ouwou@users.noreply.github.com>
Date: Fri, 9 Sep 2022 02:40:33 -0400
Subject: fix some potential crashes because of optionals
---
src/components/chatmessage.cpp | 18 ++++++++++++------
1 file changed, 12 insertions(+), 6 deletions(-)
(limited to 'src/components/chatmessage.cpp')
diff --git a/src/components/chatmessage.cpp b/src/components/chatmessage.cpp
index 1aca81d..89c924e 100644
--- a/src/components/chatmessage.cpp
+++ b/src/components/chatmessage.cpp
@@ -655,13 +655,19 @@ Gtk::Widget *ChatMessageItemContainer::CreateReplyComponent(const Message &data)
const auto role = discord.GetRole(role_id);
if (role.has_value()) {
const auto author = discord.GetUser(author_id);
- return "Color) + "\">" + author->GetEscapedString() + "";
+ if (author.has_value()) {
+ return "Color) + "\">" + author->GetEscapedString() + "";
+ }
}
}
}
const auto author = discord.GetUser(author_id);
- return author->GetEscapedBoldString();
+ if (author.has_value()) {
+ return author->GetEscapedBoldString();
+ }
+
+ return "Unknown User";
};
// if the message wasnt fetched from store it might have an un-fetched reference
@@ -673,15 +679,15 @@ Gtk::Widget *ChatMessageItemContainer::CreateReplyComponent(const Message &data)
}
if (data.Interaction.has_value()) {
- const auto user = *discord.GetUser(data.Interaction->User.ID);
-
if (data.GuildID.has_value()) {
- lbl->set_markup(get_author_markup(user.ID, *data.GuildID) +
+ lbl->set_markup(get_author_markup(data.Interaction->User.ID, *data.GuildID) +
" used /" +
Glib::Markup::escape_text(data.Interaction->Name) +
"");
+ } else if (const auto user = discord.GetUser(data.Interaction->User.ID); user.has_value()) {
+ lbl->set_markup(user->GetEscapedBoldString());
} else {
- lbl->set_markup(user.GetEscapedBoldString());
+ lbl->set_markup("Unknown User");
}
} else if (referenced_message.has_value()) {
if (referenced_message.value() == nullptr) {
--
cgit v1.2.3