From f4859295eb01773e05dcb18cc1ade8d4178c4a84 Mon Sep 17 00:00:00 2001 From: Andy Cedilnik Date: Mon, 14 Oct 2002 15:11:21 -0400 Subject: Even more cleanups, fix time on certain platforms such as windows, cygwin, and linux. Hopefully we can add entries for other platforms until try_compile works. Also escape certain characters for xml. --- Source/ctest.cxx | 140 +++++++++++++++++++++++++++++++++++++++++++------------ Source/ctest.h | 1 + 2 files changed, 111 insertions(+), 30 deletions(-) diff --git a/Source/ctest.cxx b/Source/ctest.cxx index b8a853f..4d81c9c 100644 --- a/Source/ctest.cxx +++ b/Source/ctest.cxx @@ -21,6 +21,54 @@ #include #include + +/* Implement floattime() for various platforms */ +// Taken from Python 2.1.3 + +#if defined( _WIN32 ) && !defined( __CYGWIN__ ) +# define HAVE_FTIME +# defint FTIME _ftime_ +#elif defined( __CYGWIN__ ) || defined( __linux__ ) +# include +# define HAVE_GETTIMEOFDAY +#endif + +static double +floattime(void) +{ + /* There are three ways to get the time: + (1) gettimeofday() -- resolution in microseconds + (2) ftime() -- resolution in milliseconds + (3) time() -- resolution in seconds + In all cases the return value is a float in seconds. + Since on some systems (e.g. SCO ODT 3.0) gettimeofday() may + fail, so we fall back on ftime() or time(). + Note: clock resolution does not imply clock accuracy! */ +#ifdef HAVE_GETTIMEOFDAY + { + struct timeval t; +#ifdef GETTIMEOFDAY_NO_TZ + if (gettimeofday(&t) == 0) + return (double)t.tv_sec + t.tv_usec*0.000001; +#else /* !GETTIMEOFDAY_NO_TZ */ + if (gettimeofday(&t, (struct timezone *)NULL) == 0) + return (double)t.tv_sec + t.tv_usec*0.000001; +#endif /* !GETTIMEOFDAY_NO_TZ */ + } +#endif /* !HAVE_GETTIMEOFDAY */ + { +#if defined(HAVE_FTIME) + struct timeb t; + FTIME(&t); + return (double)t.time + (double)t.millitm * (double)0.001; +#else /* !HAVE_FTIME */ + time_t secs; + time(&secs); + return (double)secs; +#endif /* !HAVE_FTIME */ + } +} + static std::string CleanString(std::string str) { std::string::size_type spos = str.find_first_not_of(" \n\t"); @@ -31,7 +79,7 @@ static std::string CleanString(std::string str) } if ( epos != str.npos ) { - epos ++; + epos = epos - spos + 1; } return str.substr(spos, epos); } @@ -105,6 +153,30 @@ static const char* cmCTestWarningExceptions[] = { 0 }; +std::string ctest::MakeXMLSafe(const std::string& str) +{ + std::string::size_type pos = 0; + cmOStringStream ost; + for ( pos = 0; pos < str.size(); pos ++ ) + { + char ch = str[pos]; + if ( ch > 126 ) + { + ost << "&" << hex << ch; + } + else + { + switch ( ch ) + { + case '&': ost << "&"; break; + case '<': ost << "<"; break; + case '>': ost << ">"; break; + default: ost << ch; + } + } + } + return ost.str(); +} bool TryExecutable(const char *dir, const char *file, std::string *fullPath, const char *subdir) @@ -646,7 +718,8 @@ void ctest::GenerateDartBuildOutput(std::ostream& os, << m_DartConfiguration["Site"] << "\">\n" << "\n" << "\t" << m_StartBuild << "\n" - << "" << m_DartConfiguration["MakeCommand"] + << "" + << this->MakeXMLSafe(m_DartConfiguration["MakeCommand"]) << "" << std::endl; std::vector::iterator it; @@ -655,7 +728,8 @@ void ctest::GenerateDartBuildOutput(std::ostream& os, cmCTestBuildErrorWarning *cm = &(*it); os << "\t<" << (cm->m_Error ? "Error" : "Warning") << ">\n" << "\t\t" << cm->m_LogLine << "\n" - << "\t\t" << cm->m_Text << "\n" << std::endl; + << "\t\t" << this->MakeXMLSafe(cm->m_Text) + << "\n" << std::endl; if ( cm->m_SourceFile.size() > 0 ) { os << "\t\t" << cm->m_SourceFile << "" @@ -671,8 +745,10 @@ void ctest::GenerateDartBuildOutput(std::ostream& os, os << "\t\t" << cm->m_LineNumber << "" << std::endl; } - os << "\t\t" << cm->m_PreContext << "\n" - << "\t\t" << cm->m_PostContext << "\n" + os << "\t\t" << this->MakeXMLSafe(cm->m_PreContext) + << "\n" + << "\t\t" << this->MakeXMLSafe(cm->m_PostContext) + << "\n" << "\t\t0\n" << "m_Error ? "Error" : "Warning") << ">\n\n" << std::endl; @@ -789,15 +865,14 @@ void ctest::ProcessDirectory(std::vector &passed, std::string output; int retVal; - clock_t clock_start, clock_finish; - double clocks_per_sec = (double)CLOCKS_PER_SEC; - clock_start = clock(); + double clock_start, clock_finish; + clock_start = floattime(); bool res = cmSystemTools::RunCommand(testCommand.c_str(), output, retVal, 0, false); - clock_finish = clock(); + clock_finish = floattime(); - cres.m_ExecutionTime = (double)(clock_finish - clock_start) / clocks_per_sec; + cres.m_ExecutionTime = (double)(clock_finish - clock_start); cres.m_FullCommandLine = testCommand; if (!res || retVal != 0) @@ -923,47 +998,52 @@ void ctest::GenerateDartOutput(std::ostream& os) << "\" BuildStamp=\"" << m_CurrentTag << "-Experimental\" Name=\"" << m_DartConfiguration["Site"] << "\">\n" << "\n" - << " " << m_StartTest << "\n" - << " \n"; + << "\t" << m_StartTest << "\n" + << "\t\n"; tm_TestResultsVector::size_type cc; for ( cc = 0; cc < m_TestResults.size(); cc ++ ) { cmCTestTestResult *result = &m_TestResults[cc]; - os << " " << result->m_Path << "/" << result->m_Name + os << "\t\t" << this->MakeXMLSafe(result->m_Path) + << "/" << this->MakeXMLSafe(result->m_Name) << "" << std::endl; } - os << " \n"; + os << "\t\n"; for ( cc = 0; cc < m_TestResults.size(); cc ++ ) { cmCTestTestResult *result = &m_TestResults[cc]; - os << " m_ReturnValue?"failed":"passed") + os << "\tm_ReturnValue?"failed":"passed") << "\">\n" - << " " << result->m_Name << "\n" - << " " << result->m_Path << "\n" - << " " << result->m_Path << "/" << result->m_Name << "\n" - << " " << result->m_FullCommandLine << "\n" - << " " << std::endl; + << "\t\t" << this->MakeXMLSafe(result->m_Name) << "\n" + << "\t\t" << this->MakeXMLSafe(result->m_Path) << "\n" + << "\t\t" << this->MakeXMLSafe(result->m_Path) + << "/" << this->MakeXMLSafe(result->m_Name) << "\n" + << "\t\t" + << this->MakeXMLSafe(result->m_FullCommandLine) + << "\n" + << "\t\t" << std::endl; if ( result->m_ReturnValue ) { - os << " " + os << "\t\t\t" << "CHILDSTATUS" << "\n" - << " " + << "\t\t\t" << result->m_ReturnValue << "" << std::endl; } - os << " " << result->m_ExecutionTime << "\n" - << " " << result->m_CompletionStatus << "\n" - << " \n" - << " " << result->m_Output << "\n" - << " \n" - << " \n" - << " " << std::endl; + << "\t\t\t\n" + << "\t\t\t\t" << this->MakeXMLSafe(result->m_Output) + << "\n" + << "\t\t\t\n" + << "\t\t\n" + << "\t" << std::endl; } - os << "" << m_EndTest << "\n" + os << "\t" << m_EndTest << "\n" << "\n" << "" << std::endl; } diff --git a/Source/ctest.h b/Source/ctest.h index 426f3b9..e346bcf 100644 --- a/Source/ctest.h +++ b/Source/ctest.h @@ -151,5 +151,6 @@ private: bool OpenFile(const std::string& path, const std::string& name, std::ofstream& stream); + std::string MakeXMLSafe(const std::string&); }; -- cgit v0.12