2014-06-06 14:10:13 +02:00
|
|
|
<?php
|
2015-02-03 16:27:59 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | http://www.gnu.org/licenses/gpl-2.0.txt */
|
2014-06-06 14:10:13 +02:00
|
|
|
|
|
|
|
namespace Icinga\Module\Doc;
|
|
|
|
|
|
|
|
use ArrayIterator;
|
2014-06-30 15:22:32 +02:00
|
|
|
use Countable;
|
2014-06-06 14:10:13 +02:00
|
|
|
use IteratorAggregate;
|
|
|
|
use RecursiveIteratorIterator;
|
|
|
|
use RecursiveDirectoryIterator;
|
2014-12-09 12:29:48 +01:00
|
|
|
use Icinga\File\NonEmptyFileIterator;
|
|
|
|
use Icinga\File\FileExtensionFilterIterator;
|
2014-06-06 14:10:13 +02:00
|
|
|
|
2014-07-28 18:59:42 +02:00
|
|
|
/**
|
|
|
|
* Iterator over non-empty Markdown files ordered by the case insensitive "natural order" of file names
|
|
|
|
*/
|
2014-06-30 15:22:32 +02:00
|
|
|
class DocIterator implements Countable, IteratorAggregate
|
2014-06-06 14:10:13 +02:00
|
|
|
{
|
2014-07-28 18:59:42 +02:00
|
|
|
/**
|
|
|
|
* Ordered files
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $fileInfo;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new DocIterator
|
|
|
|
*
|
|
|
|
* @param string $path Path to the documentation
|
|
|
|
*/
|
2014-06-06 14:10:13 +02:00
|
|
|
public function __construct($path)
|
|
|
|
{
|
2014-12-09 12:29:48 +01:00
|
|
|
$it = new FileExtensionFilterIterator(
|
2014-07-28 18:59:42 +02:00
|
|
|
new NonEmptyFileIterator(
|
2014-12-09 12:29:48 +01:00
|
|
|
new RecursiveIteratorIterator(
|
|
|
|
new RecursiveDirectoryIterator($path),
|
|
|
|
RecursiveIteratorIterator::SELF_FIRST
|
2014-07-28 18:59:42 +02:00
|
|
|
)
|
2014-12-09 12:29:48 +01:00
|
|
|
),
|
|
|
|
'md'
|
2014-06-06 14:10:13 +02:00
|
|
|
);
|
2014-07-28 18:59:42 +02:00
|
|
|
// Unfortunately we have no chance to sort the iterator
|
|
|
|
$fileInfo = iterator_to_array($it);
|
|
|
|
natcasesort($fileInfo);
|
|
|
|
$this->fileInfo = $fileInfo;
|
2014-06-06 14:10:13 +02:00
|
|
|
}
|
|
|
|
|
2014-07-28 18:59:42 +02:00
|
|
|
/**
|
|
|
|
* (non-PHPDoc)
|
|
|
|
* @see Countable::count()
|
|
|
|
*/
|
2014-06-30 15:22:32 +02:00
|
|
|
public function count()
|
|
|
|
{
|
2014-07-28 18:59:42 +02:00
|
|
|
return count($this->fileInfo);
|
2014-06-30 15:22:32 +02:00
|
|
|
}
|
|
|
|
|
2014-07-28 18:59:42 +02:00
|
|
|
/**
|
|
|
|
* (non-PHPDoc)
|
|
|
|
* @see IteratorAggregate::getIterator()
|
|
|
|
*/
|
2014-06-06 14:10:13 +02:00
|
|
|
public function getIterator()
|
|
|
|
{
|
2014-07-28 18:59:42 +02:00
|
|
|
return new ArrayIterator($this->fileInfo);
|
2014-06-06 14:10:13 +02:00
|
|
|
}
|
|
|
|
}
|