forked from qt-creator/qt-creator
If there is a message counter mismatch it is very helpful to get message content. Change-Id: I4ea2526bd4b72010627e99de08ff9a8e64ca3d02 Reviewed-by: Tim Jenssen <tim.jenssen@theqtcompany.com>
118 lines
3.0 KiB
C++
118 lines
3.0 KiB
C++
/****************************************************************************
|
|
**
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
** Contact: https://www.qt.io/licensing/
|
|
**
|
|
** This file is part of Qt Creator.
|
|
**
|
|
** Commercial License Usage
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
** accordance with the commercial license agreement provided with the
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
|
**
|
|
** GNU General Public License Usage
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
** General Public License version 3 as published by the Free Software
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
** included in the packaging of this file. Please review the following
|
|
** information to ensure the GNU General Public License requirements will
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
|
**
|
|
****************************************************************************/
|
|
|
|
#include "readmessageblock.h"
|
|
|
|
#include "messageenvelop.h"
|
|
|
|
#include <QDataStream>
|
|
#include <QDebug>
|
|
#include <QIODevice>
|
|
#include <QVariant>
|
|
|
|
namespace ClangBackEnd {
|
|
|
|
ReadMessageBlock::ReadMessageBlock(QIODevice *ioDevice)
|
|
: ioDevice(ioDevice),
|
|
messageCounter(0),
|
|
blockSize(0)
|
|
{
|
|
}
|
|
|
|
bool ReadMessageBlock::checkIfMessageIsLost(QDataStream &in)
|
|
{
|
|
qint64 currentMessageCounter;
|
|
|
|
in >> currentMessageCounter;
|
|
|
|
bool messageIsLost = false;
|
|
#ifndef DONT_CHECK_MESSAGE_COUNTER
|
|
messageIsLost = !((currentMessageCounter == 0 && messageCounter == 0) || (messageCounter + 1 == currentMessageCounter));
|
|
if (messageIsLost)
|
|
qWarning() << "message lost: " << messageCounter << currentMessageCounter;
|
|
#endif
|
|
|
|
messageCounter = currentMessageCounter;
|
|
|
|
return messageIsLost;
|
|
}
|
|
|
|
MessageEnvelop ReadMessageBlock::read()
|
|
{
|
|
QDataStream in(ioDevice);
|
|
|
|
MessageEnvelop message;
|
|
|
|
if (isTheWholeMessageReadable(in)) {
|
|
bool messageIsLost = checkIfMessageIsLost(in);
|
|
|
|
in >> message;
|
|
|
|
if (messageIsLost)
|
|
qDebug() << message;
|
|
}
|
|
|
|
return message;
|
|
}
|
|
|
|
QVector<MessageEnvelop> ReadMessageBlock::readAll()
|
|
{
|
|
QVector<MessageEnvelop> messages;
|
|
|
|
while (true) {
|
|
const MessageEnvelop message = read();
|
|
if (message.isValid())
|
|
messages.append(message);
|
|
else
|
|
return messages;
|
|
}
|
|
|
|
Q_UNREACHABLE();
|
|
}
|
|
|
|
void ReadMessageBlock::resetCounter()
|
|
{
|
|
messageCounter = 0;
|
|
}
|
|
|
|
bool ReadMessageBlock::isTheWholeMessageReadable(QDataStream &in)
|
|
{
|
|
if (ioDevice->bytesAvailable() < qint64(sizeof(blockSize)))
|
|
return false;
|
|
|
|
if (blockSize == 0)
|
|
in >> blockSize;
|
|
|
|
if (ioDevice->bytesAvailable() < blockSize)
|
|
return false;
|
|
|
|
blockSize = 0;
|
|
|
|
return true;
|
|
}
|
|
|
|
} // namespace ClangBackEnd
|
|
|