2013-03-14 16:02:19 +01:00
|
|
|
/****************************************************************************
|
|
|
|
**
|
2016-01-15 14:57:40 +01:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2013-03-14 16:02:19 +01:00
|
|
|
**
|
|
|
|
** 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
|
2016-01-15 14:57:40 +01:00
|
|
|
** 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.
|
2013-03-14 16:02:19 +01:00
|
|
|
**
|
2015-09-18 11:34:48 +02:00
|
|
|
** GNU General Public License Usage
|
|
|
|
** Alternatively, this file may be used under the terms of the GNU
|
2016-01-15 14:57:40 +01:00
|
|
|
** 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.
|
2013-03-14 16:02:19 +01:00
|
|
|
**
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include "debugview.h"
|
|
|
|
#include "debugviewwidget.h"
|
|
|
|
|
|
|
|
#include <qmldesignerplugin.h>
|
|
|
|
|
|
|
|
#include <bindingproperty.h>
|
|
|
|
#include <nodeabstractproperty.h>
|
2017-03-07 17:37:23 +01:00
|
|
|
#include <nodelistproperty.h>
|
2020-07-01 18:00:39 +02:00
|
|
|
#include <nodemetainfo.h>
|
|
|
|
#include <signalhandlerproperty.h>
|
2013-03-14 16:02:19 +01:00
|
|
|
#include <variantproperty.h>
|
|
|
|
|
2015-07-15 11:58:27 +02:00
|
|
|
#include <qmlitemnode.h>
|
|
|
|
|
2019-01-09 18:29:20 +01:00
|
|
|
#include <utils/algorithm.h>
|
|
|
|
|
2013-03-14 16:02:19 +01:00
|
|
|
namespace {
|
2014-05-12 14:09:02 +02:00
|
|
|
const QString lineBreak = QStringLiteral("<br>");
|
2013-03-14 16:02:19 +01:00
|
|
|
|
|
|
|
bool isDebugViewEnabled()
|
|
|
|
{
|
2017-01-19 13:46:37 +01:00
|
|
|
return QmlDesigner::DesignerSettings::getValue(
|
2016-01-13 14:48:40 +01:00
|
|
|
QmlDesigner::DesignerSettingsKey::ENABLE_DEBUGVIEW).toBool();
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
bool isDebugViewShown()
|
|
|
|
{
|
2017-01-19 13:46:37 +01:00
|
|
|
return QmlDesigner::DesignerSettings::getValue(
|
2016-01-13 14:48:40 +01:00
|
|
|
QmlDesigner::DesignerSettingsKey::SHOW_DEBUGVIEW).toBool();
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace QmlDesigner {
|
|
|
|
|
|
|
|
namespace Internal {
|
|
|
|
|
2013-07-31 15:45:09 +02:00
|
|
|
DebugView::DebugView(QObject *parent) : AbstractView(parent),
|
2013-03-14 16:02:19 +01:00
|
|
|
m_debugViewWidget(new DebugViewWidget)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
DebugView::~DebugView()
|
|
|
|
{
|
2016-04-13 15:54:00 +03:00
|
|
|
delete m_debugViewWidget;
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::modelAttached(Model *model)
|
|
|
|
{
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::modelAttached:", QString("filename %1").arg(model->fileUrl().toLocalFile()));
|
2013-03-14 16:02:19 +01:00
|
|
|
m_debugViewWidget->setDebugViewEnabled(isDebugViewEnabled());
|
2013-10-31 14:21:25 +01:00
|
|
|
if (isDebugViewEnabled())
|
2015-10-23 15:00:12 +02:00
|
|
|
qDebug() << tr("Debug view is enabled");
|
2013-07-31 15:45:09 +02:00
|
|
|
AbstractView::modelAttached(model);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::modelAboutToBeDetached(Model *model)
|
|
|
|
{
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::modelAboutToBeDetached:", QString("filename %1").arg(model->fileUrl().toLocalFile()));
|
2013-07-31 15:45:09 +02:00
|
|
|
AbstractView::modelAboutToBeDetached(model);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::importsChanged(const QList<Import> &addedImports, const QList<Import> &removedImports)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QString message;
|
2016-12-01 10:25:26 +01:00
|
|
|
message += QString("added imports:") += lineBreak;
|
2013-03-14 16:02:19 +01:00
|
|
|
foreach (const Import &import, addedImports) {
|
2013-08-14 15:05:56 +02:00
|
|
|
message += import.toImportString() += lineBreak;
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
message += QString("removed imports:") += lineBreak;
|
2013-03-14 16:02:19 +01:00
|
|
|
foreach (const Import &import, removedImports) {
|
2013-08-14 15:05:56 +02:00
|
|
|
message += import.toImportString() += lineBreak;
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::importsChanged:", message);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::nodeCreated(const ModelNode &createdNode)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
message << createdNode;
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::nodeCreated:", message.readAll());
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::nodeAboutToBeRemoved(const ModelNode &removedNode)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
2015-07-15 11:58:27 +02:00
|
|
|
message << removedNode << lineBreak;
|
|
|
|
foreach (const ModelNode &modelNode, removedNode.allSubModelNodes()) {
|
2016-12-01 10:25:26 +01:00
|
|
|
message << "child node:" << modelNode << lineBreak;
|
2015-07-15 11:58:27 +02:00
|
|
|
}
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::nodeAboutToBeRemoved:", message.readAll());
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::nodeReparented(const ModelNode &node, const NodeAbstractProperty &newPropertyParent,
|
|
|
|
const NodeAbstractProperty &oldPropertyParent, AbstractView::PropertyChangeFlags propertyChange)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
message << node;
|
2016-12-01 10:25:26 +01:00
|
|
|
message << "new parent property:";
|
2013-03-14 16:02:19 +01:00
|
|
|
message << lineBreak;
|
|
|
|
message << newPropertyParent;
|
2016-12-01 10:25:26 +01:00
|
|
|
message << "old parent property:";
|
2013-03-14 16:02:19 +01:00
|
|
|
message << lineBreak;
|
|
|
|
message << oldPropertyParent;
|
2016-12-01 10:25:26 +01:00
|
|
|
message << "property change flag";
|
2013-03-14 16:02:19 +01:00
|
|
|
message << lineBreak;
|
|
|
|
message << propertyChange;
|
2016-12-01 10:25:26 +01:00
|
|
|
log(tr("::nodeReparented:"), message.readAll());
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::nodeIdChanged(const ModelNode &node, const QString &newId, const QString &oldId)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
message << node;
|
2016-12-01 10:25:26 +01:00
|
|
|
message << QString("new id:") << ' ' << newId << lineBreak;
|
|
|
|
message << QString("old id:") << ' ' << oldId << lineBreak;
|
|
|
|
log(tr("::nodeIdChanged:"), string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::propertiesAboutToBeRemoved(const QList<AbstractProperty> & /*propertyList*/)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::variantPropertiesChanged(const QList<VariantProperty> &propertyList,
|
|
|
|
AbstractView::PropertyChangeFlags /*propertyChange*/)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
foreach (const VariantProperty &property, propertyList) {
|
|
|
|
message << property;
|
|
|
|
}
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::variantPropertiesChanged:", string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::bindingPropertiesChanged(const QList<BindingProperty> &propertyList,
|
|
|
|
AbstractView::PropertyChangeFlags /*propertyChange*/)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
foreach (const BindingProperty &property, propertyList) {
|
|
|
|
message << property;
|
|
|
|
}
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::Binding properties changed:", string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-04-02 14:57:20 +02:00
|
|
|
void DebugView::signalHandlerPropertiesChanged(const QVector<SignalHandlerProperty> &propertyList, AbstractView::PropertyChangeFlags /*propertyChange*/)
|
2013-04-02 12:27:45 +02:00
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
foreach (const SignalHandlerProperty &property, propertyList) {
|
|
|
|
message << property;
|
|
|
|
}
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::signalHandlerPropertiesChanged:", string);
|
2013-04-02 12:27:45 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-03-14 16:02:19 +01:00
|
|
|
void DebugView::rootNodeTypeChanged(const QString &type, int majorVersion, int minorVersion)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QString message;
|
|
|
|
message += type;
|
2014-05-12 14:09:02 +02:00
|
|
|
message += QStringLiteral(" ");
|
2013-03-14 16:02:19 +01:00
|
|
|
message += QString::number(majorVersion);
|
2014-05-12 14:09:02 +02:00
|
|
|
message += QStringLiteral(" ");
|
2013-03-14 16:02:19 +01:00
|
|
|
message += QString::number(minorVersion);
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::rootNodeTypeChanged:", message);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-07 10:27:06 +02:00
|
|
|
void DebugView::selectedNodesChanged(const QList<ModelNode> &selectedNodes /*selectedNodeList*/,
|
2013-03-14 16:02:19 +01:00
|
|
|
const QList<ModelNode> & /*lastSelectedNodeList*/)
|
|
|
|
{
|
2014-08-07 10:27:06 +02:00
|
|
|
foreach (const ModelNode &selectedNode, selectedNodes) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
message << selectedNode;
|
2019-01-25 15:38:51 +01:00
|
|
|
message << " version: " << selectedNode.majorVersion() << '.' << selectedNode.minorVersion();
|
2019-01-09 18:29:20 +01:00
|
|
|
for (const VariantProperty &property : selectedNode.variantProperties())
|
|
|
|
message << property << lineBreak;
|
|
|
|
|
|
|
|
message << lineBreak;
|
|
|
|
|
2020-07-01 18:00:39 +02:00
|
|
|
if (selectedNode.metaInfo().isValid()) {
|
|
|
|
for (const NodeMetaInfo &metaInfo : selectedNode.metaInfo().classHierarchy())
|
|
|
|
message << metaInfo.typeName() << lineBreak;
|
|
|
|
|
|
|
|
message << lineBreak;
|
2020-07-09 20:19:22 +02:00
|
|
|
message << selectedNode.metaInfo().typeName();
|
|
|
|
message << lineBreak;
|
2020-10-05 19:27:29 +02:00
|
|
|
|
|
|
|
message << "Node Source" << selectedNode.nodeSource();
|
|
|
|
message << lineBreak;
|
|
|
|
|
|
|
|
message << "Is Component" << selectedNode.isComponent();
|
|
|
|
message << lineBreak;
|
|
|
|
|
|
|
|
message << "Node Source Type" << selectedNode.nodeSourceType();
|
|
|
|
message << lineBreak;
|
|
|
|
|
|
|
|
message << lineBreak;
|
|
|
|
|
2020-07-09 20:19:22 +02:00
|
|
|
for (const PropertyName &name : selectedNode.metaInfo().slotNames())
|
|
|
|
message << name << " ";
|
|
|
|
|
|
|
|
message << lineBreak;
|
2020-07-01 18:00:39 +02:00
|
|
|
}
|
|
|
|
|
2019-01-09 18:29:20 +01:00
|
|
|
const QHash<PropertyName, QVariant> data = selectedNode.auxiliaryData();
|
|
|
|
|
|
|
|
PropertyNameList names = data.keys();
|
|
|
|
Utils::sort(names);
|
|
|
|
for (const PropertyName &name : qAsConst(names)) {
|
|
|
|
message << name << ' ' << data.value(name).toString() << lineBreak;
|
2014-08-07 10:27:06 +02:00
|
|
|
}
|
2019-01-09 18:29:20 +01:00
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::selectedNodesChanged:", string);
|
2014-08-07 10:27:06 +02:00
|
|
|
}
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::scriptFunctionsChanged(const ModelNode & /*node*/, const QStringList & /*scriptFunctionList*/)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::propertiesRemoved(const QList<AbstractProperty> &propertyList)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
foreach (const AbstractProperty &property, propertyList) {
|
|
|
|
message << property;
|
|
|
|
}
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::propertiesRemoved:", string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::auxiliaryDataChanged(const ModelNode &node, const PropertyName &name, const QVariant &data)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
|
|
|
|
message << node;
|
|
|
|
message << name;
|
|
|
|
message << data.toString();
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::auxiliaryDataChanged:", string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-10 17:08:14 +01:00
|
|
|
void DebugView::documentMessagesChanged(const QList<DocumentMessage> &errors, const QList<DocumentMessage> &warnings)
|
2017-01-10 16:36:55 +01:00
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
|
2017-01-10 17:08:14 +01:00
|
|
|
foreach (const DocumentMessage &error, errors) {
|
2017-01-10 16:36:55 +01:00
|
|
|
message << error.toString();
|
|
|
|
}
|
|
|
|
|
2017-01-10 17:08:14 +01:00
|
|
|
foreach (const DocumentMessage &warning, warnings) {
|
2017-01-10 16:36:55 +01:00
|
|
|
message << warning.toString();
|
|
|
|
}
|
|
|
|
|
|
|
|
log("::documentMessageChanged:", string);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-03-14 16:02:19 +01:00
|
|
|
void DebugView::rewriterBeginTransaction()
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled())
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::rewriterBeginTransaction:", QString(), true);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::rewriterEndTransaction()
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled())
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::rewriterEndTransaction:", QString(), true);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
WidgetInfo DebugView::widgetInfo()
|
|
|
|
{
|
2018-07-24 23:56:45 +02:00
|
|
|
return createWidgetInfo(m_debugViewWidget.data(), nullptr, QStringLiteral("DebugView"), WidgetInfo::LeftPane, 0, tr("Debug View"));
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
bool DebugView::hasWidget() const
|
|
|
|
{
|
|
|
|
if (isDebugViewShown())
|
|
|
|
return true;
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-11-28 10:34:39 +01:00
|
|
|
void DebugView::instancePropertyChanged(const QList<QPair<ModelNode, PropertyName> > &propertyList)
|
2013-03-14 16:02:19 +01:00
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
|
2018-07-24 23:56:45 +02:00
|
|
|
using Pair = QPair<ModelNode, PropertyName>;
|
2013-03-14 16:02:19 +01:00
|
|
|
|
|
|
|
foreach (const Pair &pair, propertyList) {
|
|
|
|
message << pair.first;
|
|
|
|
message << lineBreak;
|
|
|
|
message << pair.second;
|
|
|
|
}
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
logInstance(":instancePropertyChanged::", string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-28 10:34:39 +01:00
|
|
|
void DebugView::instanceErrorChanged(const QVector<ModelNode> &/*errorNodeList*/)
|
2015-07-15 11:58:27 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2013-03-14 16:02:19 +01:00
|
|
|
void DebugView::instancesCompleted(const QVector<ModelNode> &completedNodeList)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
|
|
|
|
foreach (const ModelNode &modelNode, completedNodeList) {
|
2015-07-15 11:58:27 +02:00
|
|
|
message << modelNode << lineBreak;
|
|
|
|
if (QmlItemNode::isValidQmlItemNode(modelNode)) {
|
2016-12-01 10:25:26 +01:00
|
|
|
message << "parent: " << QmlItemNode(modelNode).instanceParent() << lineBreak;
|
2015-07-15 11:58:27 +02:00
|
|
|
}
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
logInstance(":instancesCompleted::", string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-28 10:34:39 +01:00
|
|
|
void DebugView::instanceInformationsChanged(const QMultiHash<ModelNode, InformationName> &informationChangedHash)
|
2013-03-14 16:02:19 +01:00
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
|
2016-11-28 10:34:39 +01:00
|
|
|
foreach (const ModelNode &modelNode, informationChangedHash.keys()) {
|
2013-03-14 16:02:19 +01:00
|
|
|
message << modelNode;
|
2016-11-28 10:34:39 +01:00
|
|
|
message << informationChangedHash.value(modelNode);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
logInstance("::instanceInformationsChanged:", string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::instancesRenderImageChanged(const QVector<ModelNode> & /*nodeList*/)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::instancesPreviewImageChanged(const QVector<ModelNode> & /*nodeList*/)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-07-15 11:58:27 +02:00
|
|
|
void DebugView::instancesChildrenChanged(const QVector<ModelNode> & nodeList)
|
2013-03-14 16:02:19 +01:00
|
|
|
{
|
2015-07-15 11:58:27 +02:00
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
|
|
|
|
foreach (const ModelNode &modelNode, nodeList) {
|
|
|
|
message << modelNode << lineBreak;
|
|
|
|
if (QmlItemNode::isValidQmlItemNode(modelNode)) {
|
2016-12-01 10:25:26 +01:00
|
|
|
message << "parent: " << QmlItemNode(modelNode).instanceParent() << lineBreak;
|
2015-07-15 11:58:27 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
logInstance("::instancesChildrenChanged:", string);
|
2015-07-15 11:58:27 +02:00
|
|
|
}
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::customNotification(const AbstractView *view, const QString &identifier, const QList<ModelNode> &nodeList, const QList<QVariant> &data)
|
|
|
|
{
|
2020-08-21 17:18:53 +02:00
|
|
|
if (isDebugViewEnabled()) {
|
2013-03-14 16:02:19 +01:00
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
|
|
|
|
message << view;
|
|
|
|
message << identifier;
|
|
|
|
foreach (const ModelNode &node, nodeList) {
|
|
|
|
message << node;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach (const QVariant &variant, data) {
|
|
|
|
message << variant.toString();
|
|
|
|
}
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::customNotification:", string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::nodeSourceChanged(const ModelNode &modelNode, const QString &newNodeSource)
|
|
|
|
{
|
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
|
|
|
|
message << modelNode;
|
|
|
|
message << newNodeSource;
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::nodeSourceChanged:", string);
|
2013-03-14 16:02:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-07-15 11:58:27 +02:00
|
|
|
void DebugView::nodeRemoved(const ModelNode &removedNode, const NodeAbstractProperty &/*parentProperty*/, AbstractView::PropertyChangeFlags /*propertyChange*/)
|
2013-07-24 15:57:06 +02:00
|
|
|
{
|
2015-07-15 11:58:27 +02:00
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
2013-07-24 15:57:06 +02:00
|
|
|
|
2015-07-15 11:58:27 +02:00
|
|
|
message << removedNode;
|
|
|
|
|
2016-12-01 10:25:26 +01:00
|
|
|
log("::nodeRemoved:", string);
|
2015-07-15 11:58:27 +02:00
|
|
|
}
|
2013-07-24 15:57:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::nodeAboutToBeReparented(const ModelNode &/*node*/, const NodeAbstractProperty &/*newPropertyParent*/, const NodeAbstractProperty &/*oldPropertyParent*/, AbstractView::PropertyChangeFlags /*propertyChange*/)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::instancesToken(const QString &/*tokenName*/, int /*tokenNumber*/, const QVector<ModelNode> &/*nodeVector*/)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-07-31 15:19:18 +02:00
|
|
|
void DebugView::currentStateChanged(const ModelNode &/*node*/)
|
2013-07-24 15:57:06 +02:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-03-07 17:37:23 +01:00
|
|
|
void DebugView::nodeOrderChanged(const NodeListProperty &listProperty, const ModelNode &movedNode, int oldIndex)
|
2013-07-24 15:57:06 +02:00
|
|
|
{
|
2017-03-07 17:37:23 +01:00
|
|
|
if (isDebugViewEnabled()) {
|
|
|
|
QTextStream message;
|
|
|
|
QString string;
|
|
|
|
message.setString(&string);
|
|
|
|
|
|
|
|
message << movedNode << listProperty;
|
|
|
|
message << oldIndex << "to" << listProperty.indexOf(movedNode);
|
2013-07-24 15:57:06 +02:00
|
|
|
|
2017-03-07 17:37:23 +01:00
|
|
|
log("::nodeSlide:", string);
|
|
|
|
}
|
2013-07-24 15:57:06 +02:00
|
|
|
}
|
|
|
|
|
2013-03-14 16:02:19 +01:00
|
|
|
void DebugView::log(const QString &title, const QString &message, bool highlight)
|
|
|
|
{
|
|
|
|
m_debugViewWidget->addLogMessage(title, message, highlight);
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugView::logInstance(const QString &title, const QString &message, bool highlight)
|
|
|
|
{
|
|
|
|
m_debugViewWidget->addLogInstanceMessage(title, message, highlight);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namesapce Internal
|
|
|
|
|
|
|
|
} // namespace QmlDesigner
|