From f4ae0007ac4524612ae73a778ca491659cf22393 Mon Sep 17 00:00:00 2001 From: Marcus Eggenberger Date: Tue, 21 Oct 2008 00:09:08 +0200 Subject: [PATCH] starting the internal core on demand client no longer depends on core... *sigh* --- src/client/clientsyncer.cpp | 9 --------- src/qtui/coreconnectdlg.cpp | 9 +++++++++ src/qtui/monoapplication.cpp | 22 +++++++++++++++++----- src/qtui/monoapplication.h | 16 +++++++++------- 4 files changed, 35 insertions(+), 21 deletions(-) diff --git a/src/client/clientsyncer.cpp b/src/client/clientsyncer.cpp index a5a64d74..655875ff 100644 --- a/src/client/clientsyncer.cpp +++ b/src/client/clientsyncer.cpp @@ -33,10 +33,6 @@ #include "quassel.h" #include "signalproxy.h" -//#ifdef BUILD_MONO -#include "core.h" -//#endif - ClientSyncer::ClientSyncer(QObject *parent) : QObject(parent) { @@ -44,11 +40,6 @@ ClientSyncer::ClientSyncer(QObject *parent) blockSize = 0; connect(Client::signalProxy(), SIGNAL(disconnected()), this, SLOT(coreSocketDisconnected())); - - //#ifdef BUILD_MONO - connect(this, SIGNAL(connectToInternalCore(SignalProxy *)), Core::instance(), SLOT(setupInternalClientSession(SignalProxy *))); - connect(Core::instance(), SIGNAL(sessionState(const QVariant &)), this, SLOT(internalSessionStateReceived(const QVariant &))); - //#endif } ClientSyncer::~ClientSyncer() { diff --git a/src/qtui/coreconnectdlg.cpp b/src/qtui/coreconnectdlg.cpp index a7e39396..6903d937 100644 --- a/src/qtui/coreconnectdlg.cpp +++ b/src/qtui/coreconnectdlg.cpp @@ -28,6 +28,7 @@ #include "clientsyncer.h" #include "coreconfigwizard.h" #include "iconloader.h" +#include "monoapplication.h" CoreConnectDlg::CoreConnectDlg(bool autoconnect, QWidget *parent) : QDialog(parent) @@ -43,6 +44,7 @@ CoreConnectDlg::CoreConnectDlg(bool autoconnect, QWidget *parent) setWindowFlags(Qt::Sheet); clientSyncer = new ClientSyncer(this); + wizard = 0; doingAutoConnect = false; @@ -212,6 +214,13 @@ void CoreConnectDlg::on_accountButtonBox_accepted() { } void CoreConnectDlg::on_useInternalCore_clicked() { + // FIXME: this needs to be a qobject_cast - therefore MonolithicApplication needs to be a proper QObject... :/ + MonolithicApplication *monoApp = static_cast(QApplication::instance()); + if(monoApp) { + qDebug() << "starting core..."; + monoApp->startInternalCore(); + monoApp->connectClientSyncer(clientSyncer); + } clientSyncer->useInternalCore(); startSync(); } 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 &))); +} diff --git a/src/qtui/monoapplication.h b/src/qtui/monoapplication.h index 59d3747d..40503424 100644 --- a/src/qtui/monoapplication.h +++ b/src/qtui/monoapplication.h @@ -23,18 +23,20 @@ #include "qtuiapplication.h" +class ClientSyncer; class CoreApplicationInternal; class MonolithicApplication : public QtUiApplication { +public: + MonolithicApplication(int &, char **); + ~MonolithicApplication(); - public: - MonolithicApplication(int &, char **); - ~MonolithicApplication(); + bool init(); + bool startInternalCore(); + void connectClientSyncer(ClientSyncer *syncer); - bool init(); - - private: - CoreApplicationInternal *_internal; +private: + CoreApplicationInternal *_internal; }; #endif -- 2.20.1