diff options
Diffstat (limited to 'src/lib/tools/logsink.cpp')
-rw-r--r-- | src/lib/tools/logsink.cpp | 81 |
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 |