2009-02-25 09:15:00 +01:00
|
|
|
/**************************************************************************
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
|
|
|
|
** This file is part of Qt Creator
|
|
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-06-17 00:01:27 +10:00
|
|
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Commercial Usage
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** 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.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** GNU Lesser General Public License Usage
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Alternatively, 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.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** If you are unsure which license is appropriate for your use, please
|
2009-08-14 09:30:56 +02:00
|
|
|
** contact the sales department at http://qt.nokia.com/contact.
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
**************************************************************************/
|
2008-12-02 16:19:05 +01:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#include "gccparser.h"
|
2009-02-16 13:12:12 +01:00
|
|
|
#include "projectexplorerconstants.h"
|
2009-11-11 09:54:13 +01:00
|
|
|
#include "taskwindow.h"
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2009-02-16 13:12:12 +01:00
|
|
|
using namespace ProjectExplorer;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
GccParser::GccParser()
|
|
|
|
|
{
|
2008-12-03 22:02:30 +01:00
|
|
|
m_regExp.setPattern("^([^\\(\\)]+[^\\d]):(\\d+):(\\d+:)*(\\s(warning|error):)?\\s(.+)$");
|
2008-12-02 12:01:29 +01:00
|
|
|
m_regExp.setMinimal(true);
|
|
|
|
|
|
|
|
|
|
m_regExpIncluded.setPattern("^.*from\\s([^:]+):(\\d+)(,|:)$");
|
|
|
|
|
m_regExpIncluded.setMinimal(true);
|
|
|
|
|
|
2009-02-05 17:19:27 +01:00
|
|
|
m_regExpLinker.setPattern("^(\\S*)\\(\\S+\\):\\s(.+)$");
|
2008-12-02 12:01:29 +01:00
|
|
|
m_regExpLinker.setMinimal(true);
|
|
|
|
|
|
|
|
|
|
//make[4]: Entering directory `/home/kkoehne/dev/ide-explorer/src/plugins/qtscripteditor'
|
|
|
|
|
m_makeDir.setPattern("^make.*: (\\w+) directory .(.+).$");
|
|
|
|
|
m_makeDir.setMinimal(true);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString GccParser::name() const
|
|
|
|
|
{
|
2009-02-16 13:12:12 +01:00
|
|
|
return QLatin1String(ProjectExplorer::Constants::BUILD_PARSER_GCC);
|
2008-12-02 12:01:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void GccParser::stdOutput(const QString & line)
|
|
|
|
|
{
|
|
|
|
|
QString lne = line.trimmed();
|
|
|
|
|
|
|
|
|
|
if (m_makeDir.indexIn(lne) > -1) {
|
|
|
|
|
if (m_makeDir.cap(1) == "Leaving")
|
|
|
|
|
emit leaveDirectory(m_makeDir.cap(2));
|
|
|
|
|
else
|
|
|
|
|
emit enterDirectory(m_makeDir.cap(2));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void GccParser::stdError(const QString & line)
|
|
|
|
|
{
|
|
|
|
|
QString lne = line.trimmed();
|
2009-11-10 17:29:41 +01:00
|
|
|
if (m_regExpLinker.indexIn(lne) > -1) {
|
2009-02-05 17:19:27 +01:00
|
|
|
QString description = m_regExpLinker.cap(2);
|
|
|
|
|
emit addToTaskWindow(
|
2009-11-10 17:29:41 +01:00
|
|
|
m_regExpLinker.cap(1), //filename
|
2009-11-11 09:54:13 +01:00
|
|
|
TaskWindow::Error,
|
2009-11-10 17:29:41 +01:00
|
|
|
-1, //linenumber
|
|
|
|
|
description);
|
2009-11-11 09:54:13 +01:00
|
|
|
//qDebug()<<"m_regExpLinker"<<m_regExpLinker.cap(2);
|
2009-02-05 17:19:27 +01:00
|
|
|
} else if (m_regExp.indexIn(lne) > -1) {
|
2009-11-11 09:54:13 +01:00
|
|
|
TaskWindow::TaskType type;
|
2008-12-02 12:01:29 +01:00
|
|
|
if (m_regExp.cap(5) == "warning")
|
2009-11-11 09:54:13 +01:00
|
|
|
type = TaskWindow::Warning;
|
2008-12-02 12:01:29 +01:00
|
|
|
else if (m_regExp.cap(5) == "error")
|
2009-11-11 09:54:13 +01:00
|
|
|
type = TaskWindow::Error;
|
2008-12-02 12:01:29 +01:00
|
|
|
else
|
2009-11-11 09:54:13 +01:00
|
|
|
type = TaskWindow::Unknown;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
QString description = m_regExp.cap(6);
|
|
|
|
|
|
|
|
|
|
emit addToTaskWindow(
|
2009-11-10 17:29:41 +01:00
|
|
|
m_regExp.cap(1), //filename
|
|
|
|
|
type,
|
|
|
|
|
m_regExp.cap(2).toInt(), //line number
|
|
|
|
|
description);
|
2008-12-02 12:01:29 +01:00
|
|
|
} else if (m_regExpIncluded.indexIn(lne) > -1) {
|
|
|
|
|
emit addToTaskWindow(
|
2009-11-10 17:29:41 +01:00
|
|
|
m_regExpIncluded.cap(1), //filename
|
2009-11-11 09:54:13 +01:00
|
|
|
TaskWindow::Unknown,
|
2009-11-10 17:29:41 +01:00
|
|
|
m_regExpIncluded.cap(2).toInt(), //linenumber
|
|
|
|
|
lne //description
|
|
|
|
|
);
|
2008-12-02 12:01:29 +01:00
|
|
|
} else if (lne.startsWith(QLatin1String("collect2:"))) {
|
2009-02-05 17:19:27 +01:00
|
|
|
emit addToTaskWindow("", ProjectExplorer::BuildParserInterface::Error, -1, lne);
|
2009-11-10 17:29:41 +01:00
|
|
|
} else if (lne.startsWith(QLatin1String("ERROR:"))) {
|
|
|
|
|
// Triggered by cpp on windows.
|
|
|
|
|
emit addToTaskWindow(QString(), ProjectExplorer::BuildParserInterface::Error, -1, lne);
|
|
|
|
|
} else if (lne == QLatin1String("* cpp failed")) {
|
|
|
|
|
// Triggered by cpp/make on windows.
|
|
|
|
|
emit addToTaskWindow(QString(), ProjectExplorer::BuildParserInterface::Error, -1, lne);
|
2009-11-09 14:57:45 +01:00
|
|
|
}
|
|
|
|
|
}
|