Add qHash(QList)

QLists can be compared for equality, so qHash should be overloaded, too.

[ChangeLog][QtCore][QList] Added qHash(QList).

Change-Id: I9ad91811f12479764cc17d87192539612ceb0b4c
Reviewed-by: Olivier Goffart (Woboq GmbH) <ogoffart@woboq.com>
This commit is contained in:
Marc Mutz 2015-04-08 19:44:48 +02:00
parent 1b5f29e28a
commit 5fdc64f566
3 changed files with 33 additions and 0 deletions

View File

@ -632,6 +632,17 @@ void **QListData::erase(void **xi)
of \c operator<(). of \c operator<().
*/ */
/*!
\fn uint qHash(const QList<T> &key, uint seed = 0)
\since 5.6
\relates QList
Returns the hash value for \a key,
using \a seed to seed the calculation.
This function requires qHash() to be overloaded for the value type \c T.
*/
/*! /*!
\fn int QList::size() const \fn int QList::size() const

View File

@ -38,6 +38,7 @@
#include <QtCore/qiterator.h> #include <QtCore/qiterator.h>
#include <QtCore/qrefcount.h> #include <QtCore/qrefcount.h>
#include <QtCore/qarraydata.h> #include <QtCore/qarraydata.h>
#include <QtCore/qhashfunctions.h>
#include <iterator> #include <iterator>
#include <list> #include <list>
@ -1021,6 +1022,13 @@ inline int QList<T>::count_impl(const T &t, QListData::ArrayCompatibleLayout) co
Q_DECLARE_SEQUENTIAL_ITERATOR(List) Q_DECLARE_SEQUENTIAL_ITERATOR(List)
Q_DECLARE_MUTABLE_SEQUENTIAL_ITERATOR(List) Q_DECLARE_MUTABLE_SEQUENTIAL_ITERATOR(List)
template <typename T>
uint qHash(const QList<T> &key, uint seed = 0)
Q_DECL_NOEXCEPT_EXPR(noexcept(qHashRange(key.cbegin(), key.cend(), seed)))
{
return qHashRange(key.cbegin(), key.cend(), seed);
}
template <typename T> template <typename T>
bool operator<(const QList<T> &lhs, const QList<T> &rhs) bool operator<(const QList<T> &lhs, const QList<T> &rhs)
Q_DECL_NOEXCEPT_EXPR(noexcept(std::lexicographical_compare(lhs.begin(), lhs.end(), Q_DECL_NOEXCEPT_EXPR(noexcept(std::lexicographical_compare(lhs.begin(), lhs.end(),

View File

@ -399,6 +399,9 @@ private slots:
void eraseValidIteratorsOnSharedList() const; void eraseValidIteratorsOnSharedList() const;
void insertWithValidIteratorsOnSharedList() const; void insertWithValidIteratorsOnSharedList() const;
void qhashOptimal() const { qhash<Optimal>(); }
void qhashMovable() const { qhash<Movable>(); }
void qhashComplex() const { qhash<Complex>(); }
void reserve() const; void reserve() const;
private: private:
template<typename T> void length() const; template<typename T> void length() const;
@ -415,6 +418,7 @@ private:
template<typename T> void endsWith() const; template<typename T> void endsWith() const;
template<typename T> void lastIndexOf() const; template<typename T> void lastIndexOf() const;
template<typename T> void move() const; template<typename T> void move() const;
template<typename T> void qhash() const;
template<typename T> void removeAll() const; template<typename T> void removeAll() const;
template<typename T> void removeAt() const; template<typename T> void removeAt() const;
template<typename T> void removeOne() const; template<typename T> void removeOne() const;
@ -1908,6 +1912,16 @@ void tst_QList::insertWithValidIteratorsOnSharedList() const
QCOMPARE(a.at(1), 15); QCOMPARE(a.at(1), 15);
} }
template <typename T>
void tst_QList::qhash() const
{
QList<T> l1, l2;
QCOMPARE(qHash(l1), qHash(l2));
l1 << T_BAR;
l2 << T_BAR;
QCOMPARE(qHash(l1), qHash(l2));
}
void tst_QList::reserve() const void tst_QList::reserve() const
{ {
// Note: // Note: