2022-08-19 15:59:36 +02:00
|
|
|
// Copyright (C) 2016 The Qt Company Ltd.
|
2022-12-21 10:12:09 +01:00
|
|
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
|
2015-08-28 12:50:46 +02:00
|
|
|
|
|
|
|
|
#include "qmlprofilerconstants.h"
|
2021-04-06 16:44:18 +02:00
|
|
|
#include "qmlprofilerplugin.h"
|
2022-08-30 20:37:31 +02:00
|
|
|
#include "qmlprofilersettings.h"
|
|
|
|
|
#include "qmlprofilertr.h"
|
2015-08-28 12:50:46 +02:00
|
|
|
|
|
|
|
|
#include <coreplugin/icore.h>
|
|
|
|
|
|
2021-04-06 16:44:18 +02:00
|
|
|
#include <debugger/analyzer/analyzericons.h>
|
2023-02-09 11:43:49 +01:00
|
|
|
#include <debugger/debuggertr.h>
|
2021-04-06 16:44:18 +02:00
|
|
|
|
|
|
|
|
#include <utils/layoutbuilder.h>
|
|
|
|
|
|
2015-08-28 12:50:46 +02:00
|
|
|
#include <QSettings>
|
|
|
|
|
|
2021-04-06 16:44:18 +02:00
|
|
|
using namespace Utils;
|
|
|
|
|
|
2023-04-20 10:58:51 +02:00
|
|
|
namespace QmlProfiler::Internal {
|
2015-08-28 12:50:46 +02:00
|
|
|
|
2023-04-20 10:58:51 +02:00
|
|
|
class QmlProfilerOptionsPageWidget : public Core::IOptionsPageWidget
|
2015-08-28 12:50:46 +02:00
|
|
|
{
|
2023-04-20 10:58:51 +02:00
|
|
|
public:
|
|
|
|
|
explicit QmlProfilerOptionsPageWidget(QmlProfilerSettings *settings)
|
|
|
|
|
{
|
|
|
|
|
QmlProfilerSettings &s = *settings;
|
|
|
|
|
|
|
|
|
|
using namespace Layouting;
|
|
|
|
|
Form {
|
|
|
|
|
s.flushEnabled,
|
|
|
|
|
s.flushInterval,
|
|
|
|
|
s.aggregateTraces
|
|
|
|
|
}.attachTo(this);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void apply() final
|
|
|
|
|
{
|
|
|
|
|
QmlProfilerPlugin::globalSettings()->writeGlobalSettings();
|
|
|
|
|
}
|
|
|
|
|
};
|
2015-08-28 12:50:46 +02:00
|
|
|
|
2021-04-06 16:44:18 +02:00
|
|
|
QmlProfilerSettings::QmlProfilerSettings()
|
2015-08-28 12:50:46 +02:00
|
|
|
{
|
2023-04-20 10:58:51 +02:00
|
|
|
setConfigWidgetCreator([this] { return new QmlProfilerOptionsPageWidget(this); });
|
2021-04-06 16:44:18 +02:00
|
|
|
|
2021-04-06 18:35:27 +02:00
|
|
|
setSettingsGroup(Constants::ANALYZER);
|
2021-04-06 16:44:18 +02:00
|
|
|
|
2021-04-06 18:35:27 +02:00
|
|
|
registerAspect(&flushEnabled);
|
2021-04-06 16:44:18 +02:00
|
|
|
flushEnabled.setSettingsKey("Analyzer.QmlProfiler.FlushEnabled");
|
|
|
|
|
flushEnabled.setLabelPlacement(BoolAspect::LabelPlacement::InExtraLabel);
|
2022-08-30 20:37:31 +02:00
|
|
|
flushEnabled.setLabelText(Tr::tr("Flush data while profiling:"));
|
|
|
|
|
flushEnabled.setToolTip(Tr::tr(
|
2021-04-06 16:44:18 +02:00
|
|
|
"Periodically flush pending data to the profiler. This reduces the delay when loading the\n"
|
|
|
|
|
"data and the memory usage in the application. It distorts the profile as the flushing\n"
|
|
|
|
|
"itself takes time."));
|
|
|
|
|
|
2021-04-06 18:35:27 +02:00
|
|
|
registerAspect(&flushInterval);
|
2021-04-06 16:44:18 +02:00
|
|
|
flushInterval.setSettingsKey("Analyzer.QmlProfiler.FlushInterval");
|
|
|
|
|
flushInterval.setRange(1, 10000000);
|
|
|
|
|
flushInterval.setDefaultValue(1000);
|
2022-08-30 20:37:31 +02:00
|
|
|
flushInterval.setLabelText(Tr::tr("Flush interval (ms):"));
|
2021-04-12 13:43:24 +02:00
|
|
|
flushInterval.setEnabler(&flushEnabled);
|
2021-04-06 16:44:18 +02:00
|
|
|
|
2021-04-06 18:35:27 +02:00
|
|
|
registerAspect(&lastTraceFile);
|
2021-04-06 16:44:18 +02:00
|
|
|
lastTraceFile.setSettingsKey("Analyzer.QmlProfiler.LastTraceFile");
|
|
|
|
|
|
2021-04-06 18:35:27 +02:00
|
|
|
registerAspect(&aggregateTraces);
|
2021-04-06 16:44:18 +02:00
|
|
|
aggregateTraces.setSettingsKey("Analyzer.QmlProfiler.AggregateTraces");
|
|
|
|
|
aggregateTraces.setLabelPlacement(BoolAspect::LabelPlacement::InExtraLabel);
|
2022-08-30 20:37:31 +02:00
|
|
|
aggregateTraces.setLabelText(Tr::tr("Process data only when process ends:"));
|
|
|
|
|
aggregateTraces.setToolTip(Tr::tr(
|
2021-04-06 16:44:18 +02:00
|
|
|
"Only process data when the process being profiled ends, not when the current recording\n"
|
|
|
|
|
"session ends. This way multiple recording sessions can be aggregated in a single trace,\n"
|
|
|
|
|
"for example if multiple QML engines start and stop sequentially during a single run of\n"
|
|
|
|
|
"the program."));
|
|
|
|
|
|
|
|
|
|
// Read stored values
|
2021-04-06 18:35:27 +02:00
|
|
|
readSettings(Core::ICore::settings());
|
2015-08-28 12:50:46 +02:00
|
|
|
}
|
|
|
|
|
|
2021-04-06 16:44:18 +02:00
|
|
|
void QmlProfilerSettings::writeGlobalSettings() const
|
2015-08-28 12:50:46 +02:00
|
|
|
{
|
2021-04-06 18:35:27 +02:00
|
|
|
writeSettings(Core::ICore::settings());
|
2015-08-28 12:50:46 +02:00
|
|
|
}
|
|
|
|
|
|
2021-04-06 16:44:18 +02:00
|
|
|
// QmlProfilerOptionsPage
|
2015-11-18 12:34:52 +01:00
|
|
|
|
2021-04-06 16:44:18 +02:00
|
|
|
QmlProfilerOptionsPage::QmlProfilerOptionsPage()
|
2015-11-18 12:34:52 +01:00
|
|
|
{
|
2021-04-06 16:44:18 +02:00
|
|
|
setId(Constants::SETTINGS);
|
2022-08-30 20:37:31 +02:00
|
|
|
setDisplayName(Tr::tr("QML Profiler"));
|
2021-04-06 16:44:18 +02:00
|
|
|
setCategory("T.Analyzer");
|
2023-02-09 11:43:49 +01:00
|
|
|
setDisplayCategory(::Debugger::Tr::tr("Analyzer"));
|
2021-04-06 16:44:18 +02:00
|
|
|
setCategoryIconPath(Analyzer::Icons::SETTINGSCATEGORY_ANALYZER);
|
2023-04-20 10:58:51 +02:00
|
|
|
setWidgetCreator([] {
|
|
|
|
|
return new QmlProfilerOptionsPageWidget(QmlProfilerPlugin::globalSettings());
|
|
|
|
|
});
|
2015-11-18 12:34:52 +01:00
|
|
|
}
|
|
|
|
|
|
2023-04-20 10:58:51 +02:00
|
|
|
} // QmlProfiler::Internal
|