You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
320 lines
16 KiB
320 lines
16 KiB
/***************************************************************************
|
|
* Copyright (C) 1999-2001 by Bernd Gehrmann and the KDevelop Team *
|
|
* bernd@tdevelop.org *
|
|
* *
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
* it under the terms of the GNU General Public License as published by *
|
|
* the Free Software Foundation; either version 2 of the License, or *
|
|
* (at your option) any later version. *
|
|
* *
|
|
***************************************************************************/
|
|
|
|
#include <tqdatetime.h>
|
|
#include <kdebug.h>
|
|
|
|
#include "makeactionfilter.h"
|
|
#include "makeactionfilter.moc"
|
|
#include "makeitem.h"
|
|
|
|
#include <klocale.h>
|
|
|
|
//#define DEBUG
|
|
|
|
MakeActionFilter::ActionFormat::ActionFormat( const TQString& _action, const TQString& _tool, const char * regExp, int file )
|
|
: m_action( _action )
|
|
, m_expression( regExp )
|
|
, m_tool( _tool )
|
|
, m_toolGroup(-1)
|
|
, m_fileGroup( file )
|
|
{
|
|
}
|
|
|
|
MakeActionFilter::ActionFormat::ActionFormat( const TQString& _action, int tool, int file, const char * regExp)
|
|
: m_action( _action )
|
|
, m_expression( regExp )
|
|
, m_tool()
|
|
, m_toolGroup(tool)
|
|
, m_fileGroup( file )
|
|
{
|
|
}
|
|
|
|
TQString MakeActionFilter::ActionFormat::tool()
|
|
{
|
|
if (m_toolGroup==-1)
|
|
return m_tool;
|
|
return m_expression.cap(m_toolGroup);
|
|
}
|
|
|
|
TQString MakeActionFilter::ActionFormat::file()
|
|
{
|
|
return m_expression.cap(m_fileGroup);
|
|
}
|
|
|
|
bool MakeActionFilter::ActionFormat::matches(const TQString& line)
|
|
{
|
|
return ( m_expression.search( line ) != -1 );
|
|
}
|
|
|
|
|
|
MakeActionFilter::MakeActionFilter( OutputFilter& next )
|
|
: OutputFilter( next )
|
|
{
|
|
|
|
#ifdef DEBUG
|
|
test();
|
|
#endif
|
|
}
|
|
|
|
//NOTE: whenever you discover a case that is not correctly recognized by the filter, please add it as a test
|
|
//item and be sure that your modifications don't break the already existing test cases.
|
|
|
|
// returns an array of ActionFormat
|
|
MakeActionFilter::ActionFormat* MakeActionFilter::actionFormats()
|
|
{
|
|
static ActionFormat formats[] = {
|
|
ActionFormat( i18n("compiling"), 1, 2, "(?:^|[^=])\\b(gcc|CC|cc|distcc|c\\+\\+|g\\+\\+)\\s+.*-c.*[/ '\\\\]+(\\w+\\.(?:cpp|CPP|c|C|cxx|CXX|cs|java|hpf|f|F|f90|F90|f95|F95))"),
|
|
ActionFormat( i18n("compiling"), 1, 1, "^compiling (.*)" ), //unsermake
|
|
ActionFormat( i18n("compiling"), 1, 1, "\\[.+%\\] Building .* object (.*)" ), //cmake
|
|
|
|
ActionFormat( i18n("built"), 1, 1, "\\[.+%\\] Built target (.*)" ), //cmake
|
|
ActionFormat( i18n("generating"), 1, 1, "\\[.+%\\] Generating (.*)" ), //cmake
|
|
|
|
//moc and uic
|
|
ActionFormat( i18n("generating"), 1, 2, "/(moc|uic)\\b.*\\s-o\\s([^\\s;]+)"),
|
|
ActionFormat( i18n("generating"), 1, 2, "^generating (.*)" ), //unsermake
|
|
|
|
ActionFormat( i18n("linking"), "libtool", "/bin/sh\\s.*libtool.*--mode=link\\s.*\\s-o\\s([^\\s;]+)", 1 ),
|
|
//can distcc link too ?
|
|
ActionFormat( i18n("linking"), 1, 2, "(gcc|CC|cc|c\\+\\+|g\\+\\+)\\S* (?:\\S* )*-o ([^\\s;]+)"),
|
|
ActionFormat( i18n("linking"), 1, 2, "^linking (.*)" ), //unsermaker
|
|
ActionFormat( i18n("linking"), 1, 1, "^Linking .* module (.*)" ), //cmake
|
|
ActionFormat( i18n("linking"), 1, 1, "^Linking (.*)" ), //cmake
|
|
|
|
ActionFormat( i18n("creating"), "", "/(?:bin/sh\\s.*mkinstalldirs).*\\s([^\\s;]+)", 1 ),
|
|
ActionFormat( i18n("installing"), "", "/(?:usr/bin/install|bin/sh\\s.*mkinstalldirs|bin/sh\\s.*libtool.*--mode=install).*\\s([^\\s;]+)", 1 ),
|
|
ActionFormat( i18n("generating"), "dcopidl", "dcopidl .* > ([^\\s;]+)", 1 ),
|
|
ActionFormat( i18n("compiling"), "dcopidl2cpp", "dcopidl2cpp (?:\\S* )*([^\\s;]+)", 1 ),
|
|
ActionFormat( i18n("installing"), 1, 1, "-- Installing (.*)" ), //cmake
|
|
|
|
ActionFormat( TQString(), TQString(), 0, 0 )
|
|
};
|
|
|
|
return formats;
|
|
}
|
|
|
|
void MakeActionFilter::processLine( const TQString& line )
|
|
{
|
|
ActionItem* actionItem = matchLine( line );
|
|
if ( actionItem != NULL )
|
|
{
|
|
emit item( actionItem );
|
|
}
|
|
else
|
|
{
|
|
OutputFilter::processLine( line );
|
|
}
|
|
}
|
|
|
|
ActionItem* MakeActionFilter::matchLine( const TQString& line )
|
|
{
|
|
#ifdef DEBUG
|
|
TQTime t;
|
|
t.start();
|
|
#endif
|
|
/// \FIXME This is very slow, possibly due to the regexr matching. It can take
|
|
//900-1000ms to execute on an Athlon XP 2000+, while the UI is completely blocked.
|
|
int i = 0;
|
|
ActionFormat* aFormats = actionFormats();
|
|
ActionFormat* format = &aFormats[i];
|
|
|
|
while ( !format->action().isNull() )
|
|
{
|
|
// kdDebug(9004) << "Testing filter: " << format->action << ": " << format->tool << endl;
|
|
if ( format->matches( line ) )
|
|
{
|
|
ActionItem *actionItem = new ActionItem( format->action(), format->file(), format->tool(), line );
|
|
kdDebug( 9004 ) << "Found: " << actionItem->m_action << " " << actionItem->m_file << "(" << actionItem->m_tool << ")" << endl;
|
|
return actionItem;
|
|
}
|
|
#ifdef DEBUG
|
|
if ( t.elapsed() > 100 )
|
|
kdDebug(9004) << "MakeActionFilter::processLine: SLOW regexp matching: " << t.elapsed() << " ms \n";
|
|
#endif
|
|
format = &aFormats[++i];
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
struct TestItem
|
|
{
|
|
TestItem() {}
|
|
TestItem( const TQString& _line, const TQString& _action, const TQString& _tool, const TQString& _file )
|
|
: line( _line )
|
|
, action( _action )
|
|
, tool( _tool )
|
|
, file( _file )
|
|
{}
|
|
TQString line;
|
|
TQString action;
|
|
TQString tool;
|
|
TQString file;
|
|
};
|
|
|
|
#ifdef DEBUG
|
|
|
|
void MakeActionFilter::test()
|
|
{
|
|
static TQValueList<TestItem> testItems = TQValueList<TestItem>()
|
|
|
|
<< TestItem( // simple qmake compile
|
|
"g++ -c -pipe -Wall -W -O2 -DTQT_NO_DEBUG -I/home/john/src/kde/qt-copy/mkspecs/default -I. "
|
|
"-I/home/john/src/kde/qt-copy/include -o test.o test.cpp",
|
|
"compiling", "g++", "test.cpp" )
|
|
<< TestItem( // simple qmake compile different option order
|
|
"g++ -c -o test.o -pipe -Wall -W -O2 -DTQT_NO_DEBUG -I/home/john/src/kde/qt-copy/mkspecs/default -I. "
|
|
"-I/home/john/src/kde/qt-copy/include test.cpp",
|
|
"compiling", "g++", "test.cpp" )
|
|
<< TestItem( // simple qmake link
|
|
"g++ -o ../bin/test test.o -Wl,-rpath,/home/john/src/kde/qt-copy/lib -L/home/john/src/kde/qt-copy/lib "
|
|
"-L/usr/X11R6/lib -lqt-mt -lXext -lX11 -lm",
|
|
"linking", "g++", "../bin/test" )
|
|
<< TestItem( // automake 1.7, srcdir != builddir
|
|
"if /bin/sh ../../libtool --silent --mode=compile --tag=CXX g++ -DHAVE_CONFIG_H -I. "
|
|
"-I/home/john/src/kde/tdevelop/lib/interfaces -I../.. -I/usr/local/kde/include -I/home/john/src/kde/qt-copy/include "
|
|
"-I/usr/X11R6/include -DTQT_THREAD_SUPPORT -D_REENTRANT -Wnon-virtual-dtor -Wno-long-long -Wundef -Wall -pedantic -W "
|
|
"-Wpointer-arith -Wmissing-prototypes -Wwrite-strings -ansi -D_XOPEN_SOURCE=500 -D_BSD_SOURCE -Wcast-align -Wconversion "
|
|
"-Wchar-subscripts -fno-builtin -g3 -Wformat-security -Wmissing-format-attribute -fno-exceptions -fno-check-new "
|
|
"-fno-common -MT kdevcore.lo -MD -MP -MF \".deps/kdevcore.Tpo\" -c -o kdevcore.lo `test -f "
|
|
"'/home/john/src/kde/tdevelop/lib/interfaces/kdevcore.cpp' || echo "
|
|
"'/home/john/src/kde/tdevelop/lib/interfaces/'`/home/john/src/kde/tdevelop/lib/interfaces/kdevcore.cpp; then mv "
|
|
"\".deps/kdevcore.Tpo\" \".deps/kdevcore.Plo\"; else rm -f \".deps/kdevcore.Tpo\"; exit 1; fi",
|
|
"compiling", "g++", "kdevcore.cpp" )
|
|
<< TestItem( // automake 1.7, srcdir != builddir
|
|
"if g++ -DHAVE_CONFIG_H -I. -I/home/john/src/kde/tdevelop/src -I.. -I/home/john/src/kde/tdevelop/lib/interfaces "
|
|
"-I/home/john/src/kde/tdevelop/lib/sourceinfo -I/home/john/src/kde/tdevelop/lib/util -I/home/john/src/kde/tdevelop/lib "
|
|
"-I/home/john/src/kde/tdevelop/lib/qextmdi/include -I/home/john/src/kde/tdevelop/lib/structure -I/usr/local/kde/include "
|
|
"-I/home/john/src/kde/qt-copy/include -I/usr/X11R6/include -DTQT_THREAD_SUPPORT -D_REENTRANT -Wnon-virtual-dtor "
|
|
"-Wno-long-long -Wundef -Wall -pedantic -W -Wpointer-arith -Wmissing-prototypes -Wwrite-strings -ansi "
|
|
"-D_XOPEN_SOURCE=500 -D_BSD_SOURCE -Wcast-align -Wconversion -Wchar-subscripts -fno-builtin -g3 -Wformat-security "
|
|
"-Wmissing-format-attribute -fno-exceptions -fno-check-new -fno-common -MT mainwindowideal.o -MD -MP -MF "
|
|
"\".deps/mainwindowideal.Tpo\" -c -o mainwindowideal.o `test -f '/home/john/src/kde/tdevelop/src/mainwindowideal.cpp' "
|
|
"|| echo '/home/john/src/kde/tdevelop/src/'`/home/john/src/kde/tdevelop/src/mainwindowideal.cpp; then mv "
|
|
"\".deps/mainwindowideal.Tpo\" \".deps/mainwindowideal.Po\"; else rm -f \".deps/mainwindowideal.Tpo\"; exit 1; fi",
|
|
"compiling", "g++", "mainwindowideal.cpp" )
|
|
<< TestItem( // automake and libtool compiling *.c files
|
|
"if /bin/sh ../../libtool --silent --tag=CC --mode=compile gcc -DHAVE_CONFIG_H -I. -I. -I../.. -I../../lib/interfaces"
|
|
"-I../../lib/util -I/opt/trinity/include -I/usr/lib/qt3/include -I/usr/X11R6/include -DTQT_THREAD_SUPPORT -D_REENTRANT "
|
|
"-std=iso9899:1990 -W -Wall -Wchar-subscripts -Wshadow -Wpointer-arith -Wmissing-prototypes -Wwrite-strings "
|
|
"-D_XOPEN_SOURCE=500 -D_BSD_SOURCE -g3 -fno-inline -Wformat-security -Wmissing-format-attribute -MT readtags.lo "
|
|
"-MD -MP -MF \".deps/readtags.Tpo\" -c -o readtags.lo readtags.c; then mv -f \".deps/readtags.Tpo\" "
|
|
"\".deps/readtags.Plo\"; else rm -f \".deps/readtags.Tpo\"; exit 1; fi",
|
|
i18n("compiling"), "gcc", "readtags.c" )
|
|
<< TestItem(
|
|
"source='makewidget.cpp' object='makewidget.lo' libtool=yes depfile='.deps/makewidget.Plo' "
|
|
"tmpdepfile='.deps/makewidget.TPlo' depmode=gcc3 /bin/sh ../../admin/depcomp /bin/sh ../../libtool --mode=compile "
|
|
"--tag=CXX g++ -DHAVE_CONFIG_H -I. -I. -I../.. -I../../lib/interfaces -I../../lib/util -I/opt/trinity/include "
|
|
"-I/usr/lib/qt3/include -I/usr/X11R6/include -DTQT_THREAD_SUPPORT -D_REENTRANT -Wnon-virtual-dtor -Wno-long-long -Wundef "
|
|
"-Wall -pedantic -W -Wpointer-arith -Wmissing-prototypes -Wwrite-strings -ansi -D_XOPEN_SOURCE=500 -D_BSD_SOURCE "
|
|
"-Wcast-align -Wconversion -fno-builtin -g -O2 -g3 -O0 -fno-exceptions -fno-check-new -c -o makewidget.lo `test -f "
|
|
"'makewidget.cpp' || echo './'`makewidget.cpp",
|
|
"compiling", "g++", "makewidget.cpp" )
|
|
<< TestItem( // automake 1.7, srcdir != builddir
|
|
"/bin/sh ../../libtool --silent --mode=link --tag=CXX g++ -Wnon-virtual-dtor -Wno-long-long -Wundef -Wall -pedantic "
|
|
"-W -Wpointer-arith -Wmissing-prototypes -Wwrite-strings -ansi -D_XOPEN_SOURCE=500 -D_BSD_SOURCE -Wcast-align "
|
|
"-Wconversion -Wchar-subscripts -fno-builtin -g3 -Wformat-security -Wmissing-format-attribute -fno-exceptions "
|
|
"-fno-check-new -fno-common -o libkdevoutputviews.la.closure libkdevoutputviews_la_closure.lo -L/usr/X11R6/lib "
|
|
"-L/home/john/src/kde/qt-copy/lib -L/usr/local/kde/lib -avoid-version -module -no-undefined -R /usr/local/kde/lib "
|
|
"-R /home/john/src/kde/qt-copy/lib -R /usr/X11R6/lib outputviewsfactory.lo makeviewpart.lo makewidget.lo "
|
|
"appoutputviewpart.lo appoutputwidget.lo directorystatusmessagefilter.lo outputfilter.lo compileerrorfilter.lo "
|
|
"commandcontinuationfilter.lo makeitem.lo makeactionfilter.lo otherfilter.lo ../../lib/libtdevelop.la",
|
|
"linking", "libtool", "libkdevoutputviews.la.closure" )
|
|
<< TestItem( //libtool, linking 2
|
|
"/bin/sh ../libtool --silent --mode=link --tag=CXX g++ -Wnon-virtual-dtor -Wno-long-long -Wundef -Wall -pedantic "
|
|
"-W -Wpointer-arith -Wwrite-strings -ansi -D_XOPEN_SOURCE=500 -D_BSD_SOURCE -Wcast-align -Wconversion -Wchar-subscripts "
|
|
"-fno-builtin -g3 -fno-exceptions -fno-check-new -fno-common -o libkfilereplacepart.la.closure libkfilereplacepart_la_closure.lo "
|
|
"-module -no-undefined -L/usr/X11R6/lib -L/usr/lib/qt3/lib -L/opt/trinity/lib -version-info 1:0:0 kfilereplacepart.lo kfilereplacedoc.lo "
|
|
"kfilereplaceview.lo kaboutkfilereplace.lo kaddstringdlg.lo kconfirmdlg.lo kernel.lo kexpression.lo kfilereplacepref.lo "
|
|
"klistviewstring.lo knewprojectdlg.lo koptionsdlg.lo kresultview.lo filelib.lo knewprojectdlgs.lo -lkio -lkparts -lkhtml",
|
|
"linking", "libtool", "libkfilereplacepart.la.closure")
|
|
<< TestItem( //libtool, linking 3
|
|
"/bin/sh ../libtool --silent --mode=link --tag=CXX g++ -Wnon-virtual-dtor -Wno-long-long -Wundef -Wall -pedantic "
|
|
"-W -Wpointer-arith -Wwrite-strings -ansi -D_XOPEN_SOURCE=500 -D_BSD_SOURCE -Wcast-align -Wconversion -Wchar-subscripts "
|
|
"-fno-builtin -g3 -fno-exceptions -fno-check-new -fno-common -o libkfilereplacepart.la -rpath /opt/trinity/lib/trinity "
|
|
"-module -no-undefined -L/usr/X11R6/lib -L/usr/lib/qt3/lib -L/opt/trinity/lib -version-info 1:0:0 kfilereplacepart.lo "
|
|
"kfilereplacedoc.lo kfilereplaceview.lo kaboutkfilereplace.lo kaddstringdlg.lo kconfirmdlg.lo kernel.lo kexpression.lo "
|
|
"kfilereplacepref.lo klistviewstring.lo knewprojectdlg.lo koptionsdlg.lo kresultview.lo filelib.lo knewprojectdlgs.lo -lkio -lkparts -lkhtml",
|
|
"linking", "libtool", "libkfilereplacepart.la")
|
|
<< TestItem( //automake, builddir!=srcdir, libtool=no, compiling
|
|
" g++ -DHAVE_CONFIG_H -I. -I/home/andris/cvs-developement/head/quanta/quanta/project "
|
|
"-I../.. -I/home/andris/cvs-developement/head/quanta/quanta/dialogs -I/opt/trinity/include -I/usr/lib/qt3/include -I/usr/X11R6/include "
|
|
"-I../../quanta/dialogs -DTQT_THREAD_SUPPORT -D_REENTRANT -DKOMMANDER -DDESIGNER -DTQT_NO_SQL -DHAVE_KDE -Wnon-virtual-dtor "
|
|
"-Wno-long-long -Wundef -Wall -pedantic -W -Wpointer-arith -Wmissing-prototypes -Wwrite-strings -ansi -D_XOPEN_SOURCE=500 -D_BSD_SOURCE "
|
|
"-Wcast-align -Wconversion -Wchar-subscripts -fno-builtin -g3 -DKDE_NO_COMPAT -fno-exceptions -fno-check-new -fno-common -c -o project.o "
|
|
"`test -f '/home/andris/cvs-developement/head/quanta/quanta/project/project.cpp' || "
|
|
"echo '/home/andris/cvs-developement/head/quanta/quanta/project/'`/home/andris/cvs-developement/head/quanta/quanta/project/project.cpp ",
|
|
"compiling", "g++", "project.cpp")
|
|
<< TestItem(
|
|
"/usr/local/kde/bin/dcopidl /home/john/src/kde/tdevelop/lib/interfaces/KDevAppFrontendIface.h > KDevAppFrontendIface.kidl "
|
|
"|| ( rm -f KDevAppFrontendIface.kidl ; /bin/false )",
|
|
"generating", "dcopidl", "KDevAppFrontendIface.kidl" )
|
|
<< TestItem(
|
|
"/usr/local/kde/bin/dcopidl2cpp --c++-suffix cpp --no-signals --no-stub KDevAppFrontendIface.kidl",
|
|
"compiling", "dcopidl2cpp", "KDevAppFrontendIface.kidl" )
|
|
<< TestItem( //install
|
|
"/usr/bin/install -c -p -m 644 /home/andris/development/quanta/quanta/kommander/editor/kmdr-editor.desktop "
|
|
"/opt/trinity/share/applnk/Editors/kmdr-editor.desktop", "installing", "", "/opt/trinity/share/applnk/Editors/kmdr-editor.desktop")
|
|
<< TestItem( //libtool install
|
|
"/bin/sh ../../libtool --silent --mode=install /usr/bin/install -c -p libkommanderwidgets.la "
|
|
"/opt/trinity/lib/libkommanderwidgets.la", "installing", "", "/opt/trinity/lib/libkommanderwidgets.la")
|
|
<< TestItem( //libtool, automake 1.8
|
|
"if g++ -DHAVE_CONFIG_H -I. -I/home/andris/ "
|
|
"-DBUILD_KAFKAPART -MT quanta_init.o -MD -MP -MF \".deps/quanta_init.Tpo\" -c -o quanta_init.o "
|
|
"quanta_init.cpp; "
|
|
"then mv -f \".deps/quanta_init.Tpo\" \".deps/quanta_init.Po\"; else rm -f \".deps/quanta_init.Tpo\"; "
|
|
"exit 1; fi",
|
|
"compiling", "g++", "tquanta_init.cpp")
|
|
<< TestItem( //libtool, automake 1.8, file with full path
|
|
"if g++ -DHAVE_CONFIG_H -I. -I/home/andris/ "
|
|
"-DBUILD_KAFKAPART -MT quanta_init.o -MD -MP -MF \".deps/quanta_init.Tpo\" -c -o quanta_init.o "
|
|
"/home/andris/quanta_init.cpp; "
|
|
"then mv -f \".deps/quanta_init.Tpo\" \".deps/quanta_init.Po\"; else rm -f \".deps/quanta_init.Tpo\"; "
|
|
"exit 1; fi",
|
|
"compiling", "g++", "tquanta_init.cpp")
|
|
;
|
|
|
|
TQValueList<TestItem>::const_iterator it = testItems.begin();
|
|
for( ; it != testItems.end(); ++it )
|
|
{
|
|
ActionItem* actionItem = matchLine( (*it).line );
|
|
if ( actionItem == NULL )
|
|
{
|
|
kdError( 9004 ) << "MakeActionFilter::test(): match failed (no match):" << endl;
|
|
kdError( 9004 ) << (*it).line << endl;
|
|
}
|
|
else if ( actionItem->m_action != (*it).action )
|
|
{
|
|
kdError( 9004 ) << "MakeActionFilter::test(): match failed (expected action "
|
|
<< (*it).action << ", got " << actionItem->m_action << endl;
|
|
kdError( 9004 ) << (*it).line << endl;
|
|
}
|
|
else if ( actionItem->m_tool != (*it).tool )
|
|
{
|
|
kdError( 9004 ) << "MakeActionFilter::test(): match failed (expected tool "
|
|
<< (*it).tool << ", got " << actionItem->m_tool << endl;
|
|
kdError( 9004 ) << (*it).line << endl;
|
|
}
|
|
else if ( actionItem->m_file != (*it).file )
|
|
{
|
|
kdError( 9004 ) << "MakeActionFilter::test(): match failed (expected file "
|
|
<< (*it).file << ", got " << actionItem->m_file << endl;
|
|
kdError( 9004 ) << (*it).line << endl;
|
|
} else
|
|
kdDebug( 9004 ) << "Test passed, " << actionItem->m_action << " " << actionItem->m_file << " (" << actionItem->m_tool << ") found." << endl;
|
|
if ( actionItem != NULL )
|
|
delete actionItem;
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|