-void messageHandler(QtMsgType type, const char *msg) {
- switch (type) {
- case QtDebugMsg:
- std::cerr << "[DEBUG] " << msg << "\n";
- break;
- case QtWarningMsg:
- std::cerr << "[WARNING] " << msg << "\n";
- break;
- case QtCriticalMsg:
- std::cerr << "[CRITICAL] " << msg << "\n";
- break;
- case QtFatalMsg:
- std::cerr << "[FATAL] " << msg << "\n";
- abort(); // deliberately core dump
+void Logger::log() {
+ LogLevel lvl;
+ if (Quassel::optionValue("loglevel") == "Debug") lvl = DebugLevel;
+ else if (Quassel::optionValue("loglevel") == "Info") lvl = InfoLevel;
+ else if (Quassel::optionValue("loglevel") == "Warning") lvl = WarningLevel;
+ else if (Quassel::optionValue("loglevel") == "Error") lvl = ErrorLevel;
+ else lvl = InfoLevel;
+
+ if(_logLevel < lvl) return;
+
+ // if we can't open logfile we log to stdout
+ QTextStream out(stdout);
+ QFile file;
+ if(!Quassel::optionValue("logfile").isEmpty()) {
+ file.setFileName(Quassel::optionValue("logfile"));
+ if (file.open(QIODevice::Append | QIODevice::Text)) {
+ out.setDevice(&file);
+ _buffer.remove(QChar('\n'));
+ }