Files
qt-creator/src/plugins/bazaar/bazaareditor.cpp
Kai Köhne 56baf8c058 Remove GPL-3.0+ from license identifiers
Since we also license under GPL-3.0 WITH Qt-GPL-exception-1.0,
this applies only to a hypothetical newer version of GPL, that doesn't
exist yet. If such a version emerges, we can still decide to relicense...

While at it, replace (deprecated) GPL-3.0 with more explicit GPL-3.0-only

Change was done by running

  find . -type f -exec perl -pi -e "s/LicenseRef-Qt-Commercial OR GPL-3.0\+ OR GPL-3.0 WITH Qt-GPL-exception-1.0/LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0/g" {} \;

Change-Id: I5097e6ce8d10233993ee30d7e25120e2659eb10b
Reviewed-by: Eike Ziller <eike.ziller@qt.io>
2023-01-06 11:15:13 +00:00

68 lines
2.4 KiB
C++

// Copyright (C) 2016 Hugues Delorme
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#include "bazaareditor.h"
#include "annotationhighlighter.h"
#include "bazaartr.h"
#include "constants.h"
#include <utils/qtcassert.h>
#include <QString>
#include <QTextCursor>
#define BZR_CHANGE_PATTERN "[0-9]+"
namespace Bazaar::Internal {
BazaarEditorWidget::BazaarEditorWidget() :
m_changesetId(QLatin1String(Constants::CHANGESET_ID)),
m_exactChangesetId(QLatin1String(Constants::CHANGESET_ID_EXACT))
{
setAnnotateRevisionTextFormat(Tr::tr("&Annotate %1"));
setAnnotatePreviousRevisionTextFormat(Tr::tr("Annotate &parent revision %1"));
// Diff format:
// === <change> <file|dir> 'mainwindow.cpp'
setDiffFilePattern("^=== [a-z]+ [a-z]+ '(.+)'\\s*");
setLogEntryPattern("^revno: (\\d+)");
setAnnotationEntryPattern("^(" BZR_CHANGE_PATTERN ") ");
}
QString BazaarEditorWidget::changeUnderCursor(const QTextCursor &cursorIn) const
{
// The test is done in two steps: first we check if the line contains a
// changesetId. Then we check if the cursor is over the changesetId itself
// and not over "revno" or another part of the line.
// The two steps are necessary because matching only for the changesetId
// leads to many false-positives (a regex like "[0-9]+" matches a lot of text).
const int cursorCol = cursorIn.columnNumber();
QTextCursor cursor = cursorIn;
cursor.select(QTextCursor::LineUnderCursor);
if (cursor.hasSelection()) {
const QString line = cursor.selectedText();
const QRegularExpressionMatch match = m_changesetId.match(line);
if (match.hasMatch()) {
const int start = match.capturedStart();
const int stop = match.capturedEnd();
if (start <= cursorCol && cursorCol <= stop) {
cursor = cursorIn;
cursor.select(QTextCursor::WordUnderCursor);
if (cursor.hasSelection()) {
const QString change = cursor.selectedText();
if (m_exactChangesetId.match(change).hasMatch())
return change;
}
}
}
}
return QString();
}
VcsBase::BaseAnnotationHighlighter *BazaarEditorWidget::createAnnotationHighlighter(const QSet<QString> &changes) const
{
return new BazaarAnnotationHighlighter(changes);
}
} // Bazaar::Internal