diff options
author | Lars Knoll <lars.knoll@qt.io> | 2020-05-22 16:46:29 +0200 |
---|---|---|
committer | Lars Knoll <lars.knoll@qt.io> | 2020-06-01 00:39:24 +0200 |
commit | b0294bb1c74ae3f5aabb873435788200da988908 (patch) | |
tree | f5c01fe855a4c75fee53ddab82217d01d0cf76c8 /src | |
parent | 529f052add3edbc1afb063a5cbbb118b67434fb6 (diff) |
Refactor splitString to use QStringView
Instead of a QChar * and a length.
Change-Id: Ic07e92fe0889e57c19ce7c1bf6902f3a598fad05
Reviewed-by: Volker Hilsheimer <volker.hilsheimer@qt.io>
Diffstat (limited to 'src')
-rw-r--r-- | src/corelib/text/qstring.cpp | 23 |
1 files changed, 11 insertions, 12 deletions
diff --git a/src/corelib/text/qstring.cpp b/src/corelib/text/qstring.cpp index cda1c380bd..01b4337c2a 100644 --- a/src/corelib/text/qstring.cpp +++ b/src/corelib/text/qstring.cpp @@ -7183,18 +7183,18 @@ QString QString::number(double n, char f, int prec) namespace { template<class ResultList, class StringSource> -static ResultList splitString(const StringSource &source, const QChar *sep, - Qt::SplitBehavior behavior, Qt::CaseSensitivity cs, const int separatorSize) +static ResultList splitString(const StringSource &source, QStringView sep, + Qt::SplitBehavior behavior, Qt::CaseSensitivity cs) { ResultList list; typename StringSource::size_type start = 0; typename StringSource::size_type end; typename StringSource::size_type extra = 0; - while ((end = QtPrivate::findString(QStringView(source.constData(), source.size()), start + extra, QStringView(sep, separatorSize), cs)) != -1) { + while ((end = QtPrivate::findString(QStringView(source.constData(), source.size()), start + extra, sep, cs)) != -1) { if (start != end || behavior == Qt::KeepEmptyParts) list.append(source.mid(start, end - start)); - start = end + separatorSize; - extra = (separatorSize == 0 ? 1 : 0); + start = end + sep.size(); + extra = (sep.size() == 0 ? 1 : 0); } if (start != source.size() || behavior == Qt::KeepEmptyParts) list.append(source.mid(start, -1)); @@ -7245,7 +7245,7 @@ QT_WARNING_POP */ QStringList QString::split(const QString &sep, Qt::SplitBehavior behavior, Qt::CaseSensitivity cs) const { - return splitString<QStringList>(*this, sep.constData(), behavior, cs, sep.size()); + return splitString<QStringList>(*this, sep, behavior, cs); } #if QT_DEPRECATED_SINCE(5, 15) @@ -7275,8 +7275,7 @@ QStringList QString::split(const QString &sep, SplitBehavior behavior, Qt::CaseS QVector<QStringRef> QString::splitRef(const QString &sep, Qt::SplitBehavior behavior, Qt::CaseSensitivity cs) const { - return splitString<QVector<QStringRef>>(QStringRef(this), sep.constData(), behavior, - cs, sep.size()); + return splitString<QVector<QStringRef>>(QStringRef(this), sep, behavior, cs); } #if QT_DEPRECATED_SINCE(5, 15) @@ -7297,7 +7296,7 @@ QVector<QStringRef> QString::splitRef(const QString &sep, SplitBehavior behavior */ QStringList QString::split(QChar sep, Qt::SplitBehavior behavior, Qt::CaseSensitivity cs) const { - return splitString<QStringList>(*this, &sep, behavior, cs, 1); + return splitString<QStringList>(*this, QStringView(&sep, 1), behavior, cs); } #if QT_DEPRECATED_SINCE(5, 15) @@ -7318,7 +7317,7 @@ QStringList QString::split(QChar sep, SplitBehavior behavior, Qt::CaseSensitivit QVector<QStringRef> QString::splitRef(QChar sep, Qt::SplitBehavior behavior, Qt::CaseSensitivity cs) const { - return splitString<QVector<QStringRef> >(QStringRef(this), &sep, behavior, cs, 1); + return splitString<QVector<QStringRef> >(QStringRef(this), QStringView(&sep, 1), behavior, cs); } #if QT_DEPRECATED_SINCE(5, 15) @@ -7346,7 +7345,7 @@ QVector<QStringRef> QString::splitRef(QChar sep, SplitBehavior behavior, Qt::Cas */ QVector<QStringRef> QStringRef::split(const QString &sep, Qt::SplitBehavior behavior, Qt::CaseSensitivity cs) const { - return splitString<QVector<QStringRef> >(*this, sep.constData(), behavior, cs, sep.size()); + return splitString<QVector<QStringRef> >(*this, sep, behavior, cs); } #if QT_DEPRECATED_SINCE(5, 15) @@ -7367,7 +7366,7 @@ QVector<QStringRef> QStringRef::split(const QString &sep, QString::SplitBehavior */ QVector<QStringRef> QStringRef::split(QChar sep, Qt::SplitBehavior behavior, Qt::CaseSensitivity cs) const { - return splitString<QVector<QStringRef> >(*this, &sep, behavior, cs, 1); + return splitString<QVector<QStringRef> >(*this, QStringView(&sep, 1), behavior, cs); } #if QT_DEPRECATED_SINCE(5, 15) |