- DEBUG = isOptionSet("debug");
- return true;
+ DEBUG = isOptionSet("debug");
+
+ // set up logging
+ if (Quassel::runMode() != Quassel::ClientOnly) {
+ if (isOptionSet("loglevel")) {
+ QString level = optionValue("loglevel");
+
+ if (level == "Debug") _logLevel = DebugLevel;
+ else if (level == "Info") _logLevel = InfoLevel;
+ else if (level == "Warning") _logLevel = WarningLevel;
+ else if (level == "Error") _logLevel = ErrorLevel;
+ }
+
+ QString logfilename = optionValue("logfile");
+ if (!logfilename.isEmpty()) {
+ _logFile = new QFile(logfilename);
+ if (!_logFile->open(QIODevice::Append | QIODevice::Text)) {
+ qWarning() << "Could not open log file" << logfilename << ":" << _logFile->errorString();
+ _logFile->deleteLater();
+ _logFile = 0;
+ }
+ }
+#ifdef HAVE_SYSLOG
+ _logToSyslog = isOptionSet("syslog");
+#endif
+ }
+
+ return true;
-void Quassel::registerMetaTypes() {
- // Complex types
- qRegisterMetaType<QVariant>("QVariant");
- qRegisterMetaType<Message>("Message");
- qRegisterMetaType<BufferInfo>("BufferInfo");
- qRegisterMetaType<NetworkInfo>("NetworkInfo");
- qRegisterMetaType<Network::Server>("Network::Server");
- qRegisterMetaType<Identity>("Identity");
- qRegisterMetaType<Network::ConnectionState>("Network::ConnectionState");
-
- qRegisterMetaTypeStreamOperators<QVariant>("QVariant");
- qRegisterMetaTypeStreamOperators<Message>("Message");
- qRegisterMetaTypeStreamOperators<BufferInfo>("BufferInfo");
- qRegisterMetaTypeStreamOperators<NetworkInfo>("NetworkInfo");
- qRegisterMetaTypeStreamOperators<Network::Server>("Network::Server");
- qRegisterMetaTypeStreamOperators<Identity>("Identity");
- qRegisterMetaTypeStreamOperators<qint8>("Network::ConnectionState");
-
- qRegisterMetaType<IdentityId>("IdentityId");
- qRegisterMetaType<BufferId>("BufferId");
- qRegisterMetaType<NetworkId>("NetworkId");
- qRegisterMetaType<UserId>("UserId");
- qRegisterMetaType<AccountId>("AccountId");
- qRegisterMetaType<MsgId>("MsgId");
-
- qRegisterMetaTypeStreamOperators<IdentityId>("IdentityId");
- qRegisterMetaTypeStreamOperators<BufferId>("BufferId");
- qRegisterMetaTypeStreamOperators<NetworkId>("NetworkId");
- qRegisterMetaTypeStreamOperators<UserId>("UserId");
- qRegisterMetaTypeStreamOperators<AccountId>("AccountId");
- qRegisterMetaTypeStreamOperators<MsgId>("MsgId");
+void Quassel::registerMetaTypes()
+{
+ // Complex types
+ qRegisterMetaType<Message>("Message");
+ qRegisterMetaType<BufferInfo>("BufferInfo");
+ qRegisterMetaType<NetworkInfo>("NetworkInfo");
+ qRegisterMetaType<Network::Server>("Network::Server");
+ qRegisterMetaType<Identity>("Identity");
+
+ qRegisterMetaTypeStreamOperators<Message>("Message");
+ qRegisterMetaTypeStreamOperators<BufferInfo>("BufferInfo");
+ qRegisterMetaTypeStreamOperators<NetworkInfo>("NetworkInfo");
+ qRegisterMetaTypeStreamOperators<Network::Server>("Network::Server");
+ qRegisterMetaTypeStreamOperators<Identity>("Identity");
+
+ qRegisterMetaType<IdentityId>("IdentityId");
+ qRegisterMetaType<BufferId>("BufferId");
+ qRegisterMetaType<NetworkId>("NetworkId");
+ qRegisterMetaType<UserId>("UserId");
+ qRegisterMetaType<AccountId>("AccountId");
+ qRegisterMetaType<MsgId>("MsgId");
+
+ qRegisterMetaType<QHostAddress>("QHostAddress");
+
+ qRegisterMetaTypeStreamOperators<IdentityId>("IdentityId");
+ qRegisterMetaTypeStreamOperators<BufferId>("BufferId");
+ qRegisterMetaTypeStreamOperators<NetworkId>("NetworkId");
+ qRegisterMetaTypeStreamOperators<UserId>("UserId");
+ qRegisterMetaTypeStreamOperators<AccountId>("AccountId");
+ qRegisterMetaTypeStreamOperators<MsgId>("MsgId");
+
+ // Versions of Qt prior to 4.7 didn't define QVariant as a meta type
+ if (!QMetaType::type("QVariant")) {
+ qRegisterMetaType<QVariant>("QVariant");
+ qRegisterMetaTypeStreamOperators<QVariant>("QVariant");
+ }
-void Quassel::setupBuildInfo(const QString &generated) {
- _buildInfo.applicationName = "Quassel IRC";
- _buildInfo.coreApplicationName = "quasselcore";
- _buildInfo.clientApplicationName = "quasselclient";
- _buildInfo.organizationName = "Quassel Project";
- _buildInfo.organizationDomain = "quassel-irc.org";
-
- QStringList gen = generated.split(',');
- Q_ASSERT(gen.count() == 10);
- _buildInfo.baseVersion = gen[0];
- _buildInfo.generatedVersion = gen[1];
- _buildInfo.isSourceDirty = !gen[2].isEmpty();
- _buildInfo.commitHash = gen[3];
- _buildInfo.commitDate = gen[4].toUInt();
- _buildInfo.protocolVersion = gen[5].toUInt();
- _buildInfo.clientNeedsProtocol = gen[6].toUInt();
- _buildInfo.coreNeedsProtocol = gen[7].toUInt();
- _buildInfo.buildDate = QString("%1 %2").arg(gen[8], gen[9]);
- // create a nice version string
- if(_buildInfo.generatedVersion.isEmpty()) {
- if(!_buildInfo.commitHash.isEmpty()) {
- // dist version
- _buildInfo.plainVersionString = QString("v%1 (dist-%2)")
- .arg(_buildInfo.baseVersion)
- .arg(_buildInfo.commitHash.left(7));
- _buildInfo.fancyVersionString = QString("v%1 (dist-<a href=\"http://git.quassel-irc.org/?p=quassel.git;a=commit;h=%3\">%2</a>)")
- .arg(_buildInfo.baseVersion)
- .arg(_buildInfo.commitHash.left(7))
- .arg(_buildInfo.commitHash);
- } else {
- // we only have a base version :(
- _buildInfo.plainVersionString = QString("v%1 (unknown rev)").arg(_buildInfo.baseVersion);
+
+void Quassel::setupBuildInfo(const QString &generated)
+{
+ _buildInfo.applicationName = "Quassel IRC";
+ _buildInfo.coreApplicationName = "quasselcore";
+ _buildInfo.clientApplicationName = "quasselclient";
+ _buildInfo.organizationName = "Quassel Project";
+ _buildInfo.organizationDomain = "quassel-irc.org";
+
+ QStringList gen = generated.split(',');
+ Q_ASSERT(gen.count() == 10);
+ _buildInfo.baseVersion = gen[0];
+ _buildInfo.generatedVersion = gen[1];
+ _buildInfo.isSourceDirty = !gen[2].isEmpty();
+ _buildInfo.commitHash = gen[3];
+ _buildInfo.commitDate = gen[4].toUInt();
+ _buildInfo.protocolVersion = gen[5].toUInt();
+ _buildInfo.clientNeedsProtocol = gen[6].toUInt();
+ _buildInfo.coreNeedsProtocol = gen[7].toUInt();
+ _buildInfo.buildDate = QString("%1 %2").arg(gen[8], gen[9]);
+ // create a nice version string
+ if (_buildInfo.generatedVersion.isEmpty()) {
+ if (!_buildInfo.commitHash.isEmpty()) {
+ // dist version
+ _buildInfo.plainVersionString = QString("v%1 (dist-%2)")
+ .arg(_buildInfo.baseVersion)
+ .arg(_buildInfo.commitHash.left(7));
+ _buildInfo.fancyVersionString = QString("v%1 (dist-<a href=\"http://git.quassel-irc.org/?p=quassel.git;a=commit;h=%3\">%2</a>)")
+ .arg(_buildInfo.baseVersion)
+ .arg(_buildInfo.commitHash.left(7))
+ .arg(_buildInfo.commitHash);
+ }
+ else {
+ // we only have a base version :(
+ _buildInfo.plainVersionString = QString("v%1 (unknown rev)").arg(_buildInfo.baseVersion);
+ }
- } else {
- // analyze what we got from git-describe
- QRegExp rx("(.*)-(\\d+)-g([0-9a-f]+)$");
- if(rx.exactMatch(_buildInfo.generatedVersion)) {
- QString distance = rx.cap(2) == "0" ? QString() : QString("%1+%2 ").arg(rx.cap(1), rx.cap(2));
- _buildInfo.plainVersionString = QString("v%1 (%2git-%3%4)")
- .arg(_buildInfo.baseVersion, distance, rx.cap(3))
- .arg(_buildInfo.isSourceDirty ? "*" : "");
- if(!_buildInfo.commitHash.isEmpty()) {
- _buildInfo.fancyVersionString = QString("v%1 (%2git-<a href=\"http://git.quassel-irc.org/?p=quassel.git;a=commit;h=%5\">%3</a>%4)")
- .arg(_buildInfo.baseVersion, distance, rx.cap(3))
- .arg(_buildInfo.isSourceDirty ? "*" : "")
- .arg(_buildInfo.commitHash);
- }
- } else {
- _buildInfo.plainVersionString = QString("v%1 (invalid rev)").arg(_buildInfo.baseVersion);
+ else {
+ // analyze what we got from git-describe
+ QRegExp rx("(.*)-(\\d+)-g([0-9a-f]+)$");
+ if (rx.exactMatch(_buildInfo.generatedVersion)) {
+ QString distance = rx.cap(2) == "0" ? QString() : QString("%1+%2 ").arg(rx.cap(1), rx.cap(2));
+ _buildInfo.plainVersionString = QString("v%1 (%2git-%3%4)")
+ .arg(_buildInfo.baseVersion, distance, rx.cap(3))
+ .arg(_buildInfo.isSourceDirty ? "*" : "");
+ if (!_buildInfo.commitHash.isEmpty()) {
+ _buildInfo.fancyVersionString = QString("v%1 (%2git-<a href=\"http://git.quassel-irc.org/?p=quassel.git;a=commit;h=%5\">%3</a>%4)")
+ .arg(_buildInfo.baseVersion, distance, rx.cap(3))
+ .arg(_buildInfo.isSourceDirty ? "*" : "")
+ .arg(_buildInfo.commitHash);
+ }
+ }
+ else {
+ _buildInfo.plainVersionString = QString("v%1 (invalid rev)").arg(_buildInfo.baseVersion);
+ }
-const QString &Quassel::coreDumpFileName() {
- if(_coreDumpFileName.isEmpty()) {
- QDir configDir(configDirPath());
- _coreDumpFileName = configDir.absoluteFilePath(QString("Quassel-Crash-%1.log").arg(QDateTime::currentDateTime().toString("yyyyMMdd-hhmm")));
- QFile dumpFile(_coreDumpFileName);
- dumpFile.open(QIODevice::Append);
- QTextStream dumpStream(&dumpFile);
- dumpStream << "Quassel IRC: " << _buildInfo.baseVersion << ' ' << _buildInfo.commitHash << '\n';
- qDebug() << "Quassel IRC: " << _buildInfo.baseVersion << ' ' << _buildInfo.commitHash;
- dumpStream.flush();
- dumpFile.close();
- }
- return _coreDumpFileName;
+
+const QString &Quassel::coreDumpFileName()
+{
+ if (_coreDumpFileName.isEmpty()) {
+ QDir configDir(configDirPath());
+ _coreDumpFileName = configDir.absoluteFilePath(QString("Quassel-Crash-%1.log").arg(QDateTime::currentDateTime().toString("yyyyMMdd-hhmm")));
+ QFile dumpFile(_coreDumpFileName);
+ dumpFile.open(QIODevice::Append);
+ QTextStream dumpStream(&dumpFile);
+ dumpStream << "Quassel IRC: " << _buildInfo.baseVersion << ' ' << _buildInfo.commitHash << '\n';
+ qDebug() << "Quassel IRC: " << _buildInfo.baseVersion << ' ' << _buildInfo.commitHash;
+ dumpStream.flush();
+ dumpFile.close();
+ }
+ return _coreDumpFileName;
- QSettings s(format, QSettings::UserScope, QCoreApplication::organizationDomain(), buildInfo().applicationName);
- QFileInfo fileInfo(s.fileName());
- _configDirPath = fileInfo.dir().absolutePath();
+ QSettings s(format, QSettings::UserScope, QCoreApplication::organizationDomain(), buildInfo().applicationName);
+ QFileInfo fileInfo(s.fileName());
+ _configDirPath = fileInfo.dir().absolutePath();
- dataDirNames.append("/usr/share/apps/quassel/");
- }
- // on UNIX, we always check our install prefix
- QString appDir = QCoreApplication::applicationDirPath();
- int binpos = appDir.lastIndexOf("/bin");
- if(binpos >= 0) {
- appDir.replace(binpos, 4, "/share");
- appDir.append("/apps/quassel/");
- if(!dataDirNames.contains(appDir))
- dataDirNames.append(appDir);
- }
+ dataDirNames.append("/usr/share/apps/quassel/");
+ }
+ // on UNIX, we always check our install prefix
+ QString appDir = QCoreApplication::applicationDirPath();
+ int binpos = appDir.lastIndexOf("/bin");
+ if (binpos >= 0) {
+ appDir.replace(binpos, 4, "/share");
+ appDir.append("/apps/quassel/");
+ if (!dataDirNames.contains(appDir))
+ dataDirNames.append(appDir);
+ }
- // add resource path and workdir just in case
- dataDirNames << QCoreApplication::applicationDirPath() + "/data/"
- << ":/data/";
-
- // append trailing '/' and check for existence
- QStringList::Iterator iter = dataDirNames.begin();
- while(iter != dataDirNames.end()) {
- if(!iter->endsWith(QDir::separator()) && !iter->endsWith('/'))
- iter->append(QDir::separator());
- if(!QFile::exists(*iter))
- iter = dataDirNames.erase(iter);
- else
- ++iter;
- }
-
- return dataDirNames;
+ // add resource path and workdir just in case
+ dataDirNames << QCoreApplication::applicationDirPath() + "/data/"
+ << ":/data/";
+
+ // append trailing '/' and check for existence
+ QStringList::Iterator iter = dataDirNames.begin();
+ while (iter != dataDirNames.end()) {
+ if (!iter->endsWith(QDir::separator()) && !iter->endsWith('/'))
+ iter->append(QDir::separator());
+ if (!QFile::exists(*iter))
+ iter = dataDirNames.erase(iter);
+ else
+ ++iter;
+ }
+
+ return dataDirNames;
-QString Quassel::findDataFilePath(const QString &fileName) {
- QStringList dataDirs = dataDirPaths();
- foreach(QString dataDir, dataDirs) {
- QString path = dataDir + fileName;
- if(QFile::exists(path))
- return path;
- }
- return QString();
+
+QString Quassel::findDataFilePath(const QString &fileName)
+{
+ QStringList dataDirs = dataDirPaths();
+ foreach(QString dataDir, dataDirs) {
+ QString path = dataDir + fileName;
+ if (QFile::exists(path))
+ return path;
+ }
+ return QString();
-QString Quassel::translationDirPath() {
- if(_translationDirPath.isEmpty()) {
- // We support only one translation dir; fallback mechanisms wouldn't work else.
- // This means that if we have a $data/translations dir, the internal :/i18n resource won't be considered.
- foreach(const QString &dir, dataDirPaths()) {
- if(QFile::exists(dir + "translations/")) {
- _translationDirPath = dir + "translations/";
- break;
- }
+
+QString Quassel::translationDirPath()
+{
+ if (_translationDirPath.isEmpty()) {
+ // We support only one translation dir; fallback mechanisms wouldn't work else.
+ // This means that if we have a $data/translations dir, the internal :/i18n resource won't be considered.
+ foreach(const QString &dir, dataDirPaths()) {
+ if (QFile::exists(dir + "translations/")) {
+ _translationDirPath = dir + "translations/";
+ break;
+ }
+ }
+ if (_translationDirPath.isEmpty())
+ _translationDirPath = ":/i18n/";
- bool success = qtTranslator->load(QString("qt_%1").arg(locale.name()), translationDirPath());
- if(!success)
- qtTranslator->load(QString("qt_%1").arg(locale.name()), QLibraryInfo::location(QLibraryInfo::TranslationsPath));
- quasselTranslator->load(QString("%1").arg(locale.name()), translationDirPath());
+ bool success = qtTranslator->load(QString("qt_%1").arg(locale.name()), translationDirPath());
+ if (!success)
+ qtTranslator->load(QString("qt_%1").arg(locale.name()), QLibraryInfo::location(QLibraryInfo::TranslationsPath));
+ quasselTranslator->load(QString("%1").arg(locale.name()), translationDirPath());