Implementation for PHP < 5.4:
<?php
if (!class_exists('CallbackFilterIterator')) {
class CallbackFilterIterator extends FilterIterator {
protected $callback;
// "Closure" type hint should be "callable" in PHP 5.4
public function __construct(Iterator $iterator, Closure $callback = null) {
$this->callback = $callback;
parent::__construct($iterator);
}
public function accept() {
return call_user_func(
$this->callback,
$this->current(),
$this->key(),
$this->getInnerIterator()
);
}
}
}
?>
La classe CallbackFilterIterator
(PHP 5 >= 5.4.0)
Introduction
Synopsis de la classe
Exemples
La fonction de rappel doit accepter jusqu'à trois arguments : l'élément courant, la clé courante et l'itérateur courant, respectivement.
Exemple #1 Arguments disponibles pour la fonction de rappel
<?php
/**
* Fonction de rappel pour CallbackFilterIterator
*
* @param $current Valeur de l'élément courant
* @param $key Clé de l'élément courant
* @param $iterator Itérateur à filtrer
* @return boolean TRUE pour accepter l'élément courant, FALSE sinon
*/
function my_callback($current, $key, $iterator) {
// Votre filtre ici
}
?>
N'importe quel callable peut être utilisé ; comme une chaîne de caractères contenant un nom de fonction, un tableau pour une méthode, ou une fonction anonyme.
Exemple #2 Exemples simples de fonction de rappel
<?php
$dir = new FilesystemIterator(__DIR__);
// Filtre les gros fichiers ( > 100MB)
function is_large_file($current) {
return $current->isFile() && $current->getSize() > 104857600;
}
$large_files = new CallbackFilterIterator($dir, 'is_large_file');
// Filtre les dossiers
$files = new CallbackFilterIterator($dir, function ($current, $key, $iterator) {
return $current->isDir() && ! $iterator->isDot();
});
?>
Sommaire
- CallbackFilterIterator::accept — Appel la fonction de rappel avec la valeur courante, la clé courante, et l'itérateur interne comme arguments
- CallbackFilterIterator::__construct — Crée un itérateur filtré depuis un autre itérateur
dave1010 at gmail dot com ¶
1 year ago
