From addd5d1f4313268d9da7aa7f40b1014becc61f97 Mon Sep 17 00:00:00 2001 From: David Rosca Date: Sat, 8 Nov 2014 11:15:22 +0100 Subject: [PATCH] OpenSearchEngine: Use Json class instead QScriptEngine to parse suggestions --- src/lib/opensearch/opensearchengine.cpp | 39 ++++++++----------------- src/lib/opensearch/opensearchengine.h | 3 -- 2 files changed, 12 insertions(+), 30 deletions(-) diff --git a/src/lib/opensearch/opensearchengine.cpp b/src/lib/opensearch/opensearchengine.cpp index 2d7e4248a..030e4ac94 100644 --- a/src/lib/opensearch/opensearchengine.cpp +++ b/src/lib/opensearch/opensearchengine.cpp @@ -37,6 +37,7 @@ #include "opensearchengine.h" #include "qzregexp.h" #include "opensearchenginedelegate.h" +#include "json.h" #include #include @@ -44,8 +45,6 @@ #include #include #include -#include -#include #include #if QT_VERSION >= 0x050000 @@ -109,7 +108,6 @@ OpenSearchEngine::OpenSearchEngine(QObject* parent) , m_suggestionsMethod(QLatin1String("get")) , m_networkAccessManager(0) , m_suggestionsReply(0) - , m_scriptEngine(0) , m_delegate(0) { m_requestMethods.insert(QLatin1String("get"), QNetworkAccessManager::GetOperation); @@ -121,9 +119,6 @@ OpenSearchEngine::OpenSearchEngine(QObject* parent) */ OpenSearchEngine::~OpenSearchEngine() { - if (m_scriptEngine) { - m_scriptEngine->deleteLater(); - } } QString OpenSearchEngine::parseTemplate(const QString &searchTerm, const QString &searchTemplate) @@ -655,33 +650,23 @@ void OpenSearchEngine::suggestionsObtained() m_suggestionsReply->deleteLater(); m_suggestionsReply = 0; - if (response.isEmpty()) { + Json json; + const QVariant res = json.parse(response); + + if (!json.ok() || res.type() != QVariant::Map) return; - } - if (!response.startsWith(QLatin1Char('[')) || !response.endsWith(QLatin1Char(']'))) { + const QVariantList list = res.toMap().value(QSL("1")).toList(); + + if (list.isEmpty()) return; - } - if (!m_scriptEngine) { - m_scriptEngine = new QScriptEngine(); - } + QStringList out; - // Evaluate the JSON response using QtScript. - if (!m_scriptEngine->canEvaluate(response)) { - return; - } + foreach (const QVariant &v, list) + out.append(v.toString()); - QScriptValue responseParts = m_scriptEngine->evaluate(response); - - if (!responseParts.property(1).isArray()) { - return; - } - - QStringList suggestionsList; - qScriptValueToSequence(responseParts.property(1), suggestionsList); - - emit suggestions(suggestionsList); + emit suggestions(out); } /*! diff --git a/src/lib/opensearch/opensearchengine.h b/src/lib/opensearch/opensearchengine.h index d210c720e..6fa1dc5ad 100644 --- a/src/lib/opensearch/opensearchengine.h +++ b/src/lib/opensearch/opensearchengine.h @@ -47,7 +47,6 @@ #include class QNetworkReply; -class QScriptEngine; class OpenSearchEngineDelegate; class QUPZILLA_EXPORT OpenSearchEngine : public QObject @@ -164,8 +163,6 @@ private: QNetworkAccessManager* m_networkAccessManager; QNetworkReply* m_suggestionsReply; - QScriptEngine* m_scriptEngine; - OpenSearchEngineDelegate* m_delegate; };