/***************************************************************************
- * Copyright (C) 2005-07 by The Quassel IRC Development Team *
+ * Copyright (C) 2005-08 by the Quassel Project *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
- * (at your option) any later version. *
+ * (at your option) version 3. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
-#include "settings.h"
+#include <QDateTime>
#include <QString>
+#include <QTimer>
+#include <QTranslator>
+#include <QFile>
+
+#include "global.h"
+#include "logger.h"
+#include "network.h"
+#include "settings.h"
+#include "cliparser.h"
#if defined BUILD_CORE
#include <QCoreApplication>
#include "core.h"
#include "message.h"
-#elif defined BUILD_QTGUI
+#elif defined BUILD_QTUI
#include <QApplication>
#include "client.h"
-//#include "clientproxy.h"
-#include "qtgui.h"
-#include "style.h"
+#include "qtui.h"
#elif defined BUILD_MONO
#include <QApplication>
#include "client.h"
-//#include "clientproxy.h"
#include "core.h"
#include "coresession.h"
-#include "qtgui.h"
-#include "style.h"
+#include "qtui.h"
#else
#error "Something is wrong - you need to #define a build mode!"
//! Signal handler for graceful shutdown.
void handle_signal(int sig) {
- qWarning(QString("Caught signal %1 - exiting.").arg(sig).toAscii());
+ qWarning("%s", qPrintable(QString("Caught signal %1 - exiting.").arg(sig)));
QCoreApplication::quit();
}
signal(SIGTERM, handle_signal);
signal(SIGINT, handle_signal);
- qRegisterMetaType<QVariant>("QVariant");
- qRegisterMetaType<Message>("Message");
- qRegisterMetaType<BufferId>("BufferId");
- qRegisterMetaTypeStreamOperators<QVariant>("QVariant");
- qRegisterMetaTypeStreamOperators<Message>("Message");
- qRegisterMetaTypeStreamOperators<BufferId>("BufferId");
+ Global::registerMetaTypes();
+ Global::setupVersion();
#if defined BUILD_CORE
Global::runMode = Global::CoreOnly;
QCoreApplication app(argc, argv);
-#elif defined BUILD_QTGUI
+#elif defined BUILD_QTUI
Global::runMode = Global::ClientOnly;
QApplication app(argc, argv);
#else
Global::runMode = Global::Monolithic;
QApplication app(argc, argv);
#endif
+
+ Global::parser = CliParser(QCoreApplication::arguments());
+
+#ifndef BUILD_QTUI
+// put core-only arguments here
+ Global::parser.addOption("port",'p',"The port quasselcore will listen at",QString("4242"));
+ Global::parser.addSwitch("norestore", 'n', "Don't restore last core's state");
+ Global::parser.addOption("logfile",'l',"Path to logfile");
+ Global::parser.addOption("loglevel",'L',"Loglevel Debug|Info|Warning|Error","Info");
+ Global::parser.addOption("datadir", 0, "Specify the directory holding datafiles like the Sqlite DB and the SSL Cert");
+#endif // BUILD_QTUI
+#ifndef BUILD_CORE
+// put client-only arguments here
+ Global::parser.addSwitch("debugbufferswitches",0,"Enables debugging for bufferswitches");
+ Global::parser.addSwitch("debugmodel",0,"Enables debugging for models");
+#endif // BUILD_QTCORE
+// put shared client&core arguments here
+ Global::parser.addSwitch("debug",'d',"Enable debug output");
+ Global::parser.addSwitch("help",'h', "Display this help and exit");
+
+ if(!Global::parser.parse() || Global::parser.isSet("help")) {
+ Global::parser.usage();
+ return 1;
+ }
+
+ /*
+ This is an initial check if logfile is writable since the warning would spam stdout if done
+ in current Logger implementation. Can be dropped whenever the logfile is only opened once.
+ */
+ if(Global::runMode != Global::ClientOnly) {
+ QFile logFile;
+ if(!Global::parser.value("logfile").isEmpty()) {
+ logFile.setFileName(Global::parser.value("logfile"));
+ if(!logFile.open(QIODevice::Append | QIODevice::Text))
+ qWarning("Warning: Couldn't open logfile '%s' - will log to stdout instead",qPrintable(logFile.fileName()));
+ else logFile.close();
+ }
+ }
+
+ qsrand(QTime(0,0,0).secsTo(QTime::currentTime()));
+
+ // Set up i18n support
+ QLocale locale = QLocale::system();
+
+ QTranslator qtTranslator(&app);
+ qtTranslator.setObjectName("QtTr");
+ qtTranslator.load(QString(":i18n/qt_%1").arg(locale.name()));
+ app.installTranslator(&qtTranslator);
+
+ QTranslator quasselTranslator(&app);
+ quasselTranslator.setObjectName("QuasselTr");
+ quasselTranslator.load(QString(":i18n/quassel_%1").arg(locale.name()));
+ app.installTranslator(&quasselTranslator);
+
+ Network::setDefaultCodecForServer("ISO-8859-1");
+ Network::setDefaultCodecForEncoding("UTF-8");
+ Network::setDefaultCodecForDecoding("ISO-8859-15");
+
QCoreApplication::setOrganizationDomain("quassel-irc.org");
QCoreApplication::setApplicationName("Quassel IRC");
- QCoreApplication::setOrganizationName("Quassel IRC Development Team");
+ QCoreApplication::setOrganizationName("Quassel Project");
- Global::quasselDir = QDir::homePath() + "/.quassel";
-#ifndef BUILD_QTGUI
+#ifndef BUILD_QTUI
Core::instance(); // create and init the core
#endif
//Settings::init();
#ifndef BUILD_CORE
- Style::init();
- QtGui *gui = new QtGui();
+ QtUi *gui = new QtUi();
Client::init(gui);
- gui->init();
+ // init gui only after the event loop has started
+ QTimer::singleShot(0, gui, SLOT(init()));
+ //gui->init();
+#endif
+
+#ifndef BUILD_QTUI
+ if(!Global::parser.isSet("norestore")) {
+ Core::restoreState();
+ }
#endif
int exitCode = app.exec();
+#ifndef BUILD_QTUI
+ Core::saveState();
+#endif
+
#ifndef BUILD_CORE
// the mainWin has to be deleted before the Core
// if not Quassel will crash on exit under certain conditions since the gui
delete gui;
Client::destroy();
#endif
-#ifndef BUILD_QTGUI
+#ifndef BUILD_QTUI
Core::destroy();
#endif
return exitCode;
}
-
-#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;
- */
- return QVariant();
-}
-
-void Client::disconnectFromLocalCore() {
- /*
- disconnect(Core::localSession(), 0, ClientProxy::instance(), 0);
- disconnect(ClientProxy::instance(), 0, Core::localSession(), 0);
- Core::disconnectLocalClient();
- */
-}
-
-#endif