diff --git a/Source/cmCTest.cxx b/Source/cmCTest.cxx
index de6a3955d..858ef413a 100644
--- a/Source/cmCTest.cxx
+++ b/Source/cmCTest.cxx
@@ -167,10 +167,11 @@ std::string cmCTest::MakeXMLSafe(const std::string& str)
char buffer[10];
for ( pos = 0; pos < str.size(); pos ++ )
{
- char ch = str[pos];
- if ( ch > 126 )
+ unsigned char ch = str[pos];
+ if ( (ch > 126 || ch < 32) && ch != 9 )
{
- sprintf(buffer, "&%x", (int)ch);
+ sprintf(buffer, "><");
+ //sprintf(buffer, "%0x;", (unsigned int)ch);
ost << buffer;
}
else
@@ -1151,7 +1152,7 @@ int cmCTest::CoverageDirectory()
}
std::ofstream log;
- if (!this->OpenOutputFile("Coverage", "Coverage.log", log))
+ if (!this->OpenOutputFile("Temporary", "Coverage.log", log))
{
std::cout << "Cannot open log file" << std::endl;
return 1;
@@ -1163,7 +1164,8 @@ int cmCTest::CoverageDirectory()
return 1;
}
- std::string opath = m_ToplevelPath + "/Testing/" + m_CurrentTag + "/Coverage";
+ std::string opath = m_ToplevelPath + "/Testing/Temporary/Coverage";
+ cmSystemTools::MakeDirectory(opath.c_str());
for ( cc = 0; cc < files.size(); cc ++ )
{
@@ -1171,6 +1173,7 @@ int cmCTest::CoverageDirectory()
std::string output;
int retVal = 0;
//std::cout << "Run gcov on " << files[cc] << std::flush;
+ //std::cout << " --- Run [" << command << "]" << std::endl;
bool res = true;
if ( !m_ShowOnly )
{
@@ -1269,7 +1272,17 @@ int cmCTest::CoverageDirectory()
{
cov.m_FullPath = allbinaryfiles[it->first];
}
- //std::cerr << "Full path: " << cov.m_FullPath << std::endl;
+ std::string src_dir = m_DartConfiguration["SourceDirectory"];
+ std::string::size_type spos = cov.m_FullPath.find(src_dir);
+ if ( spos == 0 )
+ {
+ cov.m_FullPath = std::string(".") + cov.m_FullPath.substr(src_dir.size());
+ }
+ else
+ {
+ std::cerr << "Compare -- " << cov.m_FullPath << std::endl;
+ std::cerr << " -- " << src_dir << std::endl;
+ }
}
for ( cc = 0; cc < lines.size(); cc ++ )
{
@@ -1307,12 +1320,6 @@ int cmCTest::CoverageDirectory()
std::ofstream cfileoutput;
int cfileoutputcount = 0;
char cfileoutputname[100];
- sprintf(cfileoutputname, "CoverageLog-%d.xml", cfileoutputcount++);
- if (!this->OpenOutputFile(m_CurrentTag, cfileoutputname, cfileoutput))
- {
- std::cout << "Cannot open log file" << std::endl;
- return 1;
- }
std::string local_start_time = ::CurrentTime();
std::string local_end_time;
for ( cit = coverageresults.begin(); cit != coverageresults.end(); cit ++ )
@@ -1321,28 +1328,29 @@ int cmCTest::CoverageDirectory()
{
local_end_time = ::CurrentTime();
cfileoutput << "\t" << local_end_time << "\n"
- << "\n"
- << "" << std::endl;
+ << "\n"
+ << "" << std::endl;
cfileoutput.close();
- sprintf(cfileoutputname, "CoverageLog-%d.xml", cfileoutputcount++);
- if (!this->OpenOutputFile(m_CurrentTag, cfileoutputname, cfileoutput))
- {
- std::cout << "Cannot open log file" << std::endl;
- return 1;
- }
+ std::cout << "Close file: " << cfileoutputname << std::endl;
ccount = 0;
}
-
if ( ccount == 0 )
{
+ sprintf(cfileoutputname, "CoverageLog-%d.xml", cfileoutputcount++);
+ std::cout << "Open file: " << cfileoutputname << std::endl;
+ if (!this->OpenOutputFile(m_CurrentTag, cfileoutputname, cfileoutput))
+ {
+ std::cout << "Cannot open log file: " << cfileoutputname << std::endl;
+ return 1;
+ }
local_start_time = ::CurrentTime();
cfileoutput << "\n"
- << "GetTestModelString() << "\" Name=\""
- << m_DartConfiguration["Site"] << "\">\n"
- << "\n"
- << "\t" << local_start_time << "" << std::endl;
+ << "GetTestModelString() << "\" Site=\""
+ << m_DartConfiguration["Site"] << "\">\n"
+ << "\n"
+ << "\t" << local_start_time << "" << std::endl;
}
//std::cerr << "Final process of Source file: " << cit->first << std::endl;
@@ -1361,17 +1369,17 @@ int cmCTest::CoverageDirectory()
cmSystemTools::Split(buffer, lines);
delete [] buffer;
cfileoutput << "\tfirst << "\" FullPath=\""
- << cov.m_FullPath << std::endl << "\">\n"
- << "\t\t" << std::endl;
+ << cov.m_FullPath << std::endl << "\">\n"
+ << "\t\t" << std::endl;
for ( cc = 0; cc < lines.size(); cc ++ )
{
cfileoutput << "\t\t(cc) << "\" Count=\""
- << cov.m_Lines[cc] << "\">"
- << lines[cc] << "" << std::endl;
+ << static_cast(cc) << "\" Count=\""
+ << cov.m_Lines[cc] << "\">"
+ << cmCTest::MakeXMLSafe(lines[cc]) << "" << std::endl;
}
cfileoutput << "\t\t\n"
- << "\t" << std::endl;
+ << "\t" << std::endl;
total_tested += cov.m_Tested;
@@ -1381,17 +1389,18 @@ int cmCTest::CoverageDirectory()
if ( total_tested + total_untested > 0 )
{
cper = (100 * static_cast(cov.m_Tested)/
- static_cast(cov.m_Tested + cov.m_UnTested));
+ static_cast(cov.m_Tested + cov.m_UnTested));
cmet = ( static_cast(cov.m_Tested + 10) /
- static_cast(cov.m_Tested + cov.m_UnTested + 10));
+ static_cast(cov.m_Tested + cov.m_UnTested + 10));
}
log << "\tfirst << "\" FullPath=\"" << cov.m_FullPath
- << "\" Covered=\"" << cov.m_Covered << "\">\n"
- << "\t\t" << cov.m_Tested << "\n"
- << "\t\t" << cov.m_UnTested << "\n"
- << "\t\t" << cper << "\n"
- << "\t\t" << cmet << "\n"
- << "\t" << std::endl;
+ << "\" Covered=\"" << (cmet>0?"true":"false") << "\">\n"
+ << "\t\t" << cov.m_Tested << "\n"
+ << "\t\t" << cov.m_UnTested << "\n"
+ << "\t\t" << cper << "\n"
+ << "\t\t" << cmet << "\n"
+ << "\t" << std::endl;
+ ccount ++;
}
if ( ccount > 0 )
@@ -1427,7 +1436,6 @@ int cmCTest::CoverageDirectory()
<< "\tPercentage Coverage: " << percent_coverage << "%" << std::endl;
- std::cerr << "Coverage test is not yet implemented" << std::endl;
return 1;
}
@@ -1462,6 +1470,7 @@ bool cmCTest::OpenOutputFile(const std::string& path,
stream.open(filename.c_str());
if( !stream )
{
+ std::cout << "Problem opening file: " << filename << std::endl;
return false;
}
return true;
@@ -1791,12 +1800,32 @@ int cmCTest::SubmitResults()
if ( this->CTestFileExists("Coverage.xml") )
{
files.push_back("Coverage.xml");
+ std::vector gfiles;
+ std::string gpath = m_ToplevelPath + "/Testing/" + m_CurrentTag;
+ std::string::size_type glen = gpath.size() + 1;
+ gpath = gpath + "/CoverageLog*";
+ //std::cout << "Globbing for: " << gpath.c_str() << std::endl;
+ if ( cmSystemTools::SimpleGlob(gpath, gfiles, 1) )
+ {
+ size_t cc;
+ for ( cc = 0; cc < gfiles.size(); cc ++ )
+ {
+ gfiles[cc] = gfiles[cc].substr(glen);
+ //std::cout << "Glob file: " << gfiles[cc].c_str() << std::endl;
+ files.push_back(gfiles[cc]);
+ }
+ }
+ else
+ {
+ std::cout << "Problem globbing" << std::endl;
+ }
}
if ( this->CTestFileExists("Purify.xml") )
{
files.push_back("Purify.xml");
}
cmCTestSubmit submit;
+ submit.SetVerbose(m_Verbose);
if ( m_DartConfiguration["DropMethod"] == "" ||
m_DartConfiguration["DropMethod"] == "ftp" )
{
@@ -1806,7 +1835,8 @@ int cmCTest::SubmitResults()
m_DartConfiguration["DropSitePassword"] + "@" +
m_DartConfiguration["DropSite"] +
m_DartConfiguration["DropLocation"];
- if ( !submit.SubmitUsingFTP(m_ToplevelPath+"/Testing/"+m_CurrentTag, files, prefix, url) )
+ if ( !submit.SubmitUsingFTP(m_ToplevelPath+"/Testing/"+m_CurrentTag,
+ files, prefix, url) )
{
return 0;
}
@@ -1838,6 +1868,7 @@ int cmCTest::SubmitResults()
{
return 0;
}
+ std::cout << "Submission successfull" << std::endl;
return 1;
}
else