forked from qt-creator/qt-creator
Clang: Print message if message is lost
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>
This commit is contained in:
@@ -47,7 +47,8 @@ SOURCES += $$PWD/ipcserverinterface.cpp \
|
|||||||
$$PWD/updatetranslationunitsforeditormessage.cpp \
|
$$PWD/updatetranslationunitsforeditormessage.cpp \
|
||||||
$$PWD/updatevisibletranslationunitsmessage.cpp \
|
$$PWD/updatevisibletranslationunitsmessage.cpp \
|
||||||
$$PWD/highlightingchangedmessage.cpp \
|
$$PWD/highlightingchangedmessage.cpp \
|
||||||
$$PWD/highlightingmarkcontainer.cpp
|
$$PWD/highlightingmarkcontainer.cpp \
|
||||||
|
$$PWD/messageenvelop.cpp
|
||||||
|
|
||||||
HEADERS += \
|
HEADERS += \
|
||||||
$$PWD/ipcserverinterface.h \
|
$$PWD/ipcserverinterface.h \
|
||||||
|
121
src/libs/clangbackendipc/messageenvelop.cpp
Normal file
121
src/libs/clangbackendipc/messageenvelop.cpp
Normal file
@@ -0,0 +1,121 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** 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 "messageenvelop.h"
|
||||||
|
|
||||||
|
#include "cmbcodecompletedmessage.h"
|
||||||
|
#include "cmbcompletecodemessage.h"
|
||||||
|
#include "cmbechomessage.h"
|
||||||
|
#include "cmbregisterprojectsforeditormessage.h"
|
||||||
|
#include "cmbregistertranslationunitsforeditormessage.h"
|
||||||
|
#include "cmbunregisterprojectsforeditormessage.h"
|
||||||
|
#include "cmbunregistertranslationunitsforeditormessage.h"
|
||||||
|
#include "diagnosticschangedmessage.h"
|
||||||
|
#include "highlightingchangedmessage.h"
|
||||||
|
#include "messageenvelop.h"
|
||||||
|
#include "messageenvelop.h"
|
||||||
|
#include "projectpartsdonotexistmessage.h"
|
||||||
|
#include "registerunsavedfilesforeditormessage.h"
|
||||||
|
#include "requestdiagnosticsmessage.h"
|
||||||
|
#include "requesthighlightingmessage.h"
|
||||||
|
#include "translationunitdoesnotexistmessage.h"
|
||||||
|
#include "unregisterunsavedfilesforeditormessage.h"
|
||||||
|
#include "updatetranslationunitsforeditormessage.h"
|
||||||
|
#include "updatevisibletranslationunitsmessage.h"
|
||||||
|
|
||||||
|
namespace ClangBackEnd {
|
||||||
|
|
||||||
|
QDebug operator<<(QDebug debug, const MessageEnvelop &messageEnvelop)
|
||||||
|
{
|
||||||
|
debug.nospace() << "MessageEnvelop(";
|
||||||
|
|
||||||
|
switch (messageEnvelop.messageType()) {
|
||||||
|
case MessageType::EndMessage:
|
||||||
|
qDebug() << "EndMessage()";
|
||||||
|
break;
|
||||||
|
case MessageType::RegisterTranslationUnitForEditorMessage:
|
||||||
|
qDebug() << messageEnvelop.message<RegisterTranslationUnitForEditorMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::UpdateTranslationUnitsForEditorMessage:
|
||||||
|
qDebug() << messageEnvelop.message<UpdateTranslationUnitsForEditorMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::UnregisterTranslationUnitsForEditorMessage:
|
||||||
|
qDebug() << messageEnvelop.message<UnregisterTranslationUnitsForEditorMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::RegisterProjectPartsForEditorMessage:
|
||||||
|
qDebug() << messageEnvelop.message<RegisterProjectPartsForEditorMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::UnregisterProjectPartsForEditorMessage:
|
||||||
|
qDebug() << messageEnvelop.message<UnregisterProjectPartsForEditorMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::RegisterUnsavedFilesForEditorMessage:
|
||||||
|
qDebug() << messageEnvelop.message<RegisterUnsavedFilesForEditorMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::UnregisterUnsavedFilesForEditorMessage:
|
||||||
|
qDebug() << messageEnvelop.message<UnregisterUnsavedFilesForEditorMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::CompleteCodeMessage:
|
||||||
|
qDebug() << messageEnvelop.message<CompleteCodeMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::RequestDiagnosticsMessage:
|
||||||
|
qDebug() << messageEnvelop.message<RequestDiagnosticsMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::RequestHighlightingMessage:
|
||||||
|
qDebug() << messageEnvelop.message<RequestHighlightingMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::UpdateVisibleTranslationUnitsMessage:
|
||||||
|
qDebug() << messageEnvelop.message<UpdateVisibleTranslationUnitsMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::AliveMessage:
|
||||||
|
qDebug() << "AliveMessage()";
|
||||||
|
break;
|
||||||
|
case MessageType::EchoMessage:
|
||||||
|
qDebug() << messageEnvelop.message<EchoMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::CodeCompletedMessage:
|
||||||
|
qDebug() << messageEnvelop.message<CodeCompletedMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::TranslationUnitDoesNotExistMessage:
|
||||||
|
qDebug() << messageEnvelop.message<TranslationUnitDoesNotExistMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::ProjectPartsDoNotExistMessage:
|
||||||
|
qDebug() << messageEnvelop.message<ProjectPartsDoNotExistMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::DiagnosticsChangedMessage:
|
||||||
|
qDebug() << messageEnvelop.message<DiagnosticsChangedMessage>();
|
||||||
|
break;
|
||||||
|
case MessageType::HighlightingChangedMessage:
|
||||||
|
qDebug() << messageEnvelop.message<HighlightingChangedMessage>();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
qWarning() << "Unknown Message";
|
||||||
|
}
|
||||||
|
|
||||||
|
debug.nospace() << ")";
|
||||||
|
|
||||||
|
return debug;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace ClangBackEnd
|
@@ -29,6 +29,7 @@
|
|||||||
|
|
||||||
#include <QByteArray>
|
#include <QByteArray>
|
||||||
#include <QDataStream>
|
#include <QDataStream>
|
||||||
|
#include <QDebug>
|
||||||
|
|
||||||
namespace ClangBackEnd {
|
namespace ClangBackEnd {
|
||||||
|
|
||||||
@@ -105,6 +106,8 @@ public:
|
|||||||
&& first.data == second.data;
|
&& first.data == second.data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
friend QDebug operator<<(QDebug debug, const MessageEnvelop &messageEnvelop);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
mutable QByteArray data;
|
mutable QByteArray data;
|
||||||
MessageType messageType_ = MessageType::InvalidMessage;
|
MessageType messageType_ = MessageType::InvalidMessage;
|
||||||
|
@@ -41,19 +41,22 @@ ReadMessageBlock::ReadMessageBlock(QIODevice *ioDevice)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReadMessageBlock::checkIfMessageIsLost(QDataStream &in)
|
bool ReadMessageBlock::checkIfMessageIsLost(QDataStream &in)
|
||||||
{
|
{
|
||||||
qint64 currentMessageCounter;
|
qint64 currentMessageCounter;
|
||||||
|
|
||||||
in >> currentMessageCounter;
|
in >> currentMessageCounter;
|
||||||
|
|
||||||
|
bool messageIsLost = false;
|
||||||
#ifndef DONT_CHECK_MESSAGE_COUNTER
|
#ifndef DONT_CHECK_MESSAGE_COUNTER
|
||||||
bool messageLost = !((currentMessageCounter == 0 && messageCounter == 0) || (messageCounter + 1 == currentMessageCounter));
|
messageIsLost = !((currentMessageCounter == 0 && messageCounter == 0) || (messageCounter + 1 == currentMessageCounter));
|
||||||
if (messageLost)
|
if (messageIsLost)
|
||||||
qWarning() << "client message lost: " << messageCounter << currentMessageCounter;
|
qWarning() << "message lost: " << messageCounter << currentMessageCounter;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
messageCounter = currentMessageCounter;
|
messageCounter = currentMessageCounter;
|
||||||
|
|
||||||
|
return messageIsLost;
|
||||||
}
|
}
|
||||||
|
|
||||||
MessageEnvelop ReadMessageBlock::read()
|
MessageEnvelop ReadMessageBlock::read()
|
||||||
@@ -63,8 +66,12 @@ MessageEnvelop ReadMessageBlock::read()
|
|||||||
MessageEnvelop message;
|
MessageEnvelop message;
|
||||||
|
|
||||||
if (isTheWholeMessageReadable(in)) {
|
if (isTheWholeMessageReadable(in)) {
|
||||||
checkIfMessageIsLost(in);
|
bool messageIsLost = checkIfMessageIsLost(in);
|
||||||
|
|
||||||
in >> message;
|
in >> message;
|
||||||
|
|
||||||
|
if (messageIsLost)
|
||||||
|
qDebug() << message;
|
||||||
}
|
}
|
||||||
|
|
||||||
return message;
|
return message;
|
||||||
|
@@ -48,7 +48,7 @@ public:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
bool isTheWholeMessageReadable(QDataStream &in);
|
bool isTheWholeMessageReadable(QDataStream &in);
|
||||||
void checkIfMessageIsLost(QDataStream &in);
|
bool checkIfMessageIsLost(QDataStream &in);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QIODevice *ioDevice;
|
QIODevice *ioDevice;
|
||||||
|
Reference in New Issue
Block a user