X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fcore.cpp;h=add0e9000d11c8884ff8b49b18f1109d0b891ce4;hb=40b2631f91d4ed5f8361292decf40a92b3d37e1f;hp=407eac8ff0bac2ae67e4a5212ab70a1b9dd5af06;hpb=d3ea803d8977692f95bbe31fbaba3686fc2ce5a9;p=quassel.git diff --git a/src/core/core.cpp b/src/core/core.cpp index 407eac8f..add0e900 100644 --- a/src/core/core.cpp +++ b/src/core/core.cpp @@ -84,7 +84,7 @@ void Core::init() { } Core::~Core() { - foreach(QTcpSocket *socket, blocksizes.keys()) { + foreach(QTcpSocket *socket, blocksizes.keys()) { qDebug() << "disconnecting" << socket << blocksizes.keys(); socket->disconnectFromHost(); // disconnect local (i.e. non-authed) clients } qDeleteAll(sessions); @@ -235,9 +235,9 @@ NetworkId Core::networkId(UserId user, const QString &network) { return instance()->storage->getNetworkId(user, network); } -BufferInfo Core::bufferInfo(UserId user, const NetworkId &networkId, const QString &buffer) { +BufferInfo Core::bufferInfo(UserId user, const NetworkId &networkId, BufferInfo::Type type, const QString &buffer) { QMutexLocker locker(&mutex); - return instance()->storage->getBufferInfo(user, networkId, buffer); + return instance()->storage->getBufferInfo(user, networkId, type, buffer); } MsgId Core::storeMessage(const Message &message) { @@ -265,6 +265,21 @@ QList Core::requestBuffers(UserId user, QDateTime since) { return instance()->storage->requestBuffers(user, since); } +bool Core::removeBuffer(const UserId &user, const BufferId &bufferId) { + QMutexLocker locker(&mutex); + return instance()->storage->removeBuffer(user, bufferId); +} + +void Core::setBufferLastSeen(UserId user, const BufferId &bufferId, const QDateTime &seenDate) { + QMutexLocker locker(&mutex); + return instance()->storage->setBufferLastSeen(user, bufferId, seenDate); +} + +QHash Core::bufferLastSeenDates(UserId user) { + QMutexLocker locker(&mutex); + return instance()->storage->bufferLastSeenDates(user); +} + /*** Network Management ***/ bool Core::startListening(uint port) { @@ -305,6 +320,7 @@ void Core::clientHasData() { while(SignalProxy::readDataFromDevice(socket, blocksizes[socket], item)) { QVariantMap msg = item.toMap(); processClientMessage(socket, msg); + if(!blocksizes.contains(socket)) break; // this socket is no longer ours to handle! } }