/
Standard.php
113 lines (103 loc) · 3.01 KB
/
Standard.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
<?php
/**
* AspectPHP_Manager_Standard
*
* @category PHP
* @package AspectPHP_Manager
* @author Matthias Molitor <matthias@matthimatiker.de>
* @copyright 2012 Matthias Molitor
* @license http://www.opensource.org/licenses/BSD-3-Clause BSD License
* @link https://github.com/Matthimatiker/AspectPHP
* @since 12.01.2012
*/
/**
* The default manager that stores registered aspects in memory.
*
* Registrations are lost if the manager object is destroyed.
*
* @category PHP
* @package AspectPHP_Manager
* @author Matthias Molitor <matthias@matthimatiker.de>
* @copyright 2012 Matthias Molitor
* @license http://www.opensource.org/licenses/BSD-3-Clause BSD License
* @link https://github.com/Matthimatiker/AspectPHP
* @since 12.01.2012
*/
class AspectPHP_Manager_Standard implements AspectPHP_Manager
{
/**
* The registered aspects.
*
* The pointcut is used as key, the aspect objects as value.
*
* @var array(string=>array(AspectPHP_Aspect))
*/
protected $aspects = array();
/**
* See {@link AspectPHP_Manager::register()} for details.
*
* @param AspectPHP_Aspect $aspect
* @param string $pointcut
*/
public function register(AspectPHP_Aspect $aspect, $pointcut = null)
{
if (!isset($this->aspects[$pointcut])) {
$this->aspects[$pointcut] = array();
}
$this->aspects[$pointcut][] = $aspect;
}
/**
* See {@link AspectPHP_Manager::unregister()} for details.
*
* @param AspectPHP_Aspect $aspect
*/
public function unregister(AspectPHP_Aspect $aspect)
{
foreach ($this->aspects as $pointcut => $aspects) {
/* @var string $pointcut */
/* @var array(AspectPHP_Aspect) $aspects */
foreach ($aspects as $index => $currentAspect) {
/* @var AspectPHP_Aspect $currentAspect */
if ($currentAspect === $aspect) {
unset($this->aspects[$pointcut][$index]);
}
}
}
}
/**
* See {@link AspectPHP_Manager::getAspects()} for details.
*
* @return array(AspectPHP_Aspect)
*/
public function getAspects()
{
$allAspects = array();
foreach ($this->aspects as $aspects) {
$allAspects = array_merge($allAspects, $aspects);
}
return $allAspects;
}
/**
* Returns the aspects that were registered for the given method.
*
* @param string $method
* @return array(AspectPHP_Aspect)
* @deprecated Will not be used in the future. See getAdvicesFor().
*/
public function getAspectsFor($method)
{
if (!isset($this->aspects[$method])) {
return array();
}
return $this->aspects[$method];
}
/**
* See {@link AspectPHP_Manager::getAdvicesFor()} for details.
*
* @param string $method
* @return AspectPHP_Advice_Container
*/
public function getAdvicesFor($method)
{
}
}