Added the zend framework 2 library, the path is specified in line no.26 in zend_modul...
[openemr.git] / interface / modules / zend_modules / library / Zend / View / Resolver / AggregateResolver.php
blob2dc907ae22a1171c79035831236c58d07ddb8101
1 <?php
2 /**
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
8 */
10 namespace Zend\View\Resolver;
12 use Countable;
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';
23 /**
24 * Last lookup failure
25 * @var false|string
27 protected $lastLookupFailure = false;
29 /**
30 * @var Resolver
32 protected $lastSuccessfulResolver;
34 /**
35 * @var PriorityQueue
37 protected $queue;
39 /**
40 * Constructor
42 * Instantiate the internal priority queue
45 public function __construct()
47 $this->queue = new PriorityQueue();
50 /**
51 * Return count of attached resolvers
53 * @return int
55 public function count()
57 return $this->queue->count();
60 /**
61 * IteratorAggregate: return internal iterator
63 * @return PriorityQueue
65 public function getIterator()
67 return $this->queue;
70 /**
71 * Attach a resolver
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);
80 return $this;
83 /**
84 * Resolve a template/pattern name to a resource the renderer can consume
86 * @param string $name
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;
97 return false;
100 foreach ($this->queue as $resolver) {
101 $resource = $resolver->resolve($name, $renderer);
102 if (!$resource) {
103 // No resource found; try next resolver
104 continue;
107 // Resource found; return it
108 $this->lastSuccessfulResolver = $resolver;
109 return $resource;
112 $this->lastLookupFailure = static::FAILURE_NOT_FOUND;
113 return false;
117 * Return the last successful resolver, if any
119 * @return Resolver
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;