summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2008-06-17 18:03:49 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2008-06-17 18:03:49 (GMT)
commitaa53857f59578258e780eb71eb0b4165c71276c5 (patch)
tree0e53a6e4d50aa8db0ea14e2034d4f7c6a12d4bec /Source
parentebe5eba1a08b5841188ab7fba875dd69fc58290e (diff)
downloadCMake-aa53857f59578258e780eb71eb0b4165c71276c5.zip
CMake-aa53857f59578258e780eb71eb0b4165c71276c5.tar.gz
CMake-aa53857f59578258e780eb71eb0b4165c71276c5.tar.bz2
BUG: fix for bug 7136
Diffstat (limited to 'Source')
-rw-r--r--Source/CTest/cmCTestTestHandler.cxx28
1 files changed, 16 insertions, 12 deletions
diff --git a/Source/CTest/cmCTestTestHandler.cxx b/Source/CTest/cmCTestTestHandler.cxx
index 7a3086e..fe3c3ae 100644
--- a/Source/CTest/cmCTestTestHandler.cxx
+++ b/Source/CTest/cmCTestTestHandler.cxx
@@ -1554,11 +1554,15 @@ std::string cmCTestTestHandler::GenerateRegressionImages(
SPACE_REGEX "*(name|type|encoding|compression)=\"([^\"]*)\""
SPACE_REGEX "*(name|type|encoding|compression)=\"([^\"]*)\""
SPACE_REGEX "*>([^<]*)</DartMeasurement>");
- cmsys::RegularExpression cdatameasurement(
+ cmsys::RegularExpression cdatastart(
"<DartMeasurement"
SPACE_REGEX "*(name|type|encoding|compression)=\"([^\"]*)\""
SPACE_REGEX "*(name|type|encoding|compression)=\"([^\"]*)\""
- SPACE_REGEX "*>(<!\\[CDATA\\[([^]]*\\]?[^]]+)*]]>)</DartMeasurement>");
+ SPACE_REGEX "*>"
+ SPACE_REGEX "*<!\\[CDATA\\[");
+ cmsys::RegularExpression cdataend(
+ "]]>"
+ SPACE_REGEX "*</DartMeasurement>");
cmsys::RegularExpression measurementfile(
"<DartMeasurementFile"
SPACE_REGEX "*(name|type|encoding|compression)=\"([^\"]*)\""
@@ -1618,20 +1622,20 @@ std::string cmCTestTestHandler::GenerateRegressionImages(
cxml.erase(fourattributes.start(),
fourattributes.end() - fourattributes.start());
}
- else if ( cdatameasurement.find(cxml) )
+ else if ( cdatastart.find(cxml) && cdataend.find(cxml) )
{
ostr
<< "\t\t\t<NamedMeasurement"
- << " " << cdatameasurement.match(1) << "=\""
- << cdatameasurement.match(2) << "\""
- << " " << cdatameasurement.match(3) << "=\""
- << cdatameasurement.match(4) << "\""
- << "><Value>" << cdatameasurement.match(5)
- << "</Value></NamedMeasurement>"
+ << " " << cdatastart.match(1) << "=\""
+ << cdatastart.match(2) << "\""
+ << " " << cdatastart.match(3) << "=\""
+ << cdatastart.match(4) << "\""
+ << "><Value><![CDATA["
+ << cxml.substr(cdatastart.end(), cdataend.start() - cdatastart.end())
+ << "]]></Value></NamedMeasurement>"
<< std::endl;
-
- cxml.erase(cdatameasurement.start(),
- cdatameasurement.end() - cdatameasurement.start());
+ cxml.erase(cdatastart.start(),
+ cdataend.end() - cdatastart.start());
}
else if ( measurementfile.find(cxml) )
{