X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=main%2Fmain_mono.cpp;h=584c220798a7acfeefe4ae0c871edc97ccb01bbb;hb=a37f958a6db77af048619b4af1553ef47dca295f;hp=b935a12842fa8a7a256bb34443b6d6ef8ade45f2;hpb=84516825d33a1b448a894eaf2e804cabb032f5f1;p=quassel.git diff --git a/main/main_mono.cpp b/main/main_mono.cpp index b935a128..584c2207 100644 --- a/main/main_mono.cpp +++ b/main/main_mono.cpp @@ -23,38 +23,71 @@ #include #include "core.h" -#include "quassel.h" -#include "logger.h" -#include "proxy.h" +#include "style.h" +#include "global.h" +#include "guiproxy.h" +#include "coreproxy.h" +#include "settings.h" +#include "chatwidget.h" #include "mainwin.h" int main(int argc, char **argv) { - - Quassel::init(); - Logger *logger = new Logger(); - Quassel::setLogger(logger); - QApplication app(argc, argv); - QApplication::setOrganizationDomain("quassel-irc.org"); QApplication::setApplicationName("Quassel IRC"); QApplication::setOrganizationName("The Quassel Team"); - Core::init(); + qRegisterMetaType("LayoutTask"); + + Global::runMode = Global::Monolithic; + Global::quasselDir = QDir::homePath() + "/.quassel"; + + //settings = new Settings(); + global = new Global(); + guiProxy = new GUIProxy(); + coreProxy = new CoreProxy(); + + Settings::init(); + Style::init(); - MainWin mainWin; - mainWin.show(); - return app.exec(); + MainWin *mainWin = new MainWin(); + mainWin->show(); + mainWin->init(); + int exitCode = app.exec(); + delete core; + delete guiProxy; + delete coreProxy; + delete global; + delete mainWin; + //delete settings; + return exitCode; } -QVariant proxyConnect(uint func, QVariant arg) { - using namespace Proxy; +void MainWin::syncToCore() { + Q_ASSERT(global->getData("CoreReady").toBool()); + coreBackLog = core->getBackLog(); + // NOTE: We don't need to request server states, because in the monolithic version there can't be + // any servers connected at this stage... +} + +void CoreProxy::sendToGUI(CoreSignal sig, QVariant arg1, QVariant arg2, QVariant arg3) { + guiProxy->recv(sig, arg1, arg2, arg3); +} - switch(func) { - case LOAD_IDENTITIES: return (QVariant) CoreProxy::loadIdentities(); - case STORE_IDENTITIES: CoreProxy::storeIdentities(arg.toMap()); return 0; +GUIProxy::GUIProxy() { + if(guiProxy) qFatal("Trying to instantiate more than one CoreProxy object!"); +} - } - return 0; +void GUIProxy::send(GUISignal sig, QVariant arg1, QVariant arg2, QVariant arg3) { + coreProxy->recv(sig, arg1, arg2, arg3); } + +// Dummy function definitions +// These are not needed, since we don't have a network connection to the core. +void GUIProxy::serverHasData() {} +void GUIProxy::connectToCore(QString, quint16) {} +void GUIProxy::disconnectFromCore() {} +void GUIProxy::updateCoreData(QString) {} +void GUIProxy::serverError(QAbstractSocket::SocketError) {} +