2016-09-27 22:01:08 +03:00
|
|
|
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
2004-09-07 18:37:39 +04:00
|
|
|
#ifndef cmCTestBuildHandler_h
|
|
|
|
#define cmCTestBuildHandler_h
|
|
|
|
|
2016-08-24 23:01:40 +03:00
|
|
|
#include <cmConfigure.h>
|
2016-04-29 16:40:20 +03:00
|
|
|
|
2016-08-24 23:01:40 +03:00
|
|
|
#include "cmCTestGenericHandler.h"
|
|
|
|
#include "cmTypeMacro.h"
|
2004-09-07 18:37:39 +04:00
|
|
|
|
2004-10-01 00:20:23 +04:00
|
|
|
#include <cmsys/RegularExpression.hxx>
|
2015-01-12 23:11:16 +03:00
|
|
|
#include <deque>
|
2016-08-24 23:01:40 +03:00
|
|
|
#include <iosfwd>
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
2015-01-12 23:11:16 +03:00
|
|
|
|
2004-09-07 18:37:39 +04:00
|
|
|
class cmMakefile;
|
2015-05-24 22:36:12 +03:00
|
|
|
class cmXMLWriter;
|
2004-09-07 18:37:39 +04:00
|
|
|
|
|
|
|
/** \class cmCTestBuildHandler
|
|
|
|
* \brief A class that handles ctest -S invocations
|
|
|
|
*
|
|
|
|
*/
|
2005-01-27 19:43:22 +03:00
|
|
|
class cmCTestBuildHandler : public cmCTestGenericHandler
|
2004-09-07 18:37:39 +04:00
|
|
|
{
|
|
|
|
public:
|
2005-06-17 21:04:56 +04:00
|
|
|
cmTypeMacro(cmCTestBuildHandler, cmCTestGenericHandler);
|
2004-09-07 18:37:39 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The main entry point for this class
|
|
|
|
*/
|
2016-06-27 22:25:27 +03:00
|
|
|
int ProcessHandler() CM_OVERRIDE;
|
2006-03-09 19:17:10 +03:00
|
|
|
|
2004-09-07 18:37:39 +04:00
|
|
|
cmCTestBuildHandler();
|
2006-03-09 19:17:10 +03:00
|
|
|
|
2016-06-27 22:25:27 +03:00
|
|
|
void PopulateCustomVectors(cmMakefile* mf) CM_OVERRIDE;
|
2004-09-07 18:37:39 +04:00
|
|
|
|
2005-06-17 21:04:56 +04:00
|
|
|
/**
|
|
|
|
* Initialize handler
|
|
|
|
*/
|
2016-06-27 22:25:27 +03:00
|
|
|
void Initialize() CM_OVERRIDE;
|
2006-03-09 19:17:10 +03:00
|
|
|
|
2016-05-16 17:34:04 +03:00
|
|
|
int GetTotalErrors() { return this->TotalErrors; }
|
|
|
|
int GetTotalWarnings() { return this->TotalWarnings; }
|
2009-12-04 20:09:01 +03:00
|
|
|
|
2004-10-01 02:06:29 +04:00
|
|
|
private:
|
2009-12-04 20:09:01 +03:00
|
|
|
std::string GetMakeCommand();
|
|
|
|
|
2005-06-01 23:59:22 +04:00
|
|
|
//! Run command specialized for make and configure. Returns process status
|
|
|
|
// and retVal is return value or exception.
|
2016-05-16 17:34:04 +03:00
|
|
|
int RunMakeCommand(const char* command, int* retVal, const char* dir,
|
|
|
|
int timeout, std::ostream& ofs);
|
2005-06-01 23:59:22 +04:00
|
|
|
|
2016-05-16 17:34:04 +03:00
|
|
|
enum
|
|
|
|
{
|
2005-06-01 23:59:22 +04:00
|
|
|
b_REGULAR_LINE,
|
|
|
|
b_WARNING_LINE,
|
|
|
|
b_ERROR_LINE
|
|
|
|
};
|
|
|
|
|
2004-10-01 02:06:29 +04:00
|
|
|
class cmCTestCompileErrorWarningRex
|
2016-05-16 17:34:04 +03:00
|
|
|
{
|
2004-10-01 02:06:29 +04:00
|
|
|
public:
|
|
|
|
cmCTestCompileErrorWarningRex() {}
|
2006-03-10 23:03:09 +03:00
|
|
|
int FileIndex;
|
|
|
|
int LineIndex;
|
|
|
|
cmsys::RegularExpression RegularExpression;
|
2016-05-16 17:34:04 +03:00
|
|
|
};
|
2004-10-01 01:27:58 +04:00
|
|
|
|
2004-09-07 18:37:39 +04:00
|
|
|
struct cmCTestBuildErrorWarning
|
|
|
|
{
|
2016-05-16 17:34:04 +03:00
|
|
|
bool Error;
|
|
|
|
int LogLine;
|
2006-03-10 23:03:09 +03:00
|
|
|
std::string Text;
|
|
|
|
std::string SourceFile;
|
|
|
|
std::string SourceFileTail;
|
2016-05-16 17:34:04 +03:00
|
|
|
int LineNumber;
|
2006-03-10 23:03:09 +03:00
|
|
|
std::string PreContext;
|
|
|
|
std::string PostContext;
|
2004-09-07 18:37:39 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
// generate the XML output
|
2015-05-24 22:36:12 +03:00
|
|
|
void GenerateXMLHeader(cmXMLWriter& xml);
|
|
|
|
void GenerateXMLLaunched(cmXMLWriter& xml);
|
|
|
|
void GenerateXMLLogScraped(cmXMLWriter& xml);
|
|
|
|
void GenerateXMLFooter(cmXMLWriter& xml, double elapsed_build_time);
|
2009-02-11 23:18:08 +03:00
|
|
|
bool IsLaunchedErrorFile(const char* fname);
|
|
|
|
bool IsLaunchedWarningFile(const char* fname);
|
2004-09-07 18:37:39 +04:00
|
|
|
|
2016-05-16 17:34:04 +03:00
|
|
|
std::string StartBuild;
|
|
|
|
std::string EndBuild;
|
|
|
|
double StartBuildTime;
|
|
|
|
double EndBuildTime;
|
2006-03-09 19:17:10 +03:00
|
|
|
|
2014-02-10 09:21:34 +04:00
|
|
|
std::vector<std::string> CustomErrorMatches;
|
|
|
|
std::vector<std::string> CustomErrorExceptions;
|
|
|
|
std::vector<std::string> CustomWarningMatches;
|
|
|
|
std::vector<std::string> CustomWarningExceptions;
|
2009-02-11 23:18:08 +03:00
|
|
|
std::vector<std::string> ReallyCustomWarningMatches;
|
|
|
|
std::vector<std::string> ReallyCustomWarningExceptions;
|
2006-03-10 23:03:09 +03:00
|
|
|
std::vector<cmCTestCompileErrorWarningRex> ErrorWarningFileLineRegex;
|
2005-06-01 23:59:22 +04:00
|
|
|
|
2006-03-10 23:03:09 +03:00
|
|
|
std::vector<cmsys::RegularExpression> ErrorMatchRegex;
|
|
|
|
std::vector<cmsys::RegularExpression> ErrorExceptionRegex;
|
|
|
|
std::vector<cmsys::RegularExpression> WarningMatchRegex;
|
|
|
|
std::vector<cmsys::RegularExpression> WarningExceptionRegex;
|
2005-06-01 23:59:22 +04:00
|
|
|
|
2006-01-27 21:46:33 +03:00
|
|
|
typedef std::deque<char> t_BuildProcessingQueueType;
|
|
|
|
|
2006-03-09 19:17:10 +03:00
|
|
|
void ProcessBuffer(const char* data, int length, size_t& tick,
|
2016-05-16 17:34:04 +03:00
|
|
|
size_t tick_len, std::ostream& ofs,
|
|
|
|
t_BuildProcessingQueueType* queue);
|
2005-06-01 23:59:22 +04:00
|
|
|
int ProcessSingleLine(const char* data);
|
|
|
|
|
2016-05-16 17:34:04 +03:00
|
|
|
t_BuildProcessingQueueType BuildProcessingQueue;
|
|
|
|
t_BuildProcessingQueueType BuildProcessingErrorQueue;
|
|
|
|
size_t BuildOutputLogSize;
|
|
|
|
std::vector<char> CurrentProcessingLine;
|
2005-06-01 23:59:22 +04:00
|
|
|
|
2016-05-16 17:34:04 +03:00
|
|
|
std::string SimplifySourceDir;
|
|
|
|
std::string SimplifyBuildDir;
|
|
|
|
size_t OutputLineCounter;
|
2005-06-01 23:59:22 +04:00
|
|
|
typedef std::vector<cmCTestBuildErrorWarning> t_ErrorsAndWarningsVector;
|
2016-05-16 17:34:04 +03:00
|
|
|
t_ErrorsAndWarningsVector ErrorsAndWarnings;
|
|
|
|
t_ErrorsAndWarningsVector::iterator LastErrorOrWarning;
|
|
|
|
size_t PostContextCount;
|
|
|
|
size_t MaxPreContext;
|
|
|
|
size_t MaxPostContext;
|
|
|
|
std::deque<std::string> PreContext;
|
|
|
|
|
|
|
|
int TotalErrors;
|
|
|
|
int TotalWarnings;
|
|
|
|
char LastTickChar;
|
|
|
|
|
|
|
|
bool ErrorQuotaReached;
|
|
|
|
bool WarningQuotaReached;
|
|
|
|
|
|
|
|
int MaxErrors;
|
|
|
|
int MaxWarnings;
|
2009-02-11 23:18:08 +03:00
|
|
|
|
|
|
|
bool UseCTestLaunch;
|
|
|
|
std::string CTestLaunchDir;
|
|
|
|
class LaunchHelper;
|
2016-08-24 23:01:40 +03:00
|
|
|
|
2009-02-11 23:18:08 +03:00
|
|
|
friend class LaunchHelper;
|
|
|
|
class FragmentCompare;
|
2004-09-07 18:37:39 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|