From 274da5d7bc049c748b0eb04f24275efe15ab7720 Mon Sep 17 00:00:00 2001 From: Linus Jahn Date: Wed, 2 Mar 2022 22:31:12 +0100 Subject: Stanza: Make E2eeMetadata optional to avoid allocation Avoids an allocation of the E2eeMetadataPrivate object when it's not used. It doesn't use optional directly because that wouldn't avoid the allocation and takes up 16 bytes instead of 8. This concept could be generalized and used elsewhere in the code (e.g. extended addresses in the stanza are unused 99% of the time). --- src/base/QXmppStanza.cpp | 28 +++++++++++++++++++++++----- 1 file changed, 23 insertions(+), 5 deletions(-) (limited to 'src/base/QXmppStanza.cpp') diff --git a/src/base/QXmppStanza.cpp b/src/base/QXmppStanza.cpp index 25b9baac..3aff0404 100644 --- a/src/base/QXmppStanza.cpp +++ b/src/base/QXmppStanza.cpp @@ -525,6 +525,24 @@ QXmppE2eeMetadata::QXmppE2eeMetadata(const QXmppE2eeMetadata &other) = default; QXmppE2eeMetadata::~QXmppE2eeMetadata() = default; +/// \cond +QXmppE2eeMetadata::QXmppE2eeMetadata(const std::optional &other) + : d(nullptr) +{ + if (other) { + *this = *other; + } +} + +std::optional QXmppE2eeMetadata::toOptional() const +{ + if (d) { + return *this; + } + return {}; +} +/// \endcond + /// /// Assigns \a other to this end-to-end encryption metadata class. /// @@ -618,7 +636,7 @@ public: QXmppStanza::Error error; QXmppElementList extensions; QList extendedAddresses; - QXmppE2eeMetadata e2eeMetadata; + QXmppE2eeMetadata e2eeMetadata = QXmppE2eeMetadata(std::nullopt); }; /// @@ -776,9 +794,9 @@ void QXmppStanza::setExtendedAddresses(const QList &addres /// /// \since QXmpp 1.5 /// -QXmppE2eeMetadata QXmppStanza::e2eeMetadata() const +std::optional QXmppStanza::e2eeMetadata() const { - return d->e2eeMetadata; + return d->e2eeMetadata.toOptional(); } /// @@ -786,9 +804,9 @@ QXmppE2eeMetadata QXmppStanza::e2eeMetadata() const /// /// \since QXmpp 1.5 /// -void QXmppStanza::setE2eeMetadata(const QXmppE2eeMetadata &e2eeMetadata) +void QXmppStanza::setE2eeMetadata(const std::optional &e2eeMetadata) { - d->e2eeMetadata = e2eeMetadata; + d->e2eeMetadata = QXmppE2eeMetadata(e2eeMetadata); } /// \cond -- cgit v1.2.3