mirror of
https://github.com/moparisthebest/curl
synced 2025-01-11 05:58:01 -05:00
fnmatch: optimize processing of consecutive *s and ?s pattern characters
Reported-By: Daniel Stenberg Fixes #2291 Closes #2293
This commit is contained in:
parent
ff07089585
commit
a0984eae14
@ -256,7 +256,6 @@ static int loop(const unsigned char *pattern, const unsigned char *string,
|
||||
unsigned char *p = (unsigned char *)pattern;
|
||||
unsigned char *s = (unsigned char *)string;
|
||||
unsigned char charset[CURLFNM_CHSET_SIZE] = { 0 };
|
||||
int rc = 0;
|
||||
|
||||
for(;;) {
|
||||
unsigned char *pp;
|
||||
@ -265,18 +264,24 @@ static int loop(const unsigned char *pattern, const unsigned char *string,
|
||||
case '*':
|
||||
if(!maxstars)
|
||||
return CURL_FNMATCH_NOMATCH;
|
||||
while(p[1] == '*') /* eliminate multiple stars */
|
||||
p++;
|
||||
if(*s == '\0' && p[1] == '\0')
|
||||
/* Regroup consecutive stars and question marks. This can be done because
|
||||
'*?*?*' can be expressed as '??*'. */
|
||||
for(;;) {
|
||||
if(*++p == '\0')
|
||||
return CURL_FNMATCH_MATCH;
|
||||
rc = loop(p + 1, s, maxstars - 1); /* *.txt matches .txt <=>
|
||||
.txt matches .txt */
|
||||
if(rc == CURL_FNMATCH_MATCH)
|
||||
return CURL_FNMATCH_MATCH;
|
||||
if(!*s)
|
||||
if(*p == '?') {
|
||||
if(!*s++)
|
||||
return CURL_FNMATCH_NOMATCH;
|
||||
s++; /* let the star eat up one character */
|
||||
}
|
||||
else if(*p != '*')
|
||||
break;
|
||||
}
|
||||
/* Skip string characters until we find a match with pattern suffix. */
|
||||
for(maxstars--; *s; s++) {
|
||||
if(loop(p, s, maxstars) == CURL_FNMATCH_MATCH)
|
||||
return CURL_FNMATCH_MATCH;
|
||||
}
|
||||
return CURL_FNMATCH_NOMATCH;
|
||||
case '?':
|
||||
if(!*s)
|
||||
return CURL_FNMATCH_NOMATCH;
|
||||
|
Loading…
Reference in New Issue
Block a user