3 * Zend Framework (http://framework.zend.com/)
5 * @link http://github.com/zendframework/zf2 for the canonical source repository
6 * @copyright Copyright (c) 2005-2013 Zend Technologies USA Inc. (http://www.zend.com)
7 * @license http://framework.zend.com/license/new-bsd New BSD License
10 namespace Zend\View\Resolver
;
13 use IteratorAggregate
;
14 use Zend\Stdlib\PriorityQueue
;
15 use Zend\View\Renderer\RendererInterface
as Renderer
;
16 use Zend\View\Resolver\ResolverInterface
as Resolver
;
18 class AggregateResolver
implements Countable
, IteratorAggregate
, ResolverInterface
20 const FAILURE_NO_RESOLVERS
= 'AggregateResolver_Failure_No_Resolvers';
21 const FAILURE_NOT_FOUND
= 'AggregateResolver_Failure_Not_Found';
27 protected $lastLookupFailure = false;
32 protected $lastSuccessfulResolver;
42 * Instantiate the internal priority queue
45 public function __construct()
47 $this->queue
= new PriorityQueue();
51 * Return count of attached resolvers
55 public function count()
57 return $this->queue
->count();
61 * IteratorAggregate: return internal iterator
63 * @return PriorityQueue
65 public function getIterator()
73 * @param Resolver $resolver
74 * @param int $priority
75 * @return AggregateResolver
77 public function attach(Resolver
$resolver, $priority = 1)
79 $this->queue
->insert($resolver, $priority);
84 * Resolve a template/pattern name to a resource the renderer can consume
87 * @param null|Renderer $renderer
88 * @return false|string
90 public function resolve($name, Renderer
$renderer = null)
92 $this->lastLookupFailure
= false;
93 $this->lastSuccessfulResolver
= null;
95 if (0 === count($this->queue
)) {
96 $this->lastLookupFailure
= static::FAILURE_NO_RESOLVERS
;
100 foreach ($this->queue
as $resolver) {
101 $resource = $resolver->resolve($name, $renderer);
103 // No resource found; try next resolver
107 // Resource found; return it
108 $this->lastSuccessfulResolver
= $resolver;
112 $this->lastLookupFailure
= static::FAILURE_NOT_FOUND
;
117 * Return the last successful resolver, if any
121 public function getLastSuccessfulResolver()
123 return $this->lastSuccessfulResolver
;
127 * Get last lookup failure
129 * @return false|string
131 public function getLastLookupFailure()
133 return $this->lastLookupFailure
;