<?php/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/namespaceSymfony\Component\DependencyInjection\Compiler;
useSymfony\Component\DependencyInjection\ContainerBuilder;
useSymfony\Component\DependencyInjection\Exception\InvalidArgumentException;
/**
* A pass that might be run repeatedly.
*
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
*/class RepeatedPassimplements CompilerPassInterface {
/**
* @var Boolean
*/
private $repeat = false;
/**
* @var RepeatablePassInterface[]
*/
private $passes;
/**
* Constructor.
*
* @param RepeatablePassInterface[] $passes An array of RepeatablePassInterface objects
*
* @throws InvalidArgumentException when the passes don't implement RepeatablePassInterface
*/
public function__construct(array $passes) {
foreach ($passes as $pass) {
if (!$pass instanceof RepeatablePassInterface) {
thrownewInvalidArgumentException('$passes must be an array of RepeatablePassInterface.');
}
$pass
->setRepeatedPass($this);
}
$this->passes = $passes;
}
/**
* Process the repeatable passes that run more than once.
*
* @param ContainerBuilder $container
*/
public functionprocess(ContainerBuilder $container) {
$this->repeat = false;
foreach ($this->passes as $pass) {
$pass
->process($container);
}
if ($this->repeat) {
$this
->process($container);
}
}
/**
* Sets if the pass should repeat
*/
public functionsetRepeat() {
$this->repeat = true;
}
/**
* Returns the passes
*
* @return RepeatablePassInterface[] An array of RepeatablePassInterface objects
*/
public functiongetPasses() {
return$this->passes;
}
}