qbslogsink.cpp 3.12 KB
Newer Older
1 2
/****************************************************************************
**
3 4
** Copyright (C) 2016 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
5 6 7 8 9 10 11
**
** This file is part of Qt Creator.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
12 13 14
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
15
**
16 17 18 19 20 21 22
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
23 24 25 26 27 28 29 30
**
****************************************************************************/

#include "qbslogsink.h"

#include <qbs.h>

#include <coreplugin/messagemanager.h>
31 32 33
#include <projectexplorer/projectexplorer.h>
#include <projectexplorer/taskhub.h>
#include <utils/fileutils.h>
34 35 36 37 38 39 40 41 42 43 44 45

#include <QCoreApplication>
#include <QMutexLocker>
#include <QTimer>

namespace QbsProjectManager {
namespace Internal {

// --------------------------------------------------------------------
// QbsLogSink:
// --------------------------------------------------------------------

46 47
QbsLogSink::QbsLogSink(QObject *parent) : QObject(parent)
{
48
    connect(this, SIGNAL(newTask(ProjectExplorer::Task)),
49 50
            ProjectExplorer::TaskHub::instance(),
            SLOT(addTask(ProjectExplorer::Task)), Qt::QueuedConnection);
51 52
}

53 54 55 56 57 58 59 60 61 62
void QbsLogSink::sendMessages()
{
    QStringList toSend;
    {
        QMutexLocker l(&m_mutex);
        toSend = m_messages;
        m_messages.clear();
    }

    foreach (const QString &msg, toSend)
hjk's avatar
hjk committed
63
        Core::MessageManager::write(msg);
64 65
}

66
void QbsLogSink::doPrintWarning(const qbs::ErrorInfo &warning)
67
{
68
    foreach (const qbs::ErrorItem &item, warning.items())
69
        emit newTask(ProjectExplorer::Task(ProjectExplorer::Task::Warning,
70
                                           item.description(),
Christian Kandeler's avatar
Christian Kandeler committed
71
                                           Utils::FileName::fromString(item.codeLocation().filePath()),
72
                                           item.codeLocation().line(),
73 74 75
                                           ProjectExplorer::Constants::TASK_CATEGORY_BUILDSYSTEM));
}

76
void QbsLogSink::doPrintMessage(qbs::LoggerLevel level, const QString &message, const QString &tag)
77
{
78
    Q_UNUSED(tag);
79 80 81

    {
        QMutexLocker l(&m_mutex);
82 83 84 85
        if (level <= qbs::LoggerWarning) {
            doPrintWarning(qbs::ErrorInfo(message));
            return;
        }
86
        m_messages.append(qbs::logLevelTag(level) + message);
87 88 89 90 91 92
    }
    QMetaObject::invokeMethod(this, "sendMessages", Qt::QueuedConnection);
}

} // namespace Internal
} // namespace QbsProjectManager