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 fdcf9b3d authored by Mark Nauwelaerts's avatar Mark Nauwelaerts

lspclient: normalize file URL while parsing

parent 20dfb9c7
......@@ -30,6 +30,7 @@
#include <QJsonArray>
#include <QCoreApplication>
#include <QTime>
#include <QFileInfo>
static const QString MEMBER_ID = QStringLiteral("id");
static const QString MEMBER_METHOD = QStringLiteral("method");
......@@ -546,6 +547,25 @@ public:
// follow suit; as performed in kate docmanager
// normalize at this stage/layer to avoid surprises elsewhere
// sadly this is not a single QUrl method as one might hope ...
static QUrl
normalizeUrl(const QUrl & url)
QUrl u(url.adjusted(QUrl::NormalizePathSegments));
// Resolve symbolic links for local files (done anyway in KTextEditor)
if (u.isLocalFile()) {
QString normalizedUrl = QFileInfo(u.toLocalFile()).canonicalFilePath();
if (!normalizedUrl.isEmpty()) {
u = QUrl::fromLocalFile(normalizedUrl);
return u;
static LSPMarkupContent
parseMarkupContent(const QJsonValue & v)
......@@ -589,7 +609,7 @@ parseRange(const QJsonObject & range)
static LSPLocation
parseLocation(const QJsonObject & loc)
auto uri = loc.value(MEMBER_URI).toString();
auto uri = normalizeUrl(QUrl(loc.value(MEMBER_URI).toString()));
auto range = parseRange(loc.value(MEMBER_RANGE).toObject());
return {QUrl(uri), range};
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