X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=main%2Fmain_gui.cpp;h=f48f615c4abca5172c3134c5f812a636c607e132;hp=0355811119c42d33c9ad9e617e39b5838af93158;hb=8fc3a498f754f34b21d2a163e2a28323dae384cb;hpb=ba8f57d654b07d77cc91a2b901ad3b664a31ffcf diff --git a/main/main_gui.cpp b/main/main_gui.cpp index 03558111..f48f615c 100644 --- a/main/main_gui.cpp +++ b/main/main_gui.cpp @@ -20,11 +20,15 @@ #include +#include #include +#include "style.h" #include "global.h" #include "guiproxy.h" +#include "coreconnectdlg.h" #include "util.h" +#include "chatwidget.h" #include "mainwin.h" @@ -35,13 +39,54 @@ int main(int argc, char **argv) { QApplication::setOrganizationName("The Quassel Team"); Global::runMode = Global::GUIOnly; + Global::quasselDir = QDir::homePath() + "/.quassel"; + global = new Global(); guiProxy = new GUIProxy(); + Style::init(); + MainWin mainWin; + mainWin.init(); int exitCode = app.exec(); delete guiProxy; delete global; + return exitCode; +} + +void MainWin::syncToCore() { + Q_ASSERT(!global->getData("CoreReady").toBool()); + // ok, we are running as standalone GUI + coreConnectDlg = new CoreConnectDlg(this); + if(coreConnectDlg->exec() != QDialog::Accepted) { + //qApp->quit(); + exit(1); + } + VarMap state = coreConnectDlg->getCoreState().toMap(); + delete coreConnectDlg; + VarMap data = state["CoreData"].toMap(); + QString key; + foreach(key, data.keys()) { + global->updateData(key, data[key]); + } + if(!global->getData("CoreReady").toBool()) { + QMessageBox::critical(this, tr("Fatal Error"), tr("Could not synchronize with Quassel Core!
Quassel GUI will be aborted."), QMessageBox::Abort); + //qApp->quit(); + exit(1); + } + /* + foreach(QString net, state["CoreBackLog"].toMap().keys()) { + QByteArray logbuf = state["CoreBackLog"].toMap()[net].toByteArray(); + QDataStream in(&logbuf, QIODevice::ReadOnly); in.setVersion(QDataStream::Qt_4_2); + while(!in.atEnd()) { + Message msg; in >> msg; + coreBackLog[net].append(msg); + } + qDebug() << net << coreBackLog[net].count(); + } + */ + coreBuffers.clear(); + foreach(QVariant v, state["CoreBuffers"].toList()) { coreBuffers.append(v.value()); } } GUIProxy::GUIProxy() { @@ -61,9 +106,6 @@ GUIProxy::GUIProxy() { void GUIProxy::connectToCore(QString host, quint16 port) { socket.connectToHost(host, port); - //VarMap initmsg; - //initmsg["GUIProtocol"] = GUI_PROTOCOL; - //send(GS_CLIENT_INIT, QVariant(initmsg)); } void GUIProxy::disconnectFromCore() { @@ -72,6 +114,7 @@ void GUIProxy::disconnectFromCore() { void GUIProxy::serverError(QAbstractSocket::SocketError) { emit coreConnectionError(socket.errorString()); + //qFatal(QString("Connection error: %1").arg(socket.errorString()).toAscii()); } void GUIProxy::serverHasData() {