mirror of
https://gitlab.gnome.org/GNOME/libxml2.git
synced 2025-07-29 11:41:22 +03:00
fixed problem with 0x2d in Char Range (bug #420596) added regression test
* xmlregexp.c: fixed problem with 0x2d in Char Range (bug #420596) * test/regexp/bug420596, result/regexp/bug420596: added regression test for this svn path=/trunk/; revision=3594
This commit is contained in:
14
xmlregexp.c
14
xmlregexp.c
@ -54,6 +54,11 @@
|
||||
#define CUR_SCHAR(s, l) xmlStringCurrentChar(NULL, s, &l)
|
||||
#define NEXTL(l) ctxt->cur += l;
|
||||
#define XML_REG_STRING_SEPARATOR '|'
|
||||
/*
|
||||
* Need PREV to check on a '-' within a Character Group. May only be used
|
||||
* when it's guaranteed that cur is not at the beginning of ctxt->string!
|
||||
*/
|
||||
#define PREV (ctxt->cur[-1])
|
||||
|
||||
/**
|
||||
* TODO:
|
||||
@ -4853,10 +4858,15 @@ xmlFAParseCharRange(xmlRegParserCtxtPtr ctxt) {
|
||||
ERROR("Expecting a char range");
|
||||
return;
|
||||
}
|
||||
NEXTL(len);
|
||||
if (start == '-') {
|
||||
/*
|
||||
* Since we are "inside" a range, we can assume ctxt->cur is past
|
||||
* the start of ctxt->string, and PREV should be safe
|
||||
*/
|
||||
if ((start == '-') && (NXT(1) != ']') && (PREV != '[') && (PREV != '^')) {
|
||||
NEXTL(len);
|
||||
return;
|
||||
}
|
||||
NEXTL(len);
|
||||
cur = CUR;
|
||||
if ((cur != '-') || (NXT(1) == ']')) {
|
||||
xmlRegAtomAddRange(ctxt, ctxt->atom, ctxt->neg,
|
||||
|
Reference in New Issue
Block a user