X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmonoapplication.cpp;h=a63ec55811cf7011f1158fb5b78c998a286ad11f;hp=97688f2a94df54eccbf3e7758b60cdd93955ddc8;hb=6d73c621230ed8027bbafbd49a1953ee36e1fe0f;hpb=f4ae0007ac4524612ae73a778ca491659cf22393 diff --git a/src/qtui/monoapplication.cpp b/src/qtui/monoapplication.cpp index 97688f2a..a63ec558 100644 --- a/src/qtui/monoapplication.cpp +++ b/src/qtui/monoapplication.cpp @@ -26,17 +26,24 @@ #include "qtui.h" MonolithicApplication::MonolithicApplication(int &argc, char **argv) - : QtUiApplication(argc, argv) + : QtUiApplication(argc, argv), + _internalInitDone(false) { _internal = new CoreApplicationInternal(); // needed for parser options setRunMode(Monolithic); } bool MonolithicApplication::init() { - if(Quassel::init()) { - return QtUiApplication::init(); + if(!Quassel::init()) // parse args + return false; + + if(isOptionSet("port")) { + _internal->init(); + _internalInitDone = true; } - return false; + + connect(Client::instance(), SIGNAL(newClientSyncer(ClientSyncer *)), this, SLOT(newClientSyncer(ClientSyncer *))); + return QtUiApplication::init(); } MonolithicApplication::~MonolithicApplication() { @@ -45,12 +52,17 @@ MonolithicApplication::~MonolithicApplication() { delete _internal; } -bool MonolithicApplication::startInternalCore() { - return _internal->init(); +void MonolithicApplication::newClientSyncer(ClientSyncer *syncer) { + connect(syncer, SIGNAL(startInternalCore()), this, SLOT(startInternalCore())); } -void MonolithicApplication::connectClientSyncer(ClientSyncer *syncer) { +void MonolithicApplication::startInternalCore() { + if(!_internalInitDone) { + _internal->init(); + _internalInitDone = true; + } Core *core = Core::instance(); + ClientSyncer *syncer = static_cast(sender()); connect(syncer, SIGNAL(connectToInternalCore(SignalProxy *)), core, SLOT(setupInternalClientSession(SignalProxy *))); connect(core, SIGNAL(sessionState(const QVariant &)), syncer, SLOT(internalSessionStateReceived(const QVariant &))); }