@ -81,6 +81,7 @@ import org.eclipse.jgit.errors.NoClosingBracketException;
* e . g . [ [ : xdigit : ] ] < / li >
* < / ul >
* < / p >
* Any character can be escaped by prepending it with a \
* /
public class FileNameMatcher {
static final List < Head > EMPTY_HEAD_LIST = Collections . emptyList ( ) ;
@ -199,7 +200,7 @@ public class FileNameMatcher {
int groupEnd = - 1 ;
while ( groupEnd = = - 1 ) {
final int possibleGroupEnd = pattern . indexOf ( ']' ,
final int possibleGroupEnd = indexOfUnescaped ( pattern , ']' ,
firstValidEndBracketIndex ) ;
if ( possibleGroupEnd = = - 1 )
throw new NoClosingBracketException ( indexOfStartBracket , "[" , //$NON-NLS-1$
@ -238,7 +239,7 @@ public class FileNameMatcher {
int currentIndex = 0 ;
List < AbstractHead > heads = new ArrayList < AbstractHead > ( ) ;
while ( currentIndex < pattern . length ( ) ) {
final int groupStart = pattern . indexOf ( '[' , currentIndex ) ;
final int groupStart = indexOfUnescaped ( pattern , '[' , currentIndex ) ;
if ( groupStart = = - 1 ) {
final String patternPart = pattern . substring ( currentIndex ) ;
heads . addAll ( createSimpleHeads ( patternPart ,
@ -264,8 +265,15 @@ public class FileNameMatcher {
final String patternPart , final Character invalidWildgetCharacter ) {
final List < AbstractHead > heads = new ArrayList < AbstractHead > (
patternPart . length ( ) ) ;
boolean escaped = false ;
for ( int i = 0 ; i < patternPart . length ( ) ; i + + ) {
final char c = patternPart . charAt ( i ) ;
if ( escaped ) {
final CharacterHead head = new CharacterHead ( c ) ;
heads . add ( head ) ;
escaped = false ;
} else {
switch ( c ) {
case '*' : {
final AbstractHead head = createWildCardHead (
@ -279,11 +287,15 @@ public class FileNameMatcher {
heads . add ( head ) ;
break ;
}
case '\\' :
escaped = true ;
break ;
default :
final CharacterHead head = new CharacterHead ( c ) ;
heads . add ( head ) ;
}
}
}
return heads ;
}
@ -317,6 +329,18 @@ public class FileNameMatcher {
heads = newHeads ;
}
private static int indexOfUnescaped ( final String searchString ,
final char ch , final int fromIndex ) {
for ( int i = fromIndex ; i < searchString . length ( ) ; i + + ) {
char current = searchString . charAt ( i ) ;
if ( current = = ch )
return i ;
if ( current = = '\\' )
i + + ; // Skip the next char as it is escaped }
}
return - 1 ;
}
/ * *
*
* @param stringToMatch