Correctly remove prefix in DelimiterFilter

Previously this called String.replaceFirst which uses a regular
expression and incorrectly handles characters like *.  Also remove
other correct but unnecessary call to String.replaceFirst.
This commit is contained in:
Andrew Gaul 2016-02-09 10:43:12 -08:00
parent 4ecb078092
commit a697396e8c
1 changed files with 2 additions and 3 deletions

View File

@ -39,7 +39,6 @@ import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.SortedSet; import java.util.SortedSet;
import java.util.UUID; import java.util.UUID;
import java.util.regex.Pattern;
import javax.annotation.Resource; import javax.annotation.Resource;
import javax.inject.Inject; import javax.inject.Inject;
@ -473,7 +472,7 @@ public final class LocalBlobStore implements BlobStore {
return name.indexOf(delimiter) == -1; return name.indexOf(delimiter) == -1;
} }
if (name.startsWith(prefix)) { if (name.startsWith(prefix)) {
String unprefixedName = name.replaceFirst(prefix, ""); String unprefixedName = name.substring(prefix.length());
if (unprefixedName.equals("")) { if (unprefixedName.equals("")) {
// a blob that matches the prefix should also be returned // a blob that matches the prefix should also be returned
return true; return true;
@ -498,7 +497,7 @@ public final class LocalBlobStore implements BlobStore {
String working = metadata.getName(); String working = metadata.getName();
if (prefix != null) { if (prefix != null) {
if (working.startsWith(prefix)) { if (working.startsWith(prefix)) {
working = working.replaceFirst(Pattern.quote(prefix), ""); working = working.substring(prefix.length());
} else { } else {
return NO_PREFIX; return NO_PREFIX;
} }