shared: Add LimitQueue which discards oldest entry once limit hit

Šī revīzija ir iekļauta:
Albert S. 2022-08-06 09:03:05 +02:00
vecāks 00abc6bc1b
revīzija ad06497b4b
2 mainīti faili ar 49 papildinājumiem un 0 dzēšanām

48
shared/limitqueue.h Parasts fails
Parādīt failu

@ -0,0 +1,48 @@
#ifndef LIMITQUEUE_H
#define LIMITQUEUE_H
#include <QQueue>
template <class T> class LimitQueue
{
protected:
QQueue<T> queue;
unsigned int limit = 0;
public:
LimitQueue();
LimitQueue(unsigned int limit)
{
this->limit = limit;
}
void enqueue(const T &t)
{
if(queue.size() == limit)
{
queue.dequeue();
}
queue.enqueue(t);
}
int size()
{
return queue.size();
}
T dequeue()
{
return queue.dequeue();
}
void setLimit(unsigned int limit)
{
this->limit = limit;
}
void clear()
{
queue.clear();
}
};
#endif // LIMITQUEUE_H

Parādīt failu

@ -77,6 +77,7 @@ HEADERS += sqlitesearch.h \
filescanworker.h \
indexer.h \
indexsyncer.h \
limitqueue.h \
logger.h \
looqsgeneralexception.h \
looqsquery.h \