summaryrefslogtreecommitdiff
path: root/src/plugins/projectexplorer/compileoutputwindow.cpp
diff options
context:
space:
mode:
authorChristian Kandeler <christian.kandeler@qt.io>2021-11-25 12:31:14 +0100
committerChristian Kandeler <christian.kandeler@qt.io>2021-11-25 15:19:42 +0000
commit08a86169db490b23fc9512388c3311a79f12de56 (patch)
tree38c345d9643d94862c4fa383e0c3bd650fd048c3 /src/plugins/projectexplorer/compileoutputwindow.cpp
parent857ca05ac37d43bd5895b8a25a014e93c7570d4a (diff)
downloadqt-creator-08a86169db490b23fc9512388c3311a79f12de56.tar.gz
ProjectExplorer: Generalize issues -> output pane linking
This feature was specific to the compile output pane, but we want to have it in other panes too. Change-Id: I110b27af7d0aa23acbc5623d1c0405816250df19 Reviewed-by: hjk <hjk@qt.io>
Diffstat (limited to 'src/plugins/projectexplorer/compileoutputwindow.cpp')
-rw-r--r--src/plugins/projectexplorer/compileoutputwindow.cpp44
1 files changed, 1 insertions, 43 deletions
diff --git a/src/plugins/projectexplorer/compileoutputwindow.cpp b/src/plugins/projectexplorer/compileoutputwindow.cpp
index 609321f425..839a1d2546 100644
--- a/src/plugins/projectexplorer/compileoutputwindow.cpp
+++ b/src/plugins/projectexplorer/compileoutputwindow.cpp
@@ -81,17 +81,6 @@ CompileOutputWindow::CompileOutputWindow(QAction *cancelBuildAction) :
m_outputWindow->setUndoRedoEnabled(false);
m_outputWindow->setMaxCharCount(Core::Constants::DEFAULT_MAX_CHAR_COUNT);
- outputFormatter()->overridePostPrintAction([this](Utils::OutputLineParser *parser) {
- if (const auto taskParser = qobject_cast<OutputTaskParser *>(parser)) {
- int offset = 0;
- Utils::reverseForeach(taskParser->taskInfo(), [this, &offset](const OutputTaskParser::TaskInfo &ti) {
- registerPositionOf(ti.task, ti.linkedLines, ti.skippedLines, offset);
- offset += ti.linkedLines;
- });
- }
- parser->runPostPrintActions();
- });
-
Utils::ProxyAction *cancelBuildProxyButton =
Utils::ProxyAction::proxyActionWithIcon(cancelBuildAction,
Utils::Icons::STOP_SMALL_TOOLBAR.icon());
@@ -198,7 +187,6 @@ void CompileOutputWindow::appendText(const QString &text, BuildStep::OutputForma
void CompileOutputWindow::clearContents()
{
m_outputWindow->clear();
- m_taskPositions.clear();
}
int CompileOutputWindow::priorityInStatusBar() const
@@ -230,37 +218,7 @@ bool CompileOutputWindow::canNavigate() const
void CompileOutputWindow::registerPositionOf(const Task &task, int linkedOutputLines, int skipLines,
int offset)
{
- if (linkedOutputLines <= 0)
- return;
-
- const int blocknumber = m_outputWindow->document()->blockCount() - offset;
- const int firstLine = blocknumber - linkedOutputLines - skipLines;
- const int lastLine = firstLine + linkedOutputLines - 1;
-
- m_taskPositions.insert(task.taskId, qMakePair(firstLine, lastLine));
-}
-
-bool CompileOutputWindow::knowsPositionOf(const Task &task)
-{
- return (m_taskPositions.contains(task.taskId));
-}
-
-void CompileOutputWindow::showPositionOf(const Task &task)
-{
- QPair<int, int> position = m_taskPositions.value(task.taskId);
- QTextCursor newCursor(m_outputWindow->document()->findBlockByNumber(position.second));
-
- // Move cursor to end of last line of interest:
- newCursor.movePosition(QTextCursor::EndOfBlock, QTextCursor::MoveAnchor);
- m_outputWindow->setTextCursor(newCursor);
-
- // Move cursor and select lines:
- newCursor.setPosition(m_outputWindow->document()->findBlockByNumber(position.first).position(),
- QTextCursor::KeepAnchor);
- m_outputWindow->setTextCursor(newCursor);
-
- // Center cursor now:
- m_outputWindow->centerCursor();
+ m_outputWindow->registerPositionOf(task.taskId, linkedOutputLines, skipLines, offset);
}
void CompileOutputWindow::flush()