aboutsummaryrefslogtreecommitdiffstats
path: root/src/lib/tools/logsink.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/tools/logsink.cpp')
-rw-r--r--src/lib/tools/logsink.cpp81
1 files changed, 81 insertions, 0 deletions
diff --git a/src/lib/tools/logsink.cpp b/src/lib/tools/logsink.cpp
new file mode 100644
index 000000000..a9a4cc064
--- /dev/null
+++ b/src/lib/tools/logsink.cpp
@@ -0,0 +1,81 @@
+/**************************************************************************
+**
+** This file is part of the Qt Build Suite
+**
+** Copyright (c) 2012 Nokia Corporation and/or its subsidiary(-ies).
+**
+** Contact: Nokia Corporation (info@qt.nokia.com)
+**
+**
+** GNU Lesser General Public License Usage
+**
+** This file may be used under the terms of the GNU Lesser General Public
+** License version 2.1 as published by the Free Software Foundation and
+** appearing in the file LICENSE.LGPL included in the packaging of this file.
+** Please review the following information to ensure the GNU Lesser General
+** Public License version 2.1 requirements will be met:
+** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Nokia gives you certain additional
+** rights. These rights are described in the Nokia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU General
+** Public License version 3.0 as published by the Free Software Foundation
+** and appearing in the file LICENSE.GPL included in the packaging of this
+** file.
+** Please review the following information to ensure the GNU General
+** Public License version 3.0 requirements will be met:
+** http://www.gnu.org/copyleft/gpl.html.
+**
+** Other Usage
+** Alternatively, this file may be used in accordance with the terms and
+** conditions contained in a signed written agreement between you and Nokia.
+**
+**************************************************************************/
+
+#include "logsink.h"
+#include "logger.h"
+#include "coloredoutput.h"
+
+#include <qhash.h>
+#include <stdio.h>
+
+namespace qbs {
+
+void ConsolePrintLogSink::outputLogMessage(LoggerLevel level, const LogMessage &message)
+{
+ FILE *file = stdout;
+ if (message.outputChannel == LogOutputStdErr)
+ file = stderr;
+
+ if (message.printLogLevel) {
+ switch (level) {
+ case LoggerFatal:
+ fprintfColored(TextColorRed, file, "FATAL ERROR: ");
+ break;
+ case LoggerError:
+ fprintfColored(TextColorRed, file, "ERROR: ");
+ break;
+ case LoggerWarning:
+ fprintfColored(TextColorYellow, file, "WARNING: ");
+ break;
+ case LoggerInfo:
+ fprintf(file, "INFO: ");
+ break;
+ case LoggerDebug:
+ fprintf(file, "DEBUG: ");
+ break;
+ case LoggerTrace:
+ fprintf(file, "TRACE: ");
+ break;
+ }
+ }
+ if (message.textColor == TextColorDefault || !m_coloredOutputEnabled)
+ fprintf(file, "%s\n", message.data.data());
+ else
+ fprintfColored(message.textColor, file, "%s\n", message.data.data());
+}
+
+} // namespace qbs