From cbab381bda49638e424e4ea079e90a700f4898ae Mon Sep 17 00:00:00 2001 From: Andy Cedilnik Date: Thu, 30 Sep 2004 16:20:23 -0400 Subject: ENH: Add support for SourceFile and LineNumber --- Source/CTest/cmCTestBuildHandler.cxx | 46 ++++++++++++++++++++++++++++++------ Source/CTest/cmCTestBuildHandler.h | 10 ++++++++ 2 files changed, 49 insertions(+), 7 deletions(-) diff --git a/Source/CTest/cmCTestBuildHandler.cxx b/Source/CTest/cmCTestBuildHandler.cxx index 3cebbb8..a6f1525 100644 --- a/Source/CTest/cmCTestBuildHandler.cxx +++ b/Source/CTest/cmCTestBuildHandler.cxx @@ -37,13 +37,6 @@ #include -//---------------------------------------------------------------------- -cmCTestBuildHandler::cmCTestBuildHandler() -{ - m_Verbose = false; - m_CTest = 0; -} - static const char* cmCTestErrorMatches[] = { "^[Bb]us [Ee]rror", "^[Ss]egmentation [Vv]iolation", @@ -138,6 +131,34 @@ static const char* cmCTestWarningExceptions[] = { 0 }; +static cmCTestBuildHandler::cmCTestCompileErrorWarningRex +cmCTestWarningErrorFileLine[] = { + { "^Warning W[0-9]+ ([a-zA-Z.\\:/0-9_+ ~-]+) ([0-9]+):", 1, 2, 0 }, + { "^([a-zA-Z./0-9_+ ~-]+):([0-9]+):", 1, 2, 0 }, + { "^([a-zA-Z.\\:/0-9_+ ~-]+)\\(([0-9]+)\\)", 1, 2, 0 }, + { "^([a-zA-Z./0-9_+ ~-]+)\\(([0-9]+)\\)", 1, 2, 0 }, + { "\"([a-zA-Z./0-9_+ ~-]+)\", line ([0-9]+)", 1, 2, 0 }, + { "File = ([a-zA-Z./0-9_+ ~-]+), Line = ([0-9]+)", 1, 2, 0 }, + { 0, 0, 0, 0 } +}; + +//---------------------------------------------------------------------- +cmCTestBuildHandler::cmCTestBuildHandler() +{ + m_Verbose = false; + m_CTest = 0; + int cc; + for ( cc = 0; cmCTestWarningErrorFileLine[cc].m_RegularExpressionString; ++ cc ) + { + if ( !cmCTestWarningErrorFileLine[cc].m_RegularExpression.compile( + cmCTestWarningErrorFileLine[cc].m_RegularExpressionString) ) + { + std::cout << "Problem Compiling regular expression: " + << cmCTestWarningErrorFileLine[cc].m_RegularExpressionString << std::endl; + } + } +} + //---------------------------------------------------------------------- void cmCTestBuildHandler::PopulateCustomVectors(cmMakefile *mf) @@ -421,6 +442,17 @@ void cmCTestBuildHandler::GenerateDartBuildOutput( << "\t\t" << cm->m_LogLine << "\n" << "\t\t" << m_CTest->MakeXMLSafe(cm->m_Text) << "\n" << std::endl; + int cc; + for ( cc = 0; cmCTestWarningErrorFileLine[cc].m_RegularExpressionString; ++ cc ) + { + cmsys::RegularExpression* re = &cmCTestWarningErrorFileLine[cc].m_RegularExpression; + if ( re->find(cm->m_Text.c_str() ) ) + { + cm->m_SourceFile = re->match(cmCTestWarningErrorFileLine[cc].m_FileIndex); + cm->m_LineNumber = atoi(re->match(cmCTestWarningErrorFileLine[cc].m_LineIndex).c_str()); + break; + } + } if ( cm->m_SourceFile.size() > 0 ) { os << "\t\t" << cm->m_SourceFile << "" diff --git a/Source/CTest/cmCTestBuildHandler.h b/Source/CTest/cmCTestBuildHandler.h index ec4c14f..2f63957 100644 --- a/Source/CTest/cmCTestBuildHandler.h +++ b/Source/CTest/cmCTestBuildHandler.h @@ -22,6 +22,8 @@ #include "cmStandardIncludes.h" #include "cmListFileCache.h" +#include + class cmCTest; class cmMakefile; @@ -60,6 +62,14 @@ private: std::string m_PostContext; }; + struct cmCTestCompileErrorWarningRex + { + char* m_RegularExpressionString; + int m_FileIndex; + int m_LineIndex; + cmsys::RegularExpression m_RegularExpression; + }; + // generate the XML output void GenerateDartBuildOutput(std::ostream& os, std::vector, -- cgit v0.12