mirror of https://github.com/apache/poi.git
Add a getEntryNames() method to POIFS/NPOIFS directory entries, to make listing easier
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1590148 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
00db163084
commit
184be5c03b
|
@ -23,6 +23,7 @@ import java.io.FileNotFoundException;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import org.apache.poi.hpsf.ClassID;
|
import org.apache.poi.hpsf.ClassID;
|
||||||
|
|
||||||
|
@ -50,6 +51,17 @@ public interface DirectoryEntry
|
||||||
|
|
||||||
public Iterator<Entry> getEntries();
|
public Iterator<Entry> getEntries();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* get the names of all the Entries contained directly in this
|
||||||
|
* instance (in other words, names of children only; no grandchildren
|
||||||
|
* etc).
|
||||||
|
*
|
||||||
|
* @return the names of all the entries that may be retrieved with
|
||||||
|
* getEntry(String), which may be empty (if this
|
||||||
|
* DirectoryEntry is empty)
|
||||||
|
*/
|
||||||
|
public Set<String> getEntryNames();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* is this DirectoryEntry empty?
|
* is this DirectoryEntry empty?
|
||||||
*
|
*
|
||||||
|
|
|
@ -27,6 +27,7 @@ import java.util.HashMap;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import org.apache.poi.hpsf.ClassID;
|
import org.apache.poi.hpsf.ClassID;
|
||||||
import org.apache.poi.poifs.dev.POIFSViewable;
|
import org.apache.poi.poifs.dev.POIFSViewable;
|
||||||
|
@ -318,6 +319,20 @@ public class DirectoryNode
|
||||||
return _entries.iterator();
|
return _entries.iterator();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* get the names of all the Entries contained directly in this
|
||||||
|
* instance (in other words, names of children only; no grandchildren
|
||||||
|
* etc).
|
||||||
|
*
|
||||||
|
* @return the names of all the entries that may be retrieved with
|
||||||
|
* getEntry(String), which may be empty (if this
|
||||||
|
* DirectoryEntry is empty)
|
||||||
|
*/
|
||||||
|
public Set<String> getEntryNames()
|
||||||
|
{
|
||||||
|
return _byname.keySet();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* is this DirectoryEntry empty?
|
* is this DirectoryEntry empty?
|
||||||
*
|
*
|
||||||
|
|
|
@ -115,6 +115,16 @@ public class FilteringDirectoryNode implements DirectoryEntry
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Set<String> getEntryNames() {
|
||||||
|
Set<String> names = new HashSet<String>();
|
||||||
|
for (String name : directory.getEntryNames()) {
|
||||||
|
if (!excludes.contains(name)) {
|
||||||
|
names.add(name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return names;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean isEmpty() {
|
public boolean isEmpty() {
|
||||||
return (getEntryCount() == 0);
|
return (getEntryCount() == 0);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue