Optimize event accessors a bit

This commit is contained in:
Nicolas Werner 2023-03-20 02:28:13 +01:00
parent eb1a900ed2
commit 807bbd8f40
No known key found for this signature in database
GPG key ID: C8D75E610773F2D9

View file

@ -15,12 +15,12 @@ namespace {
struct IsStateEvent struct IsStateEvent
{ {
template<class T> template<class T>
bool operator()(const mtx::events::StateEvent<T> &) constexpr bool operator()(const mtx::events::StateEvent<T> &)
{ {
return true; return true;
} }
template<class T> template<class T>
bool operator()(const mtx::events::Event<T> &) constexpr bool operator()(const mtx::events::Event<T> &)
{ {
return false; return false;
} }
@ -39,28 +39,6 @@ struct EventMsgType
} }
}; };
struct EventRoomName
{
template<class T>
std::string operator()(const T &e)
{
if constexpr (std::is_same_v<mtx::events::StateEvent<mtx::events::state::Name>, T>)
return e.content.name;
return "";
}
};
struct EventRoomTopic
{
template<class T>
std::string operator()(const T &e)
{
if constexpr (std::is_same_v<mtx::events::StateEvent<mtx::events::state::Topic>, T>)
return e.content.topic;
return "";
}
};
struct CallType struct CallType
{ {
template<class T> template<class T>
@ -86,37 +64,37 @@ struct CallType
struct EventBody struct EventBody
{ {
template<class T> template<class T>
std::string operator()(const mtx::events::Event<T> &e) const std::string *operator()(const mtx::events::Event<T> &e)
{ {
if constexpr (requires(decltype(e) t) { t.content.body.value(); }) if constexpr (requires(decltype(e) t) { t.content.body.value(); })
return e.content.body ? e.content.body.value() : ""; return e.content.body ? &e.content.body.value() : nullptr;
else if constexpr (requires(decltype(e) t) { std::string{t.content.body}; }) else if constexpr (requires(decltype(e) t) { std::string{t.content.body}; })
return e.content.body; return &e.content.body;
return ""; return nullptr;
} }
}; };
struct EventFormattedBody struct EventFormattedBody
{ {
template<class T> template<class T>
std::string operator()(const mtx::events::RoomEvent<T> &e) const std::string *operator()(const mtx::events::RoomEvent<T> &e)
{ {
if constexpr (requires { T::formatted_body; }) { if constexpr (requires { T::formatted_body; }) {
if (e.content.format == "org.matrix.custom.html") if (e.content.format == "org.matrix.custom.html")
return e.content.formatted_body; return &e.content.formatted_body;
} }
return ""; return nullptr;
} }
}; };
struct EventFile struct EventFile
{ {
template<class T> template<class T>
std::optional<mtx::crypto::EncryptedFile> operator()(const mtx::events::Event<T> &e) const std::optional<mtx::crypto::EncryptedFile> *operator()(const mtx::events::Event<T> &e)
{ {
if constexpr (requires { T::file; }) if constexpr (requires { T::file; })
return e.content.file; return &e.content.file;
return std::nullopt; return nullptr;
} }
}; };
@ -137,8 +115,8 @@ struct EventUrl
std::string operator()(const mtx::events::Event<T> &e) std::string operator()(const mtx::events::Event<T> &e)
{ {
if constexpr (requires { T::url; }) { if constexpr (requires { T::url; }) {
if (auto file = EventFile{}(e)) if (auto file = EventFile{}(e); file && *file)
return file->url; return (*file)->url;
return e.content.url; return e.content.url;
} }
return ""; return "";
@ -351,15 +329,23 @@ mtx::accessors::msg_type(const mtx::events::collections::TimelineEvents &event)
{ {
return std::visit(EventMsgType{}, event); return std::visit(EventMsgType{}, event);
} }
std::string std::string
mtx::accessors::room_name(const mtx::events::collections::TimelineEvents &event) mtx::accessors::room_name(const mtx::events::collections::TimelineEvents &event)
{ {
return std::visit(EventRoomName{}, event); if (auto c = std::get_if<mtx::events::StateEvent<mtx::events::state::Name>>(&event))
return c->content.name;
else
return "";
} }
std::string std::string
mtx::accessors::room_topic(const mtx::events::collections::TimelineEvents &event) mtx::accessors::room_topic(const mtx::events::collections::TimelineEvents &event)
{ {
return std::visit(EventRoomTopic{}, event); if (auto c = std::get_if<mtx::events::StateEvent<mtx::events::state::Topic>>(&event))
return c->content.topic;
else
return "";
} }
std::string std::string
@ -371,13 +357,15 @@ mtx::accessors::call_type(const mtx::events::collections::TimelineEvents &event)
std::string std::string
mtx::accessors::body(const mtx::events::collections::TimelineEvents &event) mtx::accessors::body(const mtx::events::collections::TimelineEvents &event)
{ {
return std::visit(EventBody{}, event); auto body = std::visit(EventBody{}, event);
return body ? *body : std::string{};
} }
std::string std::string
mtx::accessors::formatted_body(const mtx::events::collections::TimelineEvents &event) mtx::accessors::formatted_body(const mtx::events::collections::TimelineEvents &event)
{ {
return std::visit(EventFormattedBody{}, event); auto body = std::visit(EventFormattedBody{}, event);
return body ? *body : std::string{};
} }
QString QString
@ -395,7 +383,11 @@ mtx::accessors::formattedBodyWithFallback(const mtx::events::collections::Timeli
std::optional<mtx::crypto::EncryptedFile> std::optional<mtx::crypto::EncryptedFile>
mtx::accessors::file(const mtx::events::collections::TimelineEvents &event) mtx::accessors::file(const mtx::events::collections::TimelineEvents &event)
{ {
return std::visit(EventFile{}, event); auto temp = std::visit(EventFile{}, event);
if (temp)
return *temp;
else
return {};
} }
std::optional<mtx::crypto::EncryptedFile> std::optional<mtx::crypto::EncryptedFile>