forked from quickshell/quickshell
core/reloader: do not require ShellRoot
This commit is contained in:
parent
2996e40ff9
commit
c21df95087
|
@ -124,7 +124,10 @@ void EngineGeneration::onReload(EngineGeneration* old) {
|
|||
QObject::connect(this->engine, &QQmlEngine::quit, this, &EngineGeneration::quit);
|
||||
QObject::connect(this->engine, &QQmlEngine::exit, this, &EngineGeneration::exit);
|
||||
|
||||
this->root->reload(old == nullptr ? nullptr : old->root);
|
||||
if (auto* reloadable = qobject_cast<Reloadable*>(this->root)) {
|
||||
reloadable->reload(old ? old->root : nullptr);
|
||||
}
|
||||
|
||||
this->singletonRegistry.onReload(old == nullptr ? nullptr : &old->singletonRegistry);
|
||||
this->reloadComplete = true;
|
||||
emit this->reloadFinished();
|
||||
|
|
|
@ -13,7 +13,6 @@
|
|||
#include "incubator.hpp"
|
||||
#include "qsintercept.hpp"
|
||||
#include "scan.hpp"
|
||||
#include "shell.hpp"
|
||||
#include "singleton.hpp"
|
||||
|
||||
class RootWrapper;
|
||||
|
@ -58,7 +57,7 @@ public:
|
|||
QsUrlInterceptor urlInterceptor;
|
||||
QsInterceptNetworkAccessManagerFactory interceptNetFactory;
|
||||
QQmlEngine* engine = nullptr;
|
||||
ShellRoot* root = nullptr;
|
||||
QObject* root = nullptr;
|
||||
SingletonRegistry singletonRegistry;
|
||||
QFileSystemWatcher* watcher = nullptr;
|
||||
QVector<QString> deletedWatchedFiles;
|
||||
|
|
|
@ -14,7 +14,6 @@
|
|||
#include "generation.hpp"
|
||||
#include "qmlglobal.hpp"
|
||||
#include "scan.hpp"
|
||||
#include "shell.hpp"
|
||||
|
||||
RootWrapper::RootWrapper(QString rootPath, QString shellId)
|
||||
: QObject(nullptr)
|
||||
|
@ -60,9 +59,9 @@ void RootWrapper::reloadGraph(bool hard) {
|
|||
url.setScheme("qsintercept");
|
||||
auto component = QQmlComponent(generation->engine, url);
|
||||
|
||||
auto* obj = component.beginCreate(generation->engine->rootContext());
|
||||
auto* newRoot = component.beginCreate(generation->engine->rootContext());
|
||||
|
||||
if (obj == nullptr) {
|
||||
if (newRoot == nullptr) {
|
||||
const QString error = "failed to create root component\n" + component.errorString();
|
||||
qWarning().noquote() << error;
|
||||
generation->destroy();
|
||||
|
@ -74,20 +73,6 @@ void RootWrapper::reloadGraph(bool hard) {
|
|||
return;
|
||||
}
|
||||
|
||||
auto* newRoot = qobject_cast<ShellRoot*>(obj);
|
||||
if (newRoot == nullptr) {
|
||||
const QString error = "root component was not a Quickshell.ShellRoot";
|
||||
qWarning().noquote() << error;
|
||||
delete obj;
|
||||
generation->destroy();
|
||||
|
||||
if (this->generation != nullptr && this->generation->qsgInstance != nullptr) {
|
||||
emit this->generation->qsgInstance->reloadFailed(error);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
generation->root = newRoot;
|
||||
|
||||
component.completeCreate();
|
||||
|
|
Loading…
Reference in a new issue