X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmonoapplication.cpp;h=97688f2a94df54eccbf3e7758b60cdd93955ddc8;hp=aebe619aa1e0163759372859a4651236a0184760;hb=f4ae0007ac4524612ae73a778ca491659cf22393;hpb=cc0cad583046c34cb1296329016e1834995d171d diff --git a/src/qtui/monoapplication.cpp b/src/qtui/monoapplication.cpp index aebe619a..97688f2a 100644 --- a/src/qtui/monoapplication.cpp +++ b/src/qtui/monoapplication.cpp @@ -21,16 +21,19 @@ #include "monoapplication.h" #include "coreapplication.h" #include "client.h" +#include "clientsyncer.h" +#include "core.h" #include "qtui.h" -MonolithicApplication::MonolithicApplication(int &argc, char **argv) : QtUiApplication(argc, argv) { +MonolithicApplication::MonolithicApplication(int &argc, char **argv) + : QtUiApplication(argc, argv) +{ + _internal = new CoreApplicationInternal(); // needed for parser options setRunMode(Monolithic); - _internal = new CoreApplicationInternal(); - } bool MonolithicApplication::init() { - if(Quassel::init() && _internal->init()) { + if(Quassel::init()) { return QtUiApplication::init(); } return false; @@ -39,6 +42,15 @@ bool MonolithicApplication::init() { MonolithicApplication::~MonolithicApplication() { // Client needs to be destroyed first Client::destroy(); - delete _internal; } + +bool MonolithicApplication::startInternalCore() { + return _internal->init(); +} + +void MonolithicApplication::connectClientSyncer(ClientSyncer *syncer) { + Core *core = Core::instance(); + connect(syncer, SIGNAL(connectToInternalCore(SignalProxy *)), core, SLOT(setupInternalClientSession(SignalProxy *))); + connect(core, SIGNAL(sessionState(const QVariant &)), syncer, SLOT(internalSessionStateReceived(const QVariant &))); +}