1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
/*
* This file is part of the xTuple ERP: PostBooks Edition, a free and
* open source Enterprise Resource Planning software suite,
* Copyright (c) 1999-2012 by OpenMFG LLC, d/b/a xTuple.
* It is licensed to you under the Common Public Attribution License
* version 1.0, the full text of which (including xTuple-specific Exhibits)
* is available at www.xtuple.com/CPAL. By using this software, you agree
* to be bound by its terms.
*/
#include <xabstractmessagehandler.h>
XAbstractMessageHandler::XAbstractMessageHandler(QObject *parent)
: QAbstractMessageHandler(parent)
{
}
XAbstractMessageHandler::~XAbstractMessageHandler()
{
}
void XAbstractMessageHandler::message(QtMsgType type, const QString &description, const QUrl &identifier, const QSourceLocation &sourceLocation)
{
QMutexLocker locker(&_mutex);
_unhandledMessage.append(QPair<QtMsgType, QString>(type, description));
handleMessage(type, description, identifier, sourceLocation);
}
void XAbstractMessageHandler::message(QtMsgType type, const QString title, const QString &description, const QUrl &identifier, const QSourceLocation &sourceLocation)
{
QMutexLocker locker(&_mutex);
_unhandledMessage.append(QPair<QtMsgType, QString>(type, description));
handleMessage(type, title, description, identifier, sourceLocation);
}
// drains the queue but only returns those messages of the given type or greater
// on return, type holds the value of the greatest QtMsgType found
QStringList XAbstractMessageHandler::unhandledMessages(QtMsgType *type)
{
QStringList unhandled;
QtMsgType dummy = QtDebugMsg;
if (! type)
type = &dummy;
while (_unhandledMessage.size() > 0)
{
QPair<QtMsgType, QString> curr = _unhandledMessage.takeFirst();
if (curr.first >= *type)
{
*type = curr.first;
unhandled.append(curr.second);
}
}
return unhandled;
}
|