Move a few QStringList methods up to QList<QString>
This should be completely source-compatible, aside from the indirect header order change. Change-Id: I4cf8800ea1bfeb3023c7319991ab8ae281c925e8 Reviewed-by: Olivier Goffart <ogoffart@woboq.com>
This commit is contained in:
parent
2d89aee982
commit
90e7cc172a
@ -475,6 +475,12 @@ void **QListData::erase(void **xi)
|
|||||||
If T is a QByteArray, this class has a couple more members that can be
|
If T is a QByteArray, this class has a couple more members that can be
|
||||||
used. See the documentation for QByteArrayList for more information.
|
used. See the documentation for QByteArrayList for more information.
|
||||||
|
|
||||||
|
If T is QString, this class has the following additional members:
|
||||||
|
\l{QStringList::filter()}{filter},
|
||||||
|
\l{QStringList::join()}{join},
|
||||||
|
\l{QStringList::removeDuplicates()}{removeDuplicates},
|
||||||
|
\l{QStringList::sort()}{sort}.
|
||||||
|
|
||||||
\sa QListIterator, QMutableListIterator, QLinkedList, QVector
|
\sa QListIterator, QMutableListIterator, QLinkedList, QVector
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -948,6 +948,7 @@ Q_DECLARE_MUTABLE_SEQUENTIAL_ITERATOR(List)
|
|||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
|
|
||||||
#include <QtCore/qbytearraylist.h>
|
#include <QtCore/qbytearraylist.h>
|
||||||
|
#include <QtCore/qstringlist.h>
|
||||||
|
|
||||||
#ifdef Q_CC_MSVC
|
#ifdef Q_CC_MSVC
|
||||||
#pragma warning( pop )
|
#pragma warning( pop )
|
||||||
|
@ -31,27 +31,64 @@
|
|||||||
**
|
**
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <QtCore/qlist.h>
|
||||||
|
|
||||||
#ifndef QSTRINGLIST_H
|
#ifndef QSTRINGLIST_H
|
||||||
#define QSTRINGLIST_H
|
#define QSTRINGLIST_H
|
||||||
|
|
||||||
#include <QtCore/qalgorithms.h>
|
#include <QtCore/qalgorithms.h>
|
||||||
#include <QtCore/qdatastream.h>
|
|
||||||
#include <QtCore/qlist.h>
|
|
||||||
#include <QtCore/qregexp.h>
|
#include <QtCore/qregexp.h>
|
||||||
#include <QtCore/qstring.h>
|
#include <QtCore/qstring.h>
|
||||||
#include <QtCore/qstringmatcher.h>
|
#include <QtCore/qstringmatcher.h>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
|
|
||||||
class QRegExp;
|
class QRegExp;
|
||||||
class QRegularExpression;
|
class QRegularExpression;
|
||||||
|
|
||||||
typedef QListIterator<QString> QStringListIterator;
|
typedef QListIterator<QString> QStringListIterator;
|
||||||
typedef QMutableListIterator<QString> QMutableStringListIterator;
|
typedef QMutableListIterator<QString> QMutableStringListIterator;
|
||||||
|
|
||||||
|
class QStringList;
|
||||||
|
|
||||||
|
#ifdef Q_QDOC
|
||||||
|
class QStringList : public QList<QString>
|
||||||
|
#else
|
||||||
|
template <> struct QListSpecialMethods<QString>
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
inline void sort(Qt::CaseSensitivity cs = Qt::CaseSensitive);
|
||||||
|
inline int removeDuplicates();
|
||||||
|
|
||||||
|
inline QString join(const QString &sep) const;
|
||||||
|
inline QString join(QChar sep) const;
|
||||||
|
|
||||||
|
inline QStringList filter(const QString &str, Qt::CaseSensitivity cs = Qt::CaseSensitive) const;
|
||||||
|
inline QStringList &replaceInStrings(const QString &before, const QString &after, Qt::CaseSensitivity cs = Qt::CaseSensitive);
|
||||||
|
|
||||||
|
#ifndef QT_NO_REGEXP
|
||||||
|
inline QStringList filter(const QRegExp &rx) const;
|
||||||
|
inline QStringList &replaceInStrings(const QRegExp &rx, const QString &after);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef QT_BOOTSTRAPPED
|
||||||
|
#ifndef QT_NO_REGULAREXPRESSION
|
||||||
|
inline QStringList filter(const QRegularExpression &re) const;
|
||||||
|
inline QStringList &replaceInStrings(const QRegularExpression &re, const QString &after);
|
||||||
|
#endif // QT_NO_REGULAREXPRESSION
|
||||||
|
#endif // QT_BOOTSTRAPPED
|
||||||
|
|
||||||
|
#ifndef Q_QDOC
|
||||||
|
private:
|
||||||
|
inline QStringList *self();
|
||||||
|
inline const QStringList *self() const;
|
||||||
|
};
|
||||||
|
|
||||||
|
// ### Qt6: check if there's a better way
|
||||||
class QStringList : public QList<QString>
|
class QStringList : public QList<QString>
|
||||||
{
|
{
|
||||||
|
#endif
|
||||||
public:
|
public:
|
||||||
inline QStringList() { }
|
inline QStringList() { }
|
||||||
inline explicit QStringList(const QString &i) { append(i); }
|
inline explicit QStringList(const QString &i) { append(i); }
|
||||||
@ -70,17 +107,8 @@ public:
|
|||||||
{ QList<QString>::operator=(std::move(other)); return *this; }
|
{ QList<QString>::operator=(std::move(other)); return *this; }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
inline void sort(Qt::CaseSensitivity cs = Qt::CaseSensitive);
|
|
||||||
inline int removeDuplicates();
|
|
||||||
|
|
||||||
inline QString join(const QString &sep) const;
|
|
||||||
inline QString join(QChar sep) const;
|
|
||||||
|
|
||||||
inline QStringList filter(const QString &str, Qt::CaseSensitivity cs = Qt::CaseSensitive) const;
|
|
||||||
inline bool contains(const QString &str, Qt::CaseSensitivity cs = Qt::CaseSensitive) const;
|
inline bool contains(const QString &str, Qt::CaseSensitivity cs = Qt::CaseSensitive) const;
|
||||||
|
|
||||||
inline QStringList &replaceInStrings(const QString &before, const QString &after, Qt::CaseSensitivity cs = Qt::CaseSensitive);
|
|
||||||
|
|
||||||
inline QStringList operator+(const QStringList &other) const
|
inline QStringList operator+(const QStringList &other) const
|
||||||
{ QStringList n = *this; n += other; return n; }
|
{ QStringList n = *this; n += other; return n; }
|
||||||
inline QStringList &operator<<(const QString &str)
|
inline QStringList &operator<<(const QString &str)
|
||||||
@ -91,8 +119,6 @@ public:
|
|||||||
{ *this += l; return *this; }
|
{ *this += l; return *this; }
|
||||||
|
|
||||||
#ifndef QT_NO_REGEXP
|
#ifndef QT_NO_REGEXP
|
||||||
inline QStringList filter(const QRegExp &rx) const;
|
|
||||||
inline QStringList &replaceInStrings(const QRegExp &rx, const QString &after);
|
|
||||||
inline int indexOf(const QRegExp &rx, int from = 0) const;
|
inline int indexOf(const QRegExp &rx, int from = 0) const;
|
||||||
inline int lastIndexOf(const QRegExp &rx, int from = -1) const;
|
inline int lastIndexOf(const QRegExp &rx, int from = -1) const;
|
||||||
inline int indexOf(QRegExp &rx, int from = 0) const;
|
inline int indexOf(QRegExp &rx, int from = 0) const;
|
||||||
@ -101,8 +127,6 @@ public:
|
|||||||
|
|
||||||
#ifndef QT_BOOTSTRAPPED
|
#ifndef QT_BOOTSTRAPPED
|
||||||
#ifndef QT_NO_REGULAREXPRESSION
|
#ifndef QT_NO_REGULAREXPRESSION
|
||||||
inline QStringList filter(const QRegularExpression &re) const;
|
|
||||||
inline QStringList &replaceInStrings(const QRegularExpression &re, const QString &after);
|
|
||||||
inline int indexOf(const QRegularExpression &re, int from = 0) const;
|
inline int indexOf(const QRegularExpression &re, int from = 0) const;
|
||||||
inline int lastIndexOf(const QRegularExpression &re, int from = -1) const;
|
inline int lastIndexOf(const QRegularExpression &re, int from = -1) const;
|
||||||
#endif // QT_NO_REGULAREXPRESSION
|
#endif // QT_NO_REGULAREXPRESSION
|
||||||
@ -114,6 +138,11 @@ public:
|
|||||||
|
|
||||||
Q_DECLARE_TYPEINFO(QStringList, Q_MOVABLE_TYPE);
|
Q_DECLARE_TYPEINFO(QStringList, Q_MOVABLE_TYPE);
|
||||||
|
|
||||||
|
inline QStringList *QListSpecialMethods<QString>::self()
|
||||||
|
{ return static_cast<QStringList *>(this); }
|
||||||
|
inline const QStringList *QListSpecialMethods<QString>::self() const
|
||||||
|
{ return static_cast<const QStringList *>(this); }
|
||||||
|
|
||||||
namespace QtPrivate {
|
namespace QtPrivate {
|
||||||
void Q_CORE_EXPORT QStringList_sort(QStringList *that, Qt::CaseSensitivity cs);
|
void Q_CORE_EXPORT QStringList_sort(QStringList *that, Qt::CaseSensitivity cs);
|
||||||
int Q_CORE_EXPORT QStringList_removeDuplicates(QStringList *that);
|
int Q_CORE_EXPORT QStringList_removeDuplicates(QStringList *that);
|
||||||
@ -144,29 +173,29 @@ namespace QtPrivate {
|
|||||||
#endif // QT_BOOTSTRAPPED
|
#endif // QT_BOOTSTRAPPED
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void QStringList::sort(Qt::CaseSensitivity cs)
|
inline void QListSpecialMethods<QString>::sort(Qt::CaseSensitivity cs)
|
||||||
{
|
{
|
||||||
QtPrivate::QStringList_sort(this, cs);
|
QtPrivate::QStringList_sort(self(), cs);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int QStringList::removeDuplicates()
|
inline int QListSpecialMethods<QString>::removeDuplicates()
|
||||||
{
|
{
|
||||||
return QtPrivate::QStringList_removeDuplicates(this);
|
return QtPrivate::QStringList_removeDuplicates(self());
|
||||||
}
|
}
|
||||||
|
|
||||||
inline QString QStringList::join(const QString &sep) const
|
inline QString QListSpecialMethods<QString>::join(const QString &sep) const
|
||||||
{
|
{
|
||||||
return QtPrivate::QStringList_join(this, sep.constData(), sep.length());
|
return QtPrivate::QStringList_join(self(), sep.constData(), sep.length());
|
||||||
}
|
}
|
||||||
|
|
||||||
inline QString QStringList::join(QChar sep) const
|
inline QString QListSpecialMethods<QString>::join(QChar sep) const
|
||||||
{
|
{
|
||||||
return QtPrivate::QStringList_join(this, &sep, 1);
|
return QtPrivate::QStringList_join(self(), &sep, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline QStringList QStringList::filter(const QString &str, Qt::CaseSensitivity cs) const
|
inline QStringList QListSpecialMethods<QString>::filter(const QString &str, Qt::CaseSensitivity cs) const
|
||||||
{
|
{
|
||||||
return QtPrivate::QStringList_filter(this, str, cs);
|
return QtPrivate::QStringList_filter(self(), str, cs);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool QStringList::contains(const QString &str, Qt::CaseSensitivity cs) const
|
inline bool QStringList::contains(const QString &str, Qt::CaseSensitivity cs) const
|
||||||
@ -174,22 +203,29 @@ inline bool QStringList::contains(const QString &str, Qt::CaseSensitivity cs) co
|
|||||||
return QtPrivate::QStringList_contains(this, str, cs);
|
return QtPrivate::QStringList_contains(this, str, cs);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline QStringList &QStringList::replaceInStrings(const QString &before, const QString &after, Qt::CaseSensitivity cs)
|
inline QStringList &QListSpecialMethods<QString>::replaceInStrings(const QString &before, const QString &after, Qt::CaseSensitivity cs)
|
||||||
{
|
{
|
||||||
QtPrivate::QStringList_replaceInStrings(this, before, after, cs);
|
QtPrivate::QStringList_replaceInStrings(self(), before, after, cs);
|
||||||
return *this;
|
return *self();
|
||||||
|
}
|
||||||
|
|
||||||
|
inline QStringList operator+(const QList<QString> &one, const QStringList &other)
|
||||||
|
{
|
||||||
|
QStringList n = one;
|
||||||
|
n += other;
|
||||||
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef QT_NO_REGEXP
|
#ifndef QT_NO_REGEXP
|
||||||
inline QStringList &QStringList::replaceInStrings(const QRegExp &rx, const QString &after)
|
inline QStringList &QListSpecialMethods<QString>::replaceInStrings(const QRegExp &rx, const QString &after)
|
||||||
{
|
{
|
||||||
QtPrivate::QStringList_replaceInStrings(this, rx, after);
|
QtPrivate::QStringList_replaceInStrings(self(), rx, after);
|
||||||
return *this;
|
return *self();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline QStringList QStringList::filter(const QRegExp &rx) const
|
inline QStringList QListSpecialMethods<QString>::filter(const QRegExp &rx) const
|
||||||
{
|
{
|
||||||
return QtPrivate::QStringList_filter(this, rx);
|
return QtPrivate::QStringList_filter(self(), rx);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int QStringList::indexOf(const QRegExp &rx, int from) const
|
inline int QStringList::indexOf(const QRegExp &rx, int from) const
|
||||||
@ -215,15 +251,15 @@ inline int QStringList::lastIndexOf(QRegExp &rx, int from) const
|
|||||||
|
|
||||||
#ifndef QT_BOOTSTRAPPED
|
#ifndef QT_BOOTSTRAPPED
|
||||||
#ifndef QT_NO_REGULAREXPRESSION
|
#ifndef QT_NO_REGULAREXPRESSION
|
||||||
inline QStringList &QStringList::replaceInStrings(const QRegularExpression &rx, const QString &after)
|
inline QStringList &QListSpecialMethods<QString>::replaceInStrings(const QRegularExpression &rx, const QString &after)
|
||||||
{
|
{
|
||||||
QtPrivate::QStringList_replaceInStrings(this, rx, after);
|
QtPrivate::QStringList_replaceInStrings(self(), rx, after);
|
||||||
return *this;
|
return *self();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline QStringList QStringList::filter(const QRegularExpression &rx) const
|
inline QStringList QListSpecialMethods<QString>::filter(const QRegularExpression &rx) const
|
||||||
{
|
{
|
||||||
return QtPrivate::QStringList_filter(this, rx);
|
return QtPrivate::QStringList_filter(self(), rx);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int QStringList::indexOf(const QRegularExpression &rx, int from) const
|
inline int QStringList::indexOf(const QRegularExpression &rx, int from) const
|
||||||
|
Loading…
Reference in New Issue
Block a user