2022-08-19 15:59:36 +02:00
|
|
|
// Copyright (C) 2019 The Qt Company Ltd.
|
|
|
|
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0+ OR GPL-3.0 WITH Qt-GPL-exception-1.0
|
2019-07-11 17:48:09 +02:00
|
|
|
|
|
|
|
|
#include "lldparser.h"
|
|
|
|
|
|
|
|
|
|
#include "projectexplorerconstants.h"
|
|
|
|
|
#include "task.h"
|
|
|
|
|
|
|
|
|
|
#include <utils/fileutils.h>
|
|
|
|
|
|
|
|
|
|
#include <QStringList>
|
|
|
|
|
|
|
|
|
|
namespace ProjectExplorer {
|
|
|
|
|
namespace Internal {
|
|
|
|
|
|
2020-04-16 13:53:05 +02:00
|
|
|
Utils::OutputLineParser::Result LldParser::handleLine(const QString &line, Utils::OutputFormat type)
|
2019-07-11 17:48:09 +02:00
|
|
|
{
|
2020-04-08 17:45:39 +02:00
|
|
|
if (type != Utils::StdErrFormat)
|
|
|
|
|
return Status::NotHandled;
|
|
|
|
|
|
2019-07-11 17:48:09 +02:00
|
|
|
const QString trimmedLine = rightTrimmed(line);
|
|
|
|
|
if (trimmedLine.contains("error:") && trimmedLine.contains("lld")) {
|
2020-04-16 13:53:05 +02:00
|
|
|
scheduleTask(CompileTask(Task::Error, trimmedLine), 1);
|
2020-04-08 17:45:39 +02:00
|
|
|
return Status::Done;
|
2019-07-11 17:48:09 +02:00
|
|
|
}
|
|
|
|
|
static const QStringList prefixes{">>> referenced by ", ">>> defined at ", ">>> "};
|
|
|
|
|
for (const QString &prefix : prefixes) {
|
|
|
|
|
if (!trimmedLine.startsWith(prefix))
|
|
|
|
|
continue;
|
|
|
|
|
int lineNo = -1;
|
|
|
|
|
const int locOffset = trimmedLine.lastIndexOf(':');
|
|
|
|
|
if (locOffset != -1) {
|
|
|
|
|
const int endLocOffset = trimmedLine.indexOf(')', locOffset);
|
|
|
|
|
const int numberWidth = endLocOffset == -1 ? -1 : endLocOffset - locOffset - 1;
|
|
|
|
|
bool isNumber = true;
|
|
|
|
|
lineNo = trimmedLine.mid(locOffset + 1, numberWidth).toInt(&isNumber);
|
|
|
|
|
if (!isNumber)
|
|
|
|
|
lineNo = -1;
|
|
|
|
|
}
|
|
|
|
|
int filePathOffset = trimmedLine.lastIndexOf('(', locOffset);
|
|
|
|
|
if (filePathOffset != -1)
|
|
|
|
|
++filePathOffset;
|
|
|
|
|
else
|
|
|
|
|
filePathOffset = prefix.length();
|
|
|
|
|
const int filePathLen = locOffset == -1 ? -1 : locOffset - filePathOffset;
|
2020-04-16 13:53:05 +02:00
|
|
|
const auto file = absoluteFilePath(Utils::FilePath::fromUserInput(
|
|
|
|
|
trimmedLine.mid(filePathOffset, filePathLen).trimmed()));
|
|
|
|
|
LinkSpecs linkSpecs;
|
|
|
|
|
addLinkSpecForAbsoluteFilePath(linkSpecs, file, lineNo, filePathOffset, filePathLen);
|
|
|
|
|
scheduleTask(CompileTask(Task::Unknown, trimmedLine.mid(4).trimmed(),
|
|
|
|
|
file, lineNo), 1);
|
|
|
|
|
return {Status::Done, linkSpecs};
|
2019-07-11 17:48:09 +02:00
|
|
|
}
|
2020-04-08 17:45:39 +02:00
|
|
|
return Status::NotHandled;
|
2019-07-11 17:48:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace Internal
|
|
|
|
|
} // namespace ProjectExplorer
|