1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-13 13:18:06 +03:00

Generic wildcard matching fix from weidel@multichart.de.

Jeremy.
(This used to be commit 8b790cf3e2)
This commit is contained in:
Jeremy Allison 2000-01-06 21:09:11 +00:00
parent 8bd94c178f
commit cebc23762d

View File

@ -1143,35 +1143,68 @@ BOOL unix_do_match(char *str, char *regexp, BOOL case_sig)
break; break;
case '*': case '*':
/* Look for a character matching /*
the one after the '*' */ * Look for a character matching
* the one after the '*'.
*/
p++; p++;
if(!*p) if(!*p)
return True; /* Automatic match */ return True; /* Automatic match */
while(*str) { while(*str) {
while(*str && (case_sig ? (*p != *str) : (toupper(*p)!=toupper(*str)))) /*
str++; * Patch from weidel@multichart.de. In the case of the regexp
if(unix_do_match(str,p,case_sig)) * '*XX*' we want to ensure there are at least 2 'X' characters
return True; * in the filename after the '*' for a match to be made.
if(!*str) */
return False;
else {
str++; int matchcount=0;
/*
* Eat all the characters that match, but count how many there were.
*/
while(*str && (case_sig ? (*p == *str) : (toupper(*p)==toupper(*str)))) {
str++;
matchcount++;
}
/*
* Now check that if the regexp had n identical characters that
* matchcount had at least that many matches.
*/
while (( *(p+1) && (case_sig ? (*(p+1) == *p) : (toupper(*(p+1))==toupper(*p))))) {
p++;
matchcount--;
}
if ( matchcount <= 0 ) {
return False;
}
}
str--; /* We've eaten the match char after the '*' */
if(unix_do_match(str,p,case_sig))
return True;
if(!*str)
return False;
else
str++;
} }
return False; return False;
default: default:
if(case_sig) { if(case_sig) {
if(*str != *p) if(*str != *p)
return False; return False;
} else { } else {
if(toupper(*str) != toupper(*p)) if(toupper(*str) != toupper(*p))
return False; return False;
} }
str++, p++; str++, p++;
break; break;
} }
} }
if(!*p && !*str) if(!*p && !*str)
return True; return True;
@ -1283,10 +1316,38 @@ static BOOL do_match(char *str, char *regexp, int case_sig, BOOL win9x_semantics
while(*str) { while(*str) {
while(*str && (case_sig ? (*p != *str) : (toupper(*p)!=toupper(*str)))) while(*str && (case_sig ? (*p != *str) : (toupper(*p)!=toupper(*str))))
str++; str++;
/* Now eat all characters that match, as
we want the *last* character to match. */ /*
while(*str && (case_sig ? (*p == *str) : (toupper(*p)==toupper(*str)))) * Patch from weidel@multichart.de. In the case of the regexp
str++; * '*XX*' we want to ensure there are at least 2 'X' characters
* in the filename after the '*' for a match to be made.
*/
{
int matchcount=0;
/*
* Eat all the characters that match, but count how many there were.
*/
while(*str && (case_sig ? (*p == *str) : (toupper(*p)==toupper(*str)))) {
str++;
matchcount++;
}
/*
* Now check that if the regexp had n identical characters that
* matchcount had at least that many matches.
*/
while (( *(p+1) && (case_sig ? (*(p+1) == *p) : (toupper(*(p+1))==toupper(*p))))) {
p++;
matchcount--;
}
if ( matchcount <= 0 ) {
return False;
}
}
str--; /* We've eaten the match char after the '*' */ str--; /* We've eaten the match char after the '*' */
if(do_match(str,p,case_sig,win9x_semantics)) { if(do_match(str,p,case_sig,win9x_semantics)) {
return True; return True;