WebAssembly: Move the device infobar setup to the device files

Change-Id: I201c0f1dba59530e9e8183cb24974baed049196e
Reviewed-by: Alessandro Portale <alessandro.portale@qt.io>
This commit is contained in:
hjk
2023-11-24 15:41:43 +01:00
parent e729c37d95
commit da15f6fa0c
3 changed files with 41 additions and 47 deletions

View File

@@ -1,13 +1,27 @@
// Copyright (C) 2019 The Qt Company Ltd. // Copyright (C) 2019 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#include "webassemblyconstants.h"
#include "webassemblydevice.h" #include "webassemblydevice.h"
#include "webassemblyconstants.h"
#include "webassemblyqtversion.h"
#include "webassemblytoolchain.h"
#include "webassemblytr.h" #include "webassemblytr.h"
#include <coreplugin/coreconstants.h>
#include <coreplugin/icontext.h>
#include <coreplugin/icore.h>
#include <projectexplorer/devicesupport/desktopdevice.h> #include <projectexplorer/devicesupport/desktopdevice.h>
#include <projectexplorer/devicesupport/idevicefactory.h> #include <projectexplorer/devicesupport/idevicefactory.h>
#include <projectexplorer/devicesupport/devicemanager.h>
#include <projectexplorer/kitmanager.h>
#include <utils/infobar.h>
#include <QTimer>
using namespace Core;
using namespace ProjectExplorer; using namespace ProjectExplorer;
using namespace Utils; using namespace Utils;
@@ -30,11 +44,31 @@ public:
} }
}; };
IDevicePtr createWebAssemblyDevice() static IDevicePtr createWebAssemblyDevice()
{ {
return IDevicePtr(new WebAssemblyDevice); return IDevicePtr(new WebAssemblyDevice);
} }
static void askUserAboutEmSdkSetup()
{
const char setupWebAssemblyEmSdk[] = "SetupWebAssemblyEmSdk";
if (!ICore::infoBar()->canInfoBeAdded(setupWebAssemblyEmSdk)
|| !WebAssemblyQtVersion::isQtVersionInstalled()
|| WebAssemblyToolChain::areToolChainsRegistered())
return;
InfoBarEntry info(setupWebAssemblyEmSdk,
Tr::tr("Setup Emscripten SDK for WebAssembly? "
"To do it later, select Edit > Preferences > Devices > WebAssembly."),
InfoBarEntry::GlobalSuppression::Enabled);
info.addCustomButton(Tr::tr("Setup Emscripten SDK"), [setupWebAssemblyEmSdk] {
ICore::infoBar()->removeInfo(setupWebAssemblyEmSdk);
QTimer::singleShot(0, []() { ICore::showOptionsDialog(Constants::SETTINGS_ID); });
});
ICore::infoBar()->addInfo(info);
}
class WebAssemblyDeviceFactory final : public IDeviceFactory class WebAssemblyDeviceFactory final : public IDeviceFactory
{ {
public: public:
@@ -52,6 +86,11 @@ public:
void setupWebAssemblyDevice() void setupWebAssemblyDevice()
{ {
static WebAssemblyDeviceFactory theWebAssemblyDeviceFactory; static WebAssemblyDeviceFactory theWebAssemblyDeviceFactory;
QObject::connect(KitManager::instance(), &KitManager::kitsLoaded, [] {
DeviceManager::instance()->addDevice(createWebAssemblyDevice());
askUserAboutEmSdkSetup();
});
} }
} // WebAssembly::Internal } // WebAssembly::Internal

View File

@@ -3,12 +3,8 @@
#pragma once #pragma once
#include <projectexplorer/devicesupport/idevicefwd.h>
namespace WebAssembly::Internal { namespace WebAssembly::Internal {
ProjectExplorer::IDevicePtr createWebAssemblyDevice();
void setupWebAssemblyDevice(); void setupWebAssemblyDevice();
} // WebAssembly::Interenal } // WebAssembly::Interenal

View File

@@ -6,52 +6,18 @@
#ifdef WITH_TESTS #ifdef WITH_TESTS
#include "webassembly_test.h" #include "webassembly_test.h"
#endif // WITH_TESTS #endif // WITH_TESTS
#include "webassemblyconstants.h"
#include "webassemblydevice.h" #include "webassemblydevice.h"
#include "webassemblyqtversion.h" #include "webassemblyqtversion.h"
#include "webassemblyrunconfiguration.h" #include "webassemblyrunconfiguration.h"
#include "webassemblytoolchain.h" #include "webassemblytoolchain.h"
#include "webassemblytr.h"
#include <coreplugin/coreconstants.h>
#include <coreplugin/icontext.h>
#include <coreplugin/icore.h>
#include <extensionsystem/iplugin.h> #include <extensionsystem/iplugin.h>
#include <projectexplorer/devicesupport/devicemanager.h>
#include <projectexplorer/kitmanager.h>
#include <utils/infobar.h>
#include <QTimer>
using namespace Core;
using namespace ProjectExplorer; using namespace ProjectExplorer;
using namespace Utils; using namespace Utils;
namespace WebAssembly::Internal { namespace WebAssembly::Internal {
static void askUserAboutEmSdkSetup()
{
const char setupWebAssemblyEmSdk[] = "SetupWebAssemblyEmSdk";
if (!ICore::infoBar()->canInfoBeAdded(setupWebAssemblyEmSdk)
|| !WebAssemblyQtVersion::isQtVersionInstalled()
|| WebAssemblyToolChain::areToolChainsRegistered())
return;
InfoBarEntry info(setupWebAssemblyEmSdk,
Tr::tr("Setup Emscripten SDK for WebAssembly? "
"To do it later, select Edit > Preferences > Devices > WebAssembly."),
InfoBarEntry::GlobalSuppression::Enabled);
info.addCustomButton(Tr::tr("Setup Emscripten SDK"), [setupWebAssemblyEmSdk] {
ICore::infoBar()->removeInfo(setupWebAssemblyEmSdk);
QTimer::singleShot(0, []() { ICore::showOptionsDialog(Constants::SETTINGS_ID); });
});
ICore::infoBar()->addInfo(info);
}
class WebAssemblyPlugin final : public ExtensionSystem::IPlugin class WebAssemblyPlugin final : public ExtensionSystem::IPlugin
{ {
Q_OBJECT Q_OBJECT
@@ -69,13 +35,6 @@ public:
addTest<WebAssemblyTest>(); addTest<WebAssemblyTest>();
#endif // WITH_TESTS #endif // WITH_TESTS
} }
void extensionsInitialized() final
{
connect(KitManager::instance(), &KitManager::kitsLoaded, this, [] {
DeviceManager::instance()->addDevice(createWebAssemblyDevice());
askUserAboutEmSdkSetup();
});
}
}; };
} // WebAssembly::Internal } // WebAssembly::Internal