-
Notifications
You must be signed in to change notification settings - Fork 22
/
ReadOnlyProtectedMembers.inc
134 lines (120 loc) · 2.41 KB
/
ReadOnlyProtectedMembers.inc
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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
<?php
/**
* @file
*
*/
module_load_include('inc', 'php_lib', 'Backtrace');
module_load_include('inc', 'php_lib', 'Array');
/**
*
*/
class ReadOnlyProtectedMembers {
/**
*
* @var string
*/
protected $owner;
/**
* Call depth.
*
* @var int
*/
protected $depth;
/**
* The list of protected members.
*
* @var array
*/
protected $members;
/**
*
* @var type
*/
protected $values;
/**
*
* @param array $members
* @param array $params
* Optional parameters that set what the owning class is.
*/
public function __construct(array $members, array $params = NULL) {
$this->owner = isset($params['owner']) ? $params['owner'] : get_caller_class(1);
$this->depth = isset($params['depth']) ? $params['depth'] : 2;
$this->members = array_keys($members);
$this->values = $members;
}
/**
* Clone this object, deeply.
*/
public function __clone() {
$this->members = $this->members; // Copy the array
$this->values = $this->values; // References stored in values are shallow copied.
}
/**
*
* @param string $name
*/
public function has($name) {
return array_search($name, $this->members) !== FALSE;
}
/**
*
* @param string $name
* @return boolean
*/
public function exists($name) {
if ($this->has($name)) {
return isset($this->values[$name]);
}
return FALSE;
}
/**
*
*/
public function add($name, $value = NULL) {
if (is_array($name)) {
foreach ($name as $key => &$value) {
$this->add($key, $value);
}
}
elseif (is_string($name)) {
array_push($this->members, $name);
$this->values[$name] = $value;
}
}
/**
* Removes a member
*
* @param string $name
*/
public function remove($name) {
unset($this->members[$name]);
}
/**
* Any one can access this member.
*/
public function __get($name) {
if ($this->exists($name)) {
return $this->values[$name];
}
return NULL;
}
/**
*
* @param string $name
* @param mixed $value
*/
public function __set($name, $value) {
if ($this->has($name)) {
if (is_or_descends_from(get_caller_object($this->depth), $this->owner)) {
$this->values[$name] = $value;
}
}
}
public function __isset($name) {
return $this->exists($name);
}
public function __unset($name) {
unset($this->values[$name]);
}
}