Fixed Bug #20 (Handle Numeric Reply 433 ERR_NICKNAMEINUSE properly)
[quassel.git] / main / main_gui.cpp
index bf6ed14..f48f615 100644 (file)
 
 #include <iostream>
 
+#include <QtGui>
 #include <QApplication>
 
-#include "quassel.h"
+#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("<b>Could not synchronize with Quassel Core!</b><br>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<BufferId>()); }
 }
 
 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() {