aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/git/githighlighters.cpp
diff options
context:
space:
mode:
authorChristian Stenger <christian.stenger@qt.io>2020-07-13 12:45:12 +0200
committerChristian Stenger <christian.stenger@qt.io>2020-07-14 09:09:42 +0000
commit228f6d04af04f45a12b97880648f32082d8f5fc0 (patch)
tree288b7c1025158a1606a05534a8bb0c1abb58f456 /src/plugins/git/githighlighters.cpp
parentb9d6a041216ef4dff5d354a326684bb166c67357 (diff)
Git: Replace QRegExp by QRegularExpression
Task-number: QTCREATORBUG-24098 Change-Id: I77a2e9959981b2e173142253baf1668d57982a2e Reviewed-by: Orgad Shaneh <orgads@gmail.com>
Diffstat (limited to 'src/plugins/git/githighlighters.cpp')
-rw-r--r--src/plugins/git/githighlighters.cpp30
1 files changed, 16 insertions, 14 deletions
diff --git a/src/plugins/git/githighlighters.cpp b/src/plugins/git/githighlighters.cpp
index 763a3b9f79..4f88183391 100644
--- a/src/plugins/git/githighlighters.cpp
+++ b/src/plugins/git/githighlighters.cpp
@@ -35,10 +35,10 @@ namespace Internal {
static const char CHANGE_PATTERN[] = "\\b[a-f0-9]{7,40}\\b";
GitSubmitHighlighter::GitSubmitHighlighter(QTextEdit * parent) :
- TextEditor::SyntaxHighlighter(parent)
+ TextEditor::SyntaxHighlighter(parent),
+ m_keywordPattern("^[\\w-]+:")
{
setDefaultTextFormatCategories();
- m_keywordPattern.setPattern("^[\\w-]+:");
m_hashChar = '#';
QTC_CHECK(m_keywordPattern.isValid());
}
@@ -73,10 +73,11 @@ void GitSubmitHighlighter::highlightBlock(const QString &text)
}
case Other:
// Format key words ("Task:") italic
- if (m_keywordPattern.indexIn(text, 0, QRegExp::CaretAtZero) == 0) {
+ const QRegularExpressionMatch match = m_keywordPattern.match(text);
+ if (match.hasMatch() && match.capturedStart(0) == 0) {
QTextCharFormat charFormat = format(0);
charFormat.setFontItalic(true);
- setFormat(0, m_keywordPattern.matchedLength(), charFormat);
+ setFormat(0, match.capturedLength(), charFormat);
}
break;
}
@@ -130,20 +131,21 @@ void GitRebaseHighlighter::highlightBlock(const QString &text)
{
if (text.startsWith(m_hashChar)) {
setFormat(0, text.size(), formatForCategory(Format_Comment));
- int changeIndex = 0;
- while ((changeIndex = m_changeNumberPattern.indexIn(text, changeIndex)) != -1) {
- const int changeLen = m_changeNumberPattern.matchedLength();
- setFormat(changeIndex, changeLen, formatForCategory(Format_Change));
- changeIndex += changeLen;
+ QRegularExpressionMatchIterator it = m_changeNumberPattern.globalMatch(text);
+ while (it.hasNext()) {
+ const QRegularExpressionMatch match = it.next();
+ setFormat(match.capturedStart(), match.capturedLength(), formatForCategory(Format_Change));
}
} else {
for (const RebaseAction &action : qAsConst(m_actions)) {
- if (action.exp.indexIn(text) != -1) {
- const int len = action.exp.matchedLength();
+ const QRegularExpressionMatch match = action.exp.match(text);
+ if (match.hasMatch()) {
+ const int len = match.capturedLength();
setFormat(0, len, formatForCategory(action.formatCategory));
- const int changeIndex = m_changeNumberPattern.indexIn(text, len);
- if (changeIndex != -1) {
- const int changeLen = m_changeNumberPattern.matchedLength();
+ const QRegularExpressionMatch changeMatch = m_changeNumberPattern.match(text, len);
+ const int changeIndex = changeMatch.capturedStart();
+ if (changeMatch.hasMatch()) {
+ const int changeLen = changeMatch.capturedLength();
const int descStart = changeIndex + changeLen + 1;
setFormat(changeIndex, changeLen, formatForCategory(Format_Change));
setFormat(descStart, text.size() - descStart, formatForCategory(Format_Description));