/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying file Copyright.txt or https://cmake.org/licensing for details. */ #ifndef cmCTestBuildHandler_h #define cmCTestBuildHandler_h #include "cmConfigure.h" // IWYU pragma: keep #include #include #include #include #include #include #include "cmsys/RegularExpression.hxx" #include "cmCTestGenericHandler.h" #include "cmDuration.h" #include "cmProcessOutput.h" class cmMakefile; class cmStringReplaceHelper; class cmXMLWriter; /** \class cmCTestBuildHandler * \brief A class that handles ctest -S invocations * */ class cmCTestBuildHandler : public cmCTestGenericHandler { public: using Superclass = cmCTestGenericHandler; using Encoding = cmProcessOutput::Encoding; /* * The main entry point for this class */ int ProcessHandler() override; cmCTestBuildHandler(); void PopulateCustomVectors(cmMakefile* mf) override; /** * Initialize handler */ void Initialize() override; int GetTotalErrors() { return this->TotalErrors; } int GetTotalWarnings() { return this->TotalWarnings; } private: std::string GetMakeCommand(); //! Run command specialized for make and configure. Returns process status // and retVal is return value or exception. int RunMakeCommand(const std::string& command, int* retVal, const char* dir, int timeout, std::ostream& ofs, Encoding encoding = cmProcessOutput::Auto); enum { b_REGULAR_LINE, b_WARNING_LINE, b_ERROR_LINE }; class cmCTestCompileErrorWarningRex { public: cmCTestCompileErrorWarningRex() {} int FileIndex; int LineIndex; cmsys::RegularExpression RegularExpression; }; struct cmCTestBuildErrorWarning { bool Error; int LogLine; std::string Text; std::string SourceFile; std::string SourceFileTail; int LineNumber; std::string PreContext; std::string PostContext; }; // generate the XML output void GenerateXMLHeader(cmXMLWriter& xml); void GenerateXMLLaunched(cmXMLWriter& xml); void GenerateXMLLogScraped(cmXMLWriter& xml); void GenerateXMLFooter(cmXMLWriter& xml, cmDuration elapsed_build_time); bool IsLaunchedErrorFile(const char* fname); bool IsLaunchedWarningFile(const char* fname); std::string StartBuild; std::string EndBuild; std::chrono::system_clock::time_point StartBuildTime; std::chrono::system_clock::time_point EndBuildTime; std::vector CustomErrorMatches; std::vector CustomErrorExceptions; std::vector CustomWarningMatches; std::vector CustomWarningExceptions; std::vector ReallyCustomWarningMatches; std::vector ReallyCustomWarningExceptions; std::vector ErrorWarningFileLineRegex; std::vector ErrorMatchRegex; std::vector ErrorExceptionRegex; std::vector WarningMatchRegex; std::vector WarningExceptionRegex; using t_BuildProcessingQueueType = std::deque; void ProcessBuffer(const char* data, size_t length, size_t& tick, size_t tick_len, std::ostream& ofs, t_BuildProcessingQueueType* queue); int ProcessSingleLine(const char* data); t_BuildProcessingQueueType BuildProcessingQueue; t_BuildProcessingQueueType BuildProcessingErrorQueue; size_t BuildOutputLogSize; std::vector CurrentProcessingLine; std::string SimplifySourceDir; std::string SimplifyBuildDir; size_t OutputLineCounter; using t_ErrorsAndWarningsVector = std::vector; t_ErrorsAndWarningsVector ErrorsAndWarnings; t_ErrorsAndWarningsVector::iterator LastErrorOrWarning; size_t PostContextCount; size_t MaxPreContext; size_t MaxPostContext; std::deque PreContext; int TotalErrors; int TotalWarnings; char LastTickChar; bool ErrorQuotaReached; bool WarningQuotaReached; int MaxErrors; int MaxWarnings; // Used to remove ANSI color codes before checking for errors and warnings. cmStringReplaceHelper* ColorRemover; bool UseCTestLaunch; std::string CTestLaunchDir; class LaunchHelper; friend class LaunchHelper; class FragmentCompare; }; #endif