forked from qt-creator/qt-creator
VCS: Replace QRegExp by QRegularExpression
Task-number: QTCREATORBUG-24098 Change-Id: I7c3d8c72ab71b3aa12f0273c45dac9a843024218 Reviewed-by: Orgad Shaneh <orgads@gmail.com>
This commit is contained in:
@@ -27,7 +27,7 @@
|
||||
|
||||
#include <utils/stringutils.h>
|
||||
|
||||
#include <QRegExp>
|
||||
#include <QRegularExpression>
|
||||
#include <QStringList>
|
||||
|
||||
namespace Cvs {
|
||||
@@ -66,15 +66,16 @@ QList<CvsLogEntry> parseLogEntries(const QString &o,
|
||||
ParseState state = FileState;
|
||||
|
||||
const QString workingFilePrefix = QLatin1String("Working file: ");
|
||||
QRegExp statusPattern = QRegExp(QLatin1String("^date: ([\\d\\-]+) .*commitid: ([^;]+);$"));
|
||||
QRegExp revisionPattern = QRegExp(QLatin1String("^revision ([\\d\\.]+)$"));
|
||||
const QRegularExpression statusPattern(QLatin1String("^date: ([\\d\\-]+) .*commitid: ([^;]+);$"));
|
||||
const QRegularExpression revisionPattern(QLatin1String("^revision ([\\d\\.]+)$"));
|
||||
const QChar slash = QLatin1Char('/');
|
||||
Q_ASSERT(statusPattern.isValid() && revisionPattern.isValid());
|
||||
const QString fileSeparator = QLatin1String("=============================================================================");
|
||||
|
||||
// Parse using a state enumeration and regular expressions as not to fall for weird
|
||||
// commit messages in state 'RevisionState'
|
||||
foreach (const QString &line, lines) {
|
||||
QRegularExpressionMatch match;
|
||||
for (const QString &line : lines) {
|
||||
switch (state) {
|
||||
case FileState:
|
||||
if (line.startsWith(workingFilePrefix)) {
|
||||
@@ -87,8 +88,9 @@ QList<CvsLogEntry> parseLogEntries(const QString &o,
|
||||
}
|
||||
break;
|
||||
case RevisionState:
|
||||
if (revisionPattern.exactMatch(line)) {
|
||||
rc.back().revisions.push_back(CvsRevision(revisionPattern.cap(1)));
|
||||
match = revisionPattern.match(line);
|
||||
if (match.hasMatch()) {
|
||||
rc.back().revisions.push_back(CvsRevision(match.captured(1)));
|
||||
state = StatusLineState;
|
||||
} else {
|
||||
if (line == fileSeparator)
|
||||
@@ -96,10 +98,11 @@ QList<CvsLogEntry> parseLogEntries(const QString &o,
|
||||
}
|
||||
break;
|
||||
case StatusLineState:
|
||||
if (statusPattern.exactMatch(line)) {
|
||||
const QString commitId = statusPattern.cap(2);
|
||||
match = statusPattern.match(line);
|
||||
if (match.hasMatch()) {
|
||||
const QString commitId = match.captured(2);
|
||||
if (filterCommitId.isEmpty() || filterCommitId == commitId) {
|
||||
rc.back().revisions.back().date = statusPattern.cap(1);
|
||||
rc.back().revisions.back().date = match.captured(1);
|
||||
rc.back().revisions.back().commitId = commitId;
|
||||
} else {
|
||||
rc.back().revisions.pop_back();
|
||||
|
||||
Reference in New Issue
Block a user