<?php
-/**
+/** \ingroup Examples
* @brief Iterator that iterates over several iterators one after the other
* @author Marcus Boerger
* @version 1.0
- *
*/
class AppendIterator implements Iterator
{
- protected $iterators;
+ /** @internal array of inner iterators */
+ private $iterators;
+ /** Construct an empty AppendIterator
+ */
function __construct()
{
$this->iterators = new ArrayIterator();
}
-
+
+ /** Append an Iterator
+ * @param $it Iterator to append
+ */
function append(Iterator $it)
{
$this->iterators->append($it);
}
+ /** @return the current inner Iterator
+ */
function getInnerIterator()
{
return $this->iterators->current();
}
+ /** Rewind to the first element of the first inner Iterator.
+ * @return void
+ */
function rewind()
{
$this->iterators->rewind();
}
}
+ /** @return whether the current element is valid
+ */
function valid()
{
return $this->iterators->valid() && $this->getInnerIterator()->valid();
}
+ /** @return the current value if it is valid or \c NULL
+ */
function current()
{
/* Using $this->valid() would be exactly the same; it would omit
return $this->iterators->valid() ? $this->getInnerIterator()->current() : NULL;
}
+ /** @return the current key if it is valid or \c NULL
+ */
function key()
{
return $this->iterators->valid() ? $this->getInnerIterator()->key() : NULL;
}
-
+
+ /** Move to the next element. If this means to another Iterator that
+ * rewind that Iterator.
+ * @return void
+ */
function next()
{
if (!$this->iterators->valid())
$this->iterators->next();
}
}
+
+ /** Aggregates the inner iterator
+ */
+ function __call($func, $params)
+ {
+ return call_user_func_array(array($this->getInnerIterator(), $func), $params);
+ }
}
?>
\ No newline at end of file
--- /dev/null
+<?php
+
+/**
+ * @brief Find files by regular expression
+ * @author Marcus Boerger
+ * @version 1.1
+ *
+ */
+class RegexFindFile extends FindFile
+{
+ /** Construct from path and regular expression
+ *
+ * @param $path the directory to search in
+ * If path contains ';' then this parameter is split and every
+ * part of it is used as separate directory.
+ * @param $regex perl style regular expression to find files with
+ */
+ function __construct($path, $regex)
+ {
+ parent::__construct($path, $regex);
+ }
+
+ /** @return whether the current filename matches the regular expression.
+ */
+ function accept()
+ {
+ return preg_match($this->getSearch(), $this->current());
+ }
+}
+
+?>
\ No newline at end of file