forked from qt-creator/qt-creator
Utils: Replace QRegExp by QRegularExpression
Task-number: QTCREATORBUG-24098 Change-Id: I0e29d2a43de6ff29dfeb5c9c70ac18ed95ba2657 Reviewed-by: hjk <hjk@qt.io>
This commit is contained in:
@@ -26,7 +26,7 @@
|
|||||||
#include "filenamevalidatinglineedit.h"
|
#include "filenamevalidatinglineedit.h"
|
||||||
#include "qtcassert.h"
|
#include "qtcassert.h"
|
||||||
|
|
||||||
#include <QRegExp>
|
#include <QRegularExpression>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@@ -46,16 +46,18 @@ namespace Utils {
|
|||||||
// Naming a file like a device name will break on Windows, even if it is
|
// Naming a file like a device name will break on Windows, even if it is
|
||||||
// "com1.txt". Since we are cross-platform, we generally disallow such file
|
// "com1.txt". Since we are cross-platform, we generally disallow such file
|
||||||
// names.
|
// names.
|
||||||
static const QRegExp &windowsDeviceNoSubDirPattern()
|
static const QRegularExpression &windowsDeviceNoSubDirPattern()
|
||||||
{
|
{
|
||||||
static const QRegExp rc(QLatin1String(WINDOWS_DEVICES_PATTERN), Qt::CaseInsensitive);
|
static const QRegularExpression rc(QString("^" WINDOWS_DEVICES_PATTERN "$"),
|
||||||
|
QRegularExpression::CaseInsensitiveOption);
|
||||||
QTC_ASSERT(rc.isValid(), return rc);
|
QTC_ASSERT(rc.isValid(), return rc);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const QRegExp &windowsDeviceSubDirPattern()
|
static const QRegularExpression &windowsDeviceSubDirPattern()
|
||||||
{
|
{
|
||||||
static const QRegExp rc(QLatin1String(".*[/\\\\]" WINDOWS_DEVICES_PATTERN), Qt::CaseInsensitive);
|
static const QRegularExpression rc(QString("^.*[/\\\\]" WINDOWS_DEVICES_PATTERN "$"),
|
||||||
|
QRegularExpression::CaseInsensitiveOption);
|
||||||
QTC_ASSERT(rc.isValid(), return rc);
|
QTC_ASSERT(rc.isValid(), return rc);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
@@ -135,9 +137,9 @@ bool FileNameValidatingLineEdit::validateFileName(const QString &name,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Windows devices
|
// Windows devices
|
||||||
bool matchesWinDevice = windowsDeviceNoSubDirPattern().exactMatch(name);
|
bool matchesWinDevice = name.contains(windowsDeviceNoSubDirPattern());
|
||||||
if (!matchesWinDevice && allowDirectories)
|
if (!matchesWinDevice && allowDirectories)
|
||||||
matchesWinDevice = windowsDeviceSubDirPattern().exactMatch(name);
|
matchesWinDevice = name.contains(windowsDeviceSubDirPattern());
|
||||||
if (matchesWinDevice) {
|
if (matchesWinDevice) {
|
||||||
if (errorMessage)
|
if (errorMessage)
|
||||||
*errorMessage = tr("Name matches MS Windows device"
|
*errorMessage = tr("Name matches MS Windows device"
|
||||||
|
|||||||
@@ -30,7 +30,6 @@
|
|||||||
|
|
||||||
#include <QCoreApplication>
|
#include <QCoreApplication>
|
||||||
#include <QMutex>
|
#include <QMutex>
|
||||||
#include <QRegExp>
|
|
||||||
#include <QRegularExpression>
|
#include <QRegularExpression>
|
||||||
#include <QTextCodec>
|
#include <QTextCodec>
|
||||||
|
|
||||||
@@ -475,22 +474,24 @@ QString matchCaseReplacement(const QString &originalText, const QString &replace
|
|||||||
}
|
}
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
static QList<QRegExp> filtersToRegExps(const QStringList &filters)
|
static QList<QRegularExpression> filtersToRegExps(const QStringList &filters)
|
||||||
{
|
{
|
||||||
return Utils::transform(filters, [](const QString &filter) {
|
return Utils::transform(filters, [](const QString &filter) {
|
||||||
return QRegExp(filter, Qt::CaseInsensitive, QRegExp::Wildcard);
|
return QRegularExpression(QRegularExpression::wildcardToRegularExpression(filter),
|
||||||
|
QRegularExpression::CaseInsensitiveOption);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool matches(const QList<QRegExp> &exprList, const QString &filePath)
|
static bool matches(const QList<QRegularExpression> &exprList, const QString &filePath)
|
||||||
{
|
{
|
||||||
return Utils::anyOf(exprList, [&filePath](QRegExp reg) {
|
return Utils::anyOf(exprList, [&filePath](const QRegularExpression ®) {
|
||||||
return (reg.exactMatch(filePath)
|
return (reg.match(filePath).hasMatch()
|
||||||
|| reg.exactMatch(FilePath::fromString(filePath).fileName()));
|
|| reg.match(FilePath::fromString(filePath).fileName()).hasMatch());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool isFileIncluded(const QList<QRegExp> &filterRegs, const QList<QRegExp> &exclusionRegs,
|
static bool isFileIncluded(const QList<QRegularExpression> &filterRegs,
|
||||||
|
const QList<QRegularExpression> &exclusionRegs,
|
||||||
const QString &filePath)
|
const QString &filePath)
|
||||||
{
|
{
|
||||||
const bool isIncluded = filterRegs.isEmpty() || matches(filterRegs, filePath);
|
const bool isIncluded = filterRegs.isEmpty() || matches(filterRegs, filePath);
|
||||||
@@ -500,8 +501,8 @@ static bool isFileIncluded(const QList<QRegExp> &filterRegs, const QList<QRegExp
|
|||||||
std::function<bool(const QString &)>
|
std::function<bool(const QString &)>
|
||||||
filterFileFunction(const QStringList &filters, const QStringList &exclusionFilters)
|
filterFileFunction(const QStringList &filters, const QStringList &exclusionFilters)
|
||||||
{
|
{
|
||||||
const QList<QRegExp> filterRegs = filtersToRegExps(filters);
|
const QList<QRegularExpression> filterRegs = filtersToRegExps(filters);
|
||||||
const QList<QRegExp> exclusionRegs = filtersToRegExps(exclusionFilters);
|
const QList<QRegularExpression> exclusionRegs = filtersToRegExps(exclusionFilters);
|
||||||
return [filterRegs, exclusionRegs](const QString &filePath) {
|
return [filterRegs, exclusionRegs](const QString &filePath) {
|
||||||
return isFileIncluded(filterRegs, exclusionRegs, filePath);
|
return isFileIncluded(filterRegs, exclusionRegs, filePath);
|
||||||
};
|
};
|
||||||
@@ -510,8 +511,8 @@ filterFileFunction(const QStringList &filters, const QStringList &exclusionFilte
|
|||||||
std::function<QStringList(const QStringList &)>
|
std::function<QStringList(const QStringList &)>
|
||||||
filterFilesFunction(const QStringList &filters, const QStringList &exclusionFilters)
|
filterFilesFunction(const QStringList &filters, const QStringList &exclusionFilters)
|
||||||
{
|
{
|
||||||
const QList<QRegExp> filterRegs = filtersToRegExps(filters);
|
const QList<QRegularExpression> filterRegs = filtersToRegExps(filters);
|
||||||
const QList<QRegExp> exclusionRegs = filtersToRegExps(exclusionFilters);
|
const QList<QRegularExpression> exclusionRegs = filtersToRegExps(exclusionFilters);
|
||||||
return [filterRegs, exclusionRegs](const QStringList &filePaths) {
|
return [filterRegs, exclusionRegs](const QStringList &filePaths) {
|
||||||
return Utils::filtered(filePaths, [&filterRegs, &exclusionRegs](const QString &filePath) {
|
return Utils::filtered(filePaths, [&filterRegs, &exclusionRegs](const QString &filePath) {
|
||||||
return isFileIncluded(filterRegs, exclusionRegs, filePath);
|
return isFileIncluded(filterRegs, exclusionRegs, filePath);
|
||||||
|
|||||||
@@ -39,7 +39,7 @@
|
|||||||
|
|
||||||
#include "mimeglobpattern_p.h"
|
#include "mimeglobpattern_p.h"
|
||||||
|
|
||||||
#include <QRegExp>
|
#include <QRegularExpression>
|
||||||
#include <QStringList>
|
#include <QStringList>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
|
||||||
@@ -138,8 +138,9 @@ bool MimeGlobPattern::matchFileName(const QString &inputFilename) const
|
|||||||
return (m_pattern == filename);
|
return (m_pattern == filename);
|
||||||
|
|
||||||
// Other (quite rare) patterns, like "*.anim[1-9j]": use slow but correct method
|
// Other (quite rare) patterns, like "*.anim[1-9j]": use slow but correct method
|
||||||
QRegExp rx(m_pattern, Qt::CaseSensitive, QRegExp::WildcardUnix);
|
const QRegularExpression rx(QRegularExpression::anchoredPattern(
|
||||||
return rx.exactMatch(filename);
|
QRegularExpression::wildcardToRegularExpression(m_pattern)));
|
||||||
|
return rx.match(filename).hasMatch();
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool isFastPattern(const QString &pattern)
|
static bool isFastPattern(const QString &pattern)
|
||||||
|
|||||||
Reference in New Issue
Block a user