+
+
+ 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()));