Members of the KDE Community are recommended to subscribe to the kde-community mailing list at to allow them to participate in important discussions and receive other important announcements

Commit 92afca33 authored by Volker Krause's avatar Volker Krause

Pass through JSON input as-is

This allows unifying data import code in the application for JSON-LD data
passed from another application or device with that of yet to be extracted
parent 0d497547
......@@ -285,6 +285,22 @@ void ExtractorEngine::setData(const QByteArray &data, const QString &fileName)
} else if (fileName.endsWith(QLatin1String(".json"), Qt::CaseInsensitive)
|| fileName.endsWith(QLatin1String(".jsonld"), Qt::CaseInsensitive)
|| contentStartsWith(data, '{') || contentStartsWith(data, '['))
// pass through JSON data, so the using code can apply post-processing to that
QJsonParseError error;
const auto doc = QJsonDocument::fromJson(data, &error);
if (error.error == QJsonParseError::NoError) {
if (doc.isObject()) {
} else if (doc.isArray()) {
d->m_result = doc.array();
} else {
d->m_text = QString::fromUtf8(data); // TODO handle fallback on parse errors due to wrong type guesses a bit more generically here
} else if (fileName.endsWith(QLatin1String(".txt"), Qt::CaseInsensitive)) {
d->m_text = QString::fromUtf8(data);
} else {
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment