-
Notifications
You must be signed in to change notification settings - Fork 0
topics.iocollections
[ [doc://topics/io I/O Basics] | [doc://topics/iocollections Collections] | [doc://topics/streams Streams] ]
The I/O collections API provides interfaces to work with collections of I/O elements, usually files and folders.
An I/O element is defined by the io.collections.IOElement
interface.
- A URI (uniform resource identifier)
- A size (in bytes)
- A creation date
- A date when it was last accessed
- A date when it was last modified
A collection is defined by the io.collections.IOCollection
interface, which extends the IOElement
interface. Ontop of the IOElement
attributes, a collection has the following methods to iterate on its contents.
Instead of having to recurse through folder trees, the
io.collections.iterate.IOCollectionIterator
class
produces a flat list of all elements.
$origin= new FileCollection('/etc');
for ($i= new IOCollectionIterator($origin); $i->hasNext(); ) {
Console::writeLine('Element ', $i->next());
}
The above example will recurse into subdirectories if the iterator instanciation is changed to:
new IOCollectionIterator($origin, TRUE);
To narrow the list of returned elements, one can exchange the
IOCollectionIterator
with the
io.collections.iterate.FilteredIOCollectionIterator
class.
io.collections.iterate.AccessedAfterFilter
,
io.collections.iterate.AccessedBeforeFilter
,
io.collections.iterate.CreatedAfterFilter
,
io.collections.iterate.CreatedBeforeFilter
,
io.collections.iterate.ModifiedAfterFilter
io.collections.iterate.NameMatchesFilter
,
io.collections.iterate.NameEqualsFilter
,
io.collections.iterate.ExtensionEqualsFilter
io.collections.iterate.SizeBiggerThanFilter
,
io.collections.iterate.SizeEqualsFilter
,
io.collections.iterate.SizeSmallerThanFilter
io.collections.iterate.NegationOfFilter
,
io.collections.iterate.AllOfFilter
,
io.collections.iterate.AnyOfFilter
$origin= new FileCollection('/home/thekid/multimedia');
$filter= new ExtensionEqualsFilter('.jpg');
$recursive= FALSE;
foreach (new FilteredIOCollectionIterator($origin, $filter, $recursive) as $element) {
Console::writeLine('Element ', $element);
}
Example (all files in /home and /usr):
$collection= new CollectionComposite(array(
new FileCollection('/home'),
new FileCollection('/usr')
));
foreach (new IOCollectionIterator($origin)) {
Console::writeLine('Element ', $i->next());
}
I/O Collections were first introduced within [rfc://0075 RFC 0075] in October 2006 and enhanced later on in [rfc://0077 RFC 0077].