1/****************************************************************************
2**
3** Copyright (C) 2017 The Qt Company Ltd.
4** Contact: https://www.qt.io/licensing/
5**
6** This file is part of the QtQml module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial License Usage
10** Licensees holding valid commercial Qt licenses may use this file in
11** accordance with the commercial license agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and The Qt Company. For licensing terms
14** and conditions see https://www.qt.io/terms-conditions. For further
15** information use the contact form at https://www.qt.io/contact-us.
16**
17** GNU Lesser General Public License Usage
18** Alternatively, this file may be used under the terms of the GNU Lesser
19** General Public License version 3 as published by the Free Software
20** Foundation and appearing in the file LICENSE.LGPL3 included in the
21** packaging of this file. Please review the following information to
22** ensure the GNU Lesser General Public License version 3 requirements
23** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
24**
25** GNU General Public License Usage
26** Alternatively, this file may be used under the terms of the GNU
27** General Public License version 2.0 or (at your option) the GNU General
28** Public license version 3 or any later version approved by the KDE Free
29** Qt Foundation. The licenses are as published by the Free Software
30** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
31** included in the packaging of this file. Please review the following
32** information to ensure the GNU General Public License requirements will
33** be met: https://www.gnu.org/licenses/gpl-2.0.html and
34** https://www.gnu.org/licenses/gpl-3.0.html.
35**
36** $QT_END_LICENSE$
37**
38****************************************************************************/
39
40#include "qqmldebugmessageclient_p.h"
41
42#include <QtCore/qdatastream.h>
43
44QT_BEGIN_NAMESPACE
45
46/*!
47 \class QQmlDebugMessageClient
48 \internal
49
50 \brief Client for the debug message service
51
52 The QQmlDebugMessageClient receives debug messages routed through the QML
53 debug connection via QDebugMessageService.
54 */
55
56QQmlDebugMessageClient::QQmlDebugMessageClient(QQmlDebugConnection *client)
57 : QQmlDebugClient(QLatin1String("DebugMessages"), client)
58{
59}
60
61void QQmlDebugMessageClient::messageReceived(const QByteArray &data)
62{
63 QDataStream ds(data);
64 QByteArray command;
65 ds >> command;
66
67 if (command == "MESSAGE") {
68 int type;
69 int line;
70 QByteArray debugMessage;
71 QByteArray file;
72 QByteArray function;
73 ds >> type >> debugMessage >> file >> line >> function;
74 QQmlDebugContextInfo info;
75 info.line = line;
76 info.file = QString::fromUtf8(str: file);
77 info.function = QString::fromUtf8(str: function);
78 info.timestamp = -1;
79 if (!ds.atEnd()) {
80 QByteArray category;
81 ds >> category;
82 info.category = QString::fromUtf8(str: category);
83 if (!ds.atEnd())
84 ds >> info.timestamp;
85 }
86 emit message(QtMsgType(type), QString::fromUtf8(str: debugMessage), info);
87 }
88}
89
90QT_END_NAMESPACE
91

source code of qtdeclarative/src/qmldebug/qqmldebugmessageclient.cpp