mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
fix bugs in File.getParent and listFiles
getParent should return the same value regardless of whether it ends in a file separator, and listFiles should return null for non-directories.
This commit is contained in:
parent
c17710d2b0
commit
836fc21106
@ -148,9 +148,13 @@ public class File implements Serializable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public String getParent() {
|
public String getParent() {
|
||||||
int index = path.lastIndexOf(FileSeparator);
|
String p = path;
|
||||||
|
while (p.endsWith(FileSeparator)) {
|
||||||
|
p = p.substring(0, p.length() - 1);
|
||||||
|
}
|
||||||
|
int index = p.lastIndexOf(FileSeparator);
|
||||||
if (index >= 0) {
|
if (index >= 0) {
|
||||||
return path.substring(0, index);
|
return p.substring(0, index);
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -239,11 +243,15 @@ public class File implements Serializable {
|
|||||||
|
|
||||||
public File[] listFiles(FilenameFilter filter) {
|
public File[] listFiles(FilenameFilter filter) {
|
||||||
String[] list = list(filter);
|
String[] list = list(filter);
|
||||||
File[] result = new File[list.length];
|
if (list != null) {
|
||||||
for (int i = 0; i < list.length; ++i) {
|
File[] result = new File[list.length];
|
||||||
result[i] = new File(this, list[i]);
|
for (int i = 0; i < list.length; ++i) {
|
||||||
|
result[i] = new File(this, list[i]);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
return result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String[] list() {
|
public String[] list() {
|
||||||
@ -254,22 +262,26 @@ public class File implements Serializable {
|
|||||||
long handle = 0;
|
long handle = 0;
|
||||||
try {
|
try {
|
||||||
handle = openDir(path);
|
handle = openDir(path);
|
||||||
Pair list = null;
|
if (handle != 0) {
|
||||||
int count = 0;
|
Pair list = null;
|
||||||
for (String s = readDir(handle); s != null; s = readDir(handle)) {
|
int count = 0;
|
||||||
if (filter == null || filter.accept(this, s)) {
|
for (String s = readDir(handle); s != null; s = readDir(handle)) {
|
||||||
list = new Pair(s, list);
|
if (filter == null || filter.accept(this, s)) {
|
||||||
++ count;
|
list = new Pair(s, list);
|
||||||
|
++ count;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
String[] result = new String[count];
|
String[] result = new String[count];
|
||||||
for (int i = count - 1; i >= 0; --i) {
|
for (int i = count - 1; i >= 0; --i) {
|
||||||
result[i] = list.value;
|
result[i] = list.value;
|
||||||
list = list.next;
|
list = list.next;
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
} finally {
|
} finally {
|
||||||
if (handle != 0) {
|
if (handle != 0) {
|
||||||
closeDir(handle);
|
closeDir(handle);
|
||||||
|
@ -74,6 +74,12 @@ public class Files {
|
|||||||
f.delete();
|
f.delete();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
expect(new File("foo/bar").getParent().equals("foo"));
|
||||||
|
expect(new File("foo/bar/").getParent().equals("foo"));
|
||||||
|
expect(new File("foo/bar//").getParent().equals("foo"));
|
||||||
|
|
||||||
|
expect(new File("foo/nonexistent-directory").listFiles() == null);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user