diff generator/reporthandler.cpp @ 1:e78566595089

initial import
author mandel
date Mon, 11 May 2009 16:01:50 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/generator/reporthandler.cpp	Mon May 11 16:01:50 2009 +0000
@@ -0,0 +1,74 @@
+/****************************************************************************
+**
+** Copyright (C) 1992-2008 Nokia. All rights reserved.
+**
+** This file is part of Qt Jambi.
+**
+** * Commercial Usage
+* Licensees holding valid Qt Commercial licenses may use this file in
+* accordance with the Qt Commercial License Agreement provided with the
+* Software or, alternatively, in accordance with the terms contained in
+* a written agreement between you and Nokia.
+*
+*
+* GNU General Public License Usage
+* Alternatively, this file may be used under the terms of the GNU
+* General Public License versions 2.0 or 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 GNU General Public Licensing requirements will be met:
+* http://www.fsf.org/licensing/licenses/info/GPLv2.html and
+* http://www.gnu.org/copyleft/gpl.html.  In addition, as a special
+* exception, Nokia gives you certain additional rights. These rights
+* are described in the Nokia Qt GPL Exception version 1.2, included in
+* the file GPL_EXCEPTION.txt in this package.
+* 
+* Qt for Windows(R) Licensees
+* As a special exception, Nokia, as the sole copyright holder for Qt
+* Designer, grants users of the Qt/Eclipse Integration plug-in the
+* right for the Qt/Eclipse Integration to link to functionality
+* provided by Qt Designer and its related libraries.
+*
+*
+* If you are unsure which license is appropriate for your use, please
+* contact the sales department at qt-sales@nokia.com.
+
+**
+** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
+** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
+**
+****************************************************************************/
+
+#include "reporthandler.h"
+#include "typesystem.h"
+
+int ReportHandler::m_warning_count = 0;
+int ReportHandler::m_suppressed_count = 0;
+QString ReportHandler::m_context;
+ReportHandler::DebugLevel ReportHandler::m_debug_level = NoDebug;
+QSet<QString> ReportHandler::m_reported_warnings;
+
+
+void ReportHandler::warning(const QString &text)
+{
+    QString warningText = QString("WARNING(%1) :: %2").arg(m_context).arg(text);
+
+    TypeDatabase *db = TypeDatabase::instance();
+    if (db && db->isSuppressedWarning(warningText)) {
+        ++m_suppressed_count;
+    } else if (!m_reported_warnings.contains(warningText)) {
+        qDebug(qPrintable(warningText));
+        ++m_warning_count;
+
+        m_reported_warnings.insert(warningText);
+    }
+}
+
+void ReportHandler::debug(DebugLevel level, const QString &text)
+{
+    if (m_debug_level == NoDebug)
+        return;
+
+    if (level <= m_debug_level)
+        qDebug(" - DEBUG(%s) :: %s", qPrintable(m_context), qPrintable(text));
+}