Properly handle QGenericReturnArgument
[quassel.git] / src / common / logger.cpp
1 /***************************************************************************
2  *   Copyright (C) 2005-2012 by the Quassel Project                        *
3  *   devel@quassel-irc.org                                                 *
4  *                                                                         *
5  *   This program is free software; you can redistribute it and/or modify  *
6  *   it under the terms of the GNU General Public License as published by  *
7  *   the Free Software Foundation; either version 2 of the License, or     *
8  *   (at your option) version 3.                                           *
9  *                                                                         *
10  *   This program is distributed in the hope that it will be useful,       *
11  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
12  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
13  *   GNU General Public License for more details.                          *
14  *                                                                         *
15  *   You should have received a copy of the GNU General Public License     *
16  *   along with this program; if not, write to the                         *
17  *   Free Software Foundation, Inc.,                                       *
18  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
19  ***************************************************************************/
20
21 #include <QFile>
22 #include <QTextStream>
23 #include <QDateTime>
24
25 #ifdef HAVE_SYSLOG
26 #  include <syslog.h>
27 #endif
28
29 #include "logger.h"
30 #include "quassel.h"
31
32 Logger::~Logger() {
33   log();
34 }
35
36 void Logger::log() {
37   if(_logLevel < Quassel::logLevel())
38     return;
39
40   switch(_logLevel) {
41   case Quassel::DebugLevel:
42     _buffer.prepend("Debug: ");
43     break;
44   case Quassel::InfoLevel:
45     _buffer.prepend("Info: ");
46     break;
47     case Quassel::WarningLevel:
48     _buffer.prepend("Warning: ");
49     break;
50   case Quassel::ErrorLevel:
51     _buffer.prepend("Error: ");
52     break;
53   default:
54     break;
55   }
56
57 #ifdef HAVE_SYSLOG
58   if(Quassel::logToSyslog()) {
59     int prio;
60     switch(_logLevel) {
61     case Quassel::DebugLevel:
62       prio = LOG_DEBUG;
63       break;
64     case Quassel::InfoLevel:
65       prio = LOG_INFO;
66       break;
67     case Quassel::WarningLevel:
68       prio = LOG_WARNING;
69       break;
70     case Quassel::ErrorLevel:
71       prio = LOG_ERR;
72       break;
73     default:
74       prio = LOG_INFO;
75       break;
76     }
77     syslog(LOG_USER & prio, "%s", qPrintable(_buffer));
78   }
79 #endif
80
81   // if we neither use syslog nor have a logfile we log to stdout
82
83   if(Quassel::logFile() || !Quassel::logToSyslog()) {
84     _buffer.prepend(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss "));
85
86     QTextStream out(stdout);
87     if(Quassel::logFile() && Quassel::logFile()->isOpen()) {
88       _buffer.remove(QChar('\n'));
89       out.setDevice(Quassel::logFile());
90     }
91
92     out << _buffer << endl;
93   }
94 }
95
96
97 void Logger::logMessage(QtMsgType type, const char *msg) {
98   switch (type) {
99   case QtDebugMsg:
100     Logger(Quassel::DebugLevel) << msg;
101     break;
102   case QtWarningMsg:
103     Logger(Quassel::WarningLevel) << msg;
104     break;
105   case QtCriticalMsg:
106     Logger(Quassel::ErrorLevel) << msg;
107     break;
108   case QtFatalMsg:
109     Logger(Quassel::ErrorLevel) << msg;
110     Quassel::logFatalMessage(msg);
111     return;
112   }
113 }