Fixed comments.
[quassel.git] / src / common / main.cpp
index 48760d2..c53daab 100644 (file)
@@ -18,9 +18,6 @@
  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
  ***************************************************************************/
 
-#include <iostream>
-
-#include "global.h"
 #include "settings.h"
 
 #if defined BUILD_CORE
 
 #elif defined BUILD_QTGUI
 #include <QApplication>
-#include "style.h"
 #include "client.h"
 #include "clientproxy.h"
-#include "mainwin.h"
+#include "qtgui.h"
+#include "style.h"
 
 #elif defined BUILD_MONO
 #include <QApplication>
-#include "core.h"
-#include "coreproxy.h"
-#include "style.h"
 #include "client.h"
 #include "clientproxy.h"
-#include "mainwin.h"
+#include "core.h"
+#include "coresession.h"
+#include "qtgui.h"
+#include "style.h"
 
 #else
 #error "Something is wrong - you need to #define a build mode!"
@@ -58,27 +55,22 @@ int main(int argc, char **argv) {
   Global::runMode = Global::Monolithic;
   QApplication app(argc, argv);
 #endif
-
   QCoreApplication::setOrganizationDomain("quassel-irc.org");
   QCoreApplication::setApplicationName("Quassel IRC");
   QCoreApplication::setOrganizationName("Quassel IRC Development Team");
 
   Global::quasselDir = QDir::homePath() + "/.quassel";
-  Core::instance();
-#ifdef BUILD_MONO
-  QObject::connect(Core::localSession(), SIGNAL(proxySignal(CoreSignal, QVariant, QVariant, QVariant)), ClientProxy::instance(), SLOT(recv(CoreSignal, QVariant, QVariant, QVariant)));
-  QObject::connect(ClientProxy::instance(), SIGNAL(send(ClientSignal, QVariant, QVariant, QVariant)), Core::localSession(), SLOT(processSignal(ClientSignal, QVariant, QVariant, QVariant)));
+#ifndef BUILD_QTGUI
+  Core::instance();  // create and init the core
 #endif
 
   Settings::init();
 
 #ifndef BUILD_CORE
   Style::init();
-  MainWin *mainWin = new MainWin();
-  Client::init(mainWin);
-  mainWin->init();
-#else
-  Core::instance(); // create and init the core object
+  QtGui *gui = new QtGui();
+  Client::init(gui);
+  gui->init();
 #endif
 
   int exitCode = app.exec();
@@ -87,7 +79,7 @@ int main(int argc, char **argv) {
   // the mainWin has to be deleted before the Core
   // if not Quassel will crash on exit under certain conditions since the gui
   // still wants to access clientdata
-  delete mainWin;
+  delete gui;
   Client::destroy();
 #endif
 #ifndef BUILD_QTGUI
@@ -97,11 +89,23 @@ int main(int argc, char **argv) {
   return exitCode;
 }
 
-#ifndef BUILD_CORE
-void Client::syncToCore() {
-  //Q_ASSERT(Global::data("CoreReady").toBool());
-  coreBuffers = Core::localSession()->buffers();
-  // NOTE: We don't need to request server states, because in the monolithic version there can't be
-  //       any servers connected at this stage...
+#ifdef BUILD_QTGUI
+QVariant Client::connectToLocalCore(QString, QString) { return QVariant(); }
+void Client::disconnectFromLocalCore() {}
+
+#elif defined BUILD_MONO
+QVariant Client::connectToLocalCore(QString user, QString passwd) {
+  // TODO catch exceptions
+  QVariant reply = Core::connectLocalClient(user, passwd);
+  QObject::connect(Core::localSession(), SIGNAL(proxySignal(CoreSignal, QVariant, QVariant, QVariant)), ClientProxy::instance(), SLOT(recv(CoreSignal, QVariant, QVariant, QVariant)));
+  QObject::connect(ClientProxy::instance(), SIGNAL(send(ClientSignal, QVariant, QVariant, QVariant)), Core::localSession(), SLOT(processSignal(ClientSignal, QVariant, QVariant, QVariant)));
+  return reply;
 }
+
+void Client::disconnectFromLocalCore() {
+  disconnect(Core::localSession(), 0, ClientProxy::instance(), 0);
+  disconnect(ClientProxy::instance(), 0, Core::localSession(), 0);
+  Core::disconnectLocalClient();
+}
+
 #endif