X-Git-Url: http://www.privoxy.org/gitweb/?a=blobdiff_plain;f=pcre%2Fpcre.c;h=4f8f82cd4ec6b7ef1a89cf3ce673bff719a77a16;hb=8e0f19f1856e7840c0c4235f4e6e5d48311ad95c;hp=1e602df4399fe39bc6c7d8e99bb77fb72fa4367c;hpb=777f23fd554b0811d16bc2323ced6fe9dc0cff72;p=privoxy.git diff --git a/pcre/pcre.c b/pcre/pcre.c index 1e602df4..4f8f82cd 100644 --- a/pcre/pcre.c +++ b/pcre/pcre.c @@ -730,7 +730,7 @@ if (*p == '}') max = min; else /* Do paranoid checks, then fill in the required variables, and pass back the pointer to the terminating '}'. */ -if (min > 65535 || max > 65535) +if (min < 0 || min > 65535 || max < -1 || max > 65535) *errorptr = ERR5; else { @@ -2660,8 +2660,13 @@ while ((c = *(++ptr)) != 0) } else class_charcount++; ptr++; + if (*ptr == 0) + { + *errorptr = ERR6; + goto PCRE_ERROR_RETURN; + } } - while (*ptr != 0 && *ptr != ']'); + while (*ptr != ']'); /* Repeats for negated single chars are handled by the general code */ @@ -3018,11 +3023,6 @@ while ((c = *(++ptr)) != 0) *errorptr = "internal error"; goto PCRE_ERROR_RETURN; } - if ((int)ptr[1] >= tables_length - ctypes_offset) - { - *errorptr = ERR6; - goto PCRE_ERROR_RETURN; - } } /* This "while" is the end of the "do" above. */