|                                                                                                              1
 11  package org.eclipse.team.internal.core;
 12
 13
 14  import java.util.*;
 15
 16
 21  public class StringMatcher {
 22      protected String
  fPattern; 23      protected int fLength;     protected boolean fIgnoreWildCards;
 25      protected boolean fIgnoreCase;
 26      protected boolean fHasLeadingStar;
 27      protected boolean fHasTrailingStar;
 28      protected String
  fSegments[]; 30
 31      protected int fBound = 0;
 32
 33
 34      protected static final char fSingleWildCard = '\u0000';
 35
 36      public static class Position {
 37          int start;         int end;         public Position(int start, int end) {
 40              this.start = start;
 41              this.end = end;
 42          }
 43          public int getStart() {
 44              return start;
 45          }
 46          public int getEnd() {
 47              return end;
 48          }
 49      }
 50
 63
 64      public StringMatcher.Position find(String
  text, int start, int end) { 65          if (fPattern  == null|| text == null)
 66              throw new IllegalArgumentException
  (); 67
 68          int tlen = text.length();
 69          if (start < 0)
 70              start = 0;
 71          if (end > tlen)
 72              end = tlen;
 73          if (end < 0 ||start >= end )
 74              return null;
 75          if (fLength == 0)
 76              return new Position(start, start);
 77          if (fIgnoreWildCards) {
 78              int x = posIn(text, start, end);
 79              if (x < 0)
 80                  return null;
 81              return new Position(x, x+fLength);
 82          }
 83
 84          int segCount = fSegments.length;
 85          if (segCount == 0)            return new Position (start, end);
 87
 88          int curPos = start;
 89          int matchStart = -1;
 90          int i;
 91          for (i = 0; i < segCount && curPos < end; ++i) {
 92              String
  current = fSegments[i]; 93              int nextMatch = regExpPosIn(text, curPos, end, current);
 94              if (nextMatch < 0 )
 95                  return null;
 96              if(i == 0)
 97                  matchStart = nextMatch;
 98              curPos = nextMatch + current.length();
 99          }
 100         if (i < segCount)
 101             return null;
 102         return new Position(matchStart, curPos);
 103     }
 104
 124     public StringMatcher(String
  aPattern, boolean ignoreCase, boolean ignoreWildCards) { 125         fIgnoreCase = ignoreCase;
 126         fIgnoreWildCards = ignoreWildCards;
 127         fLength = aPattern.length();
 128
 129
 130         if (fIgnoreCase) {
 131             fPattern = aPattern.toUpperCase();
 132         } else {
 133             fPattern = aPattern;
 134         }
 135
 136         if (fIgnoreWildCards) {
 137             parseNoWildCards();
 138         } else {
 139             parseWildCards();
 140         }
 141     }
 142
 150     public boolean match(String
  text, int start, int end) { 151         if (null == text)
 152             throw new IllegalArgumentException
  (); 153
 154         if (start > end)
 155             return false;
 156
 157         if (fIgnoreWildCards)
 158             return (end - start == fLength) && fPattern.regionMatches(fIgnoreCase, 0, text, start, fLength);
 159         int segCount= fSegments.length;
 160         if (segCount == 0 && (fHasLeadingStar || fHasTrailingStar))              return true;
 162         if (start == end)
 163             return fLength == 0;
 164         if (fLength == 0)
 165             return start == end;
 166
 167         int tlen= text.length();
 168         if (start < 0)
 169             start= 0;
 170         if (end > tlen)
 171             end= tlen;
 172
 173         int tCurPos= start;
 174         int bound= end - fBound;
 175         if ( bound < 0)
 176             return false;
 177         int i=0;
 178         String
  current= fSegments[i]; 179         int segLength= current.length();
 180
 181
 182         if (!fHasLeadingStar){
 183             if(!regExpRegionMatches(text, start, current, 0, segLength)) {
 184                 return false;
 185             } else {
 186                 ++i;
 187                 tCurPos= tCurPos + segLength;
 188             }
 189         }
 190         if ((fSegments.length == 1) && (!fHasLeadingStar) && (!fHasTrailingStar)) {
 191                         return tCurPos == end;
 193         }
 194
 195         while (i < segCount) {
 196             current= fSegments[i];
 197             int currentMatch;
 198             int k= current.indexOf(fSingleWildCard);
 199             if (k < 0) {
 200                 currentMatch= textPosIn(text, tCurPos, end, current);
 201                 if (currentMatch < 0)
 202                     return false;
 203             } else {
 204                 currentMatch= regExpPosIn(text, tCurPos, end, current);
 205                 if (currentMatch < 0)
 206                     return false;
 207             }
 208             tCurPos= currentMatch + current.length();
 209             i++;
 210         }
 211
 212
 213         if (!fHasTrailingStar && tCurPos != end) {
 214             int clen= current.length();
 215             return regExpRegionMatches(text, end - clen, current, 0, clen);
 216         }
 217         return i == segCount ;
 218     }
 219
 224     public boolean  match(String
  text) { 225         return match(text, 0, text.length());
 226     }
 227
 231     private void parseNoWildCards() {
 232         fSegments = new String
  [1]; 233         fSegments[0] = fPattern;
 234         fBound = fLength;
 235     }
 236
 240     private void parseWildCards() {
 241         if(fPattern.startsWith("*"))            fHasLeadingStar = true;
 243         if(fPattern.endsWith("*")) {
 245             if (fLength > 1 && fPattern.charAt(fLength - 2) != '\\') {
 246                 fHasTrailingStar = true;
 247             }
 248         }
 249
 250         Vector temp = new Vector();
 251
 252         int pos = 0;
 253         StringBuffer
  buf = new StringBuffer  (); 254         while (pos < fLength) {
 255             char c = fPattern.charAt(pos++);
 256             switch (c) {
 257                 case '\\':
 258                     if (pos >= fLength) {
 259                         buf.append(c);
 260                     } else {
 261                         char next = fPattern.charAt(pos++);
 262
 263                         if (next == '*' || next == '?' || next == '\\') {
 264                             buf.append(next);
 265                         } else {
 266
 267                             buf.append(c);
 268                             buf.append(next);
 269                         }
 270                     }
 271                 break;
 272                 case '*':
 273                     if (buf.length() > 0) {
 274
 275                         temp.addElement(buf.toString());
 276                         fBound += buf.length();
 277                         buf.setLength(0);
 278                     }
 279                 break;
 280                 case '?':
 281
 282                     buf.append(fSingleWildCard);
 283                 break;
 284                 default:
 285                     buf.append(c);
 286             }
 287         }
 288
 289
 290         if (buf.length() > 0) {
 291             temp.addElement(buf.toString());
 292             fBound += buf.length();
 293         }
 294
 295         fSegments = new String
  [temp.size()]; 296         temp.copyInto(fSegments);
 297     }
 298
 304     protected int posIn(String
  text, int start, int end) {        int max = end - fLength; 306
 307         if (!fIgnoreCase) {
 308             int i = text.indexOf(fPattern, start);
 309             if (i == -1 || i > max)
 310                 return -1;
 311             return i;
 312         }
 313
 314         for (int i = start; i <= max; ++i) {
 315             if (text.regionMatches(true, i, fPattern, 0, fLength))
 316                 return i;
 317         }
 318
 319         return -1;
 320     }
 321
 328     protected int regExpPosIn(String
  text, int start, int end, String  p) { 329         int plen = p.length();
 330
 331         int max = end - plen;
 332         for (int i = start; i <= max; ++i) {
 333             if (regExpRegionMatches(text, i, p, 0, plen))
 334                 return i;
 335         }
 336         return -1;
 337     }
 338
 339
 348     protected boolean regExpRegionMatches(String
  text, int tStart, String  p, int pStart, int plen) { 349         while (plen-- > 0) {
 350             char tchar = text.charAt(tStart++);
 351             char pchar = p.charAt(pStart++);
 352
 353
 354             if (!fIgnoreWildCards) {
 355
 356                 if (pchar == fSingleWildCard) {
 357                     continue;
 358                 }
 359             }
 360             if (pchar == tchar)
 361                 continue;
 362             if (fIgnoreCase) {
 363                 char tc = Character.toUpperCase(tchar);
 364                 if (tc == pchar)
 365                     continue;
 366             }
 367             return false;
 368         }
 369         return true;
 370     }
 371
 378     protected int textPosIn(String
  text, int start, int end, String  p) { 379
 380         int plen = p.length();
 381         int max = end - plen;
 382
 383         if (!fIgnoreCase) {
 384             int i = text.indexOf(p, start);
 385             if (i == -1 || i > max)
 386                 return -1;
 387             return i;
 388         }
 389
 390         for (int i = start; i <= max; ++i) {
 391             if (text.regionMatches(true, i, p, 0, plen))
 392                 return i;
 393         }
 394
 395         return -1;
 396     }
 397 }
 398
                                                                                                                                                                                                             |                                                                       
 
 
 
 
 
                                                                                   Popular Tags                                                                                                                                                                                              |