From be7f78b632635c51089dc60f5bf178cc5db60350 Mon Sep 17 00:00:00 2001 From: Raquel Medina Date: Mon, 4 May 2020 10:57:37 +0200 Subject: share MessageEngine instance Share MessageEngine instance among clients in the same process using a common socket (same url). - add MessageEngineFactory class; - extend std::unordered_map<> to use QString as key; - use std::shared_ptr to share ownership among MessageEngineFactory and the engine clients; - force MessagEngine parent object null to avoid life cycle dependency on a parent; - protect insertions & deletions in m_calls map; Also, not directly related but as part of testing these changes: cleanup on voice to remove superflous model sorting (there's just one voice model for alexa voice agent). Bug-AGL: SPEC-3112 Signed-off-by: Raquel Medina Change-Id: Ie2304453dc37723dac13d256286eeb85f84ca2ab --- pbap/pbap.cpp | 13 ++++++------- pbap/pbap.h | 2 +- 2 files changed, 7 insertions(+), 8 deletions(-) (limited to 'pbap') diff --git a/pbap/pbap.cpp b/pbap/pbap.cpp index 53b07bd..f92139b 100644 --- a/pbap/pbap.cpp +++ b/pbap/pbap.cpp @@ -24,6 +24,7 @@ #include "responsemessage.h" #include "messagefactory.h" #include "messageengine.h" +#include "messageenginefactory.h" #include "pbap.h" @@ -81,24 +82,22 @@ int RecentCall::stringToEnum(QString key) } Pbap::Pbap (QUrl &url, QQmlContext *context, QObject * parent) : - QObject(parent), - m_mloop(nullptr) + QObject(parent) { - m_mloop = new MessageEngine(url); + m_mloop = MessageEngineFactory::getInstance().getMessageEngine(url); m_context = context; m_context->setContextProperty("ContactsModel", QVariant::fromValue(m_contacts)); qmlRegisterUncreatableType("PhoneNumber", 1, 0, "PhoneNumber", "Enum"); m_context->setContextProperty("RecentCallModel", QVariant::fromValue(m_calls)); qmlRegisterUncreatableType("RecentCall", 1, 0, "RecentCall", "Enum"); - QObject::connect(m_mloop, &MessageEngine::connected, this, &Pbap::onConnected); - QObject::connect(m_mloop, &MessageEngine::disconnected, this, &Pbap::onDisconnected); - QObject::connect(m_mloop, &MessageEngine::messageReceived, this, &Pbap::onMessageReceived); + QObject::connect(m_mloop.get(), &MessageEngine::connected, this, &Pbap::onConnected); + QObject::connect(m_mloop.get(), &MessageEngine::disconnected, this, &Pbap::onDisconnected); + QObject::connect(m_mloop.get(), &MessageEngine::messageReceived, this, &Pbap::onMessageReceived); } Pbap::~Pbap() { - delete m_mloop; } void Pbap::importContacts(int max_entries) diff --git a/pbap/pbap.h b/pbap/pbap.h index 4deb9c6..676b49d 100644 --- a/pbap/pbap.h +++ b/pbap/pbap.h @@ -157,7 +157,7 @@ class Pbap : public QObject void statusChanged(bool connected); private: - MessageEngine *m_mloop; + std::shared_ptr m_mloop; QQmlContext *m_context; QListm_contacts; QListm_calls; -- cgit 1.2.3-korg