2014-12-09 12:28:23 +01:00
|
|
|
<?php
|
2015-02-04 10:46:36 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
2014-12-09 12:28:23 +01:00
|
|
|
|
|
|
|
namespace Icinga\File;
|
|
|
|
|
|
|
|
use FilterIterator;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Iterator over non-empty files
|
|
|
|
*
|
|
|
|
* Usage example:
|
|
|
|
* <code>
|
|
|
|
* <?php
|
|
|
|
*
|
|
|
|
* namespace Icinga\Example;
|
|
|
|
*
|
|
|
|
* use RecursiveDirectoryIterator;
|
|
|
|
* use RecursiveIteratorIterator;
|
|
|
|
* use Icinga\File\NonEmptyFilterIterator;
|
|
|
|
*
|
|
|
|
* $nonEmptyFiles = new NonEmptyFileIterator(
|
|
|
|
* new RecursiveIteratorIterator(
|
|
|
|
* new RecursiveDirectoryIterator(__DIR__),
|
|
|
|
* RecursiveIteratorIterator::SELF_FIRST
|
|
|
|
* )
|
|
|
|
* );
|
|
|
|
* </code>
|
|
|
|
*/
|
|
|
|
class NonEmptyFileIterator extends FilterIterator
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Accept non-empty files
|
|
|
|
*
|
|
|
|
* @return bool Whether the current element of the iterator is acceptable
|
|
|
|
* through this filter
|
|
|
|
*/
|
|
|
|
public function accept()
|
|
|
|
{
|
|
|
|
$current = $this->current();
|
2015-03-12 13:39:17 +01:00
|
|
|
/** @var $current \SplFileInfo */
|
2014-12-09 12:28:23 +01:00
|
|
|
if (! $current->isFile()
|
|
|
|
|| $current->getSize() === 0
|
|
|
|
) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|