X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmonoapplication.cpp;h=60df4c5b94c3a367dd8a4808acee58f8f799b716;hp=7b05c734ec690bb155a9f4bda40b7d19a61078e7;hb=1d9dfeff6b2531ff99e0d12669b3a1dae393e768;hpb=299541db5d6586c0b09e036816dfd28477ebc249 diff --git a/src/qtui/monoapplication.cpp b/src/qtui/monoapplication.cpp index 7b05c734..60df4c5b 100644 --- a/src/qtui/monoapplication.cpp +++ b/src/qtui/monoapplication.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel IRC Team * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -21,23 +21,30 @@ #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) + : QtUiApplication(argc, argv), + _internalInitDone(false) { _internal = new CoreApplicationInternal(); // needed for parser options - setRunMode(Monolithic); +#if defined(HAVE_KDE) || defined(Q_OS_MAC) + disableCrashhandler(); +#endif /* HAVE_KDE || Q_OS_MAC */ + setRunMode(Quassel::Monolithic); } bool MonolithicApplication::init() { - connect(Client::instance(), SIGNAL(newClientSyncer(ClientSyncer *)), this, SLOT(newClientSyncer(ClientSyncer *))); - if(QtUiApplication::init()) { - return true; + if(!Quassel::init()) // parse args + return false; + + if(isOptionSet("port")) { + _internal->init(); + _internalInitDone = true; } - return false; + + return QtUiApplication::init(); } MonolithicApplication::~MonolithicApplication() { @@ -46,14 +53,12 @@ MonolithicApplication::~MonolithicApplication() { delete _internal; } -void MonolithicApplication::newClientSyncer(ClientSyncer *syncer) { - connect(syncer, SIGNAL(startInternalCore()), this, SLOT(startInternalCore())); -} - void MonolithicApplication::startInternalCore() { - _internal->init(); + 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 &))); + //connect(syncer, SIGNAL(connectToInternalCore(SignalProxy *)), core, SLOT(setupInternalClientSession(SignalProxy *))); + //connect(core, SIGNAL(sessionState(const QVariant &)), syncer, SLOT(internalSessionStateReceived(const QVariant &))); }