summaryrefslogtreecommitdiffstats
path: root/voice
diff options
context:
space:
mode:
authorRaquel Medina <raquel.medina@konsulko.com>2020-05-04 10:57:37 +0200
committerRaquel Medina <raquel.medina@konsulko.com>2020-05-04 11:08:06 +0200
commitbe7f78b632635c51089dc60f5bf178cc5db60350 (patch)
tree37b4d81ad2be449a813491d73c442284a1ac220f /voice
parentc34c355242319fcb5fb2385040a4d7f819f0afc6 (diff)
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<MessageEngine> 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 <raquel.medina@konsulko.com> Change-Id: Ie2304453dc37723dac13d256286eeb85f84ca2ab
Diffstat (limited to 'voice')
-rw-r--r--voice/voice.cpp13
-rw-r--r--voice/voice.h2
-rw-r--r--voice/voiceagentregistry.cpp6
3 files changed, 7 insertions, 14 deletions
diff --git a/voice/voice.cpp b/voice/voice.cpp
index 5961882..396984a 100644
--- a/voice/voice.cpp
+++ b/voice/voice.cpp
@@ -21,27 +21,26 @@
#include "eventmessage.h"
#include "messagefactory.h"
#include "messageengine.h"
+#include "messageenginefactory.h"
#include "voiceagentregistry.h"
#include "voice.h"
Voice::Voice (QUrl &url, QQmlContext *context, QObject *parent) :
- QObject(parent),
- m_loop(nullptr)
+ QObject(parent)
{
- m_loop = new MessageEngine(url);
+ m_loop = MessageEngineFactory::getInstance().getMessageEngine(url);
m_var = new VoiceAgentRegistry(this, context, parent);
- QObject::connect(m_loop, &MessageEngine::connected,
+ QObject::connect(m_loop.get(), &MessageEngine::connected,
this, &Voice::onConnected);
- QObject::connect(m_loop, &MessageEngine::disconnected,
+ QObject::connect(m_loop.get(), &MessageEngine::disconnected,
this, &Voice::onDisconnected);
- QObject::connect(m_loop, &MessageEngine::messageReceived,
+ QObject::connect(m_loop.get(), &MessageEngine::messageReceived,
this, &Voice::onMessageReceived);
}
Voice::~Voice()
{
- delete m_loop;
delete m_var;
}
diff --git a/voice/voice.h b/voice/voice.h
index ea0649b..2dc38c3 100644
--- a/voice/voice.h
+++ b/voice/voice.h
@@ -41,7 +41,7 @@ class Voice : public QObject
Q_INVOKABLE void getCBLpair(QString id);
private:
- MessageEngine *m_loop;
+ std::shared_ptr<MessageEngine> m_loop;
VoiceAgentRegistry *m_var;
void subscribeAgentToVshlEvents(QString id);
diff --git a/voice/voiceagentregistry.cpp b/voice/voiceagentregistry.cpp
index 62e8cd6..00eed87 100644
--- a/voice/voiceagentregistry.cpp
+++ b/voice/voiceagentregistry.cpp
@@ -29,12 +29,6 @@ VoiceAgentRegistry::VoiceAgentRegistry(Voice *voice, QQmlContext *context, QObje
vc(voice)
{
m_model = new VoiceAgentModel();
- QSortFilterProxyModel *model = new QSortFilterProxyModel();
- model->setSourceModel(m_model);
- model->setSortRole(VoiceAgentModel::VoiceAgentRoles::IdRole);
- model->setSortCaseSensitivity(Qt::CaseInsensitive);
- model->sort(0);
-
context->setContextProperty("VoiceAgentModel", m_model);
context->setContextProperty("VoiceAgent", this);
}