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:
parent
8bd94c178f
commit
cebc23762d
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user