forked from culturebase/cbserialize
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclass.cb_serialize_fallback.php
61 lines (55 loc) · 1.81 KB
/
class.cb_serialize_fallback.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
<?php
/* This file is part of cbserialize.
* Copyright © 2011-2012 stiftung kulturserver.de ggmbh <[email protected]>
*
* cbserialize is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* cbserialize is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with cbserialize. If not, see <http://www.gnu.org/licenses/>.
*/
require_once 'class.cb_serializer.php';
require_once 'class.cb_serialize_base.php';
/**
* return value of fallback properties
*
* @author Sarah
*/
class CbSerializeFallback extends CbSerializeBase {
function __construct(array $fallbacks, $fields = array(), $args = array())
{
parent::__construct($fields, $args);
$this->fallbacks = $fallbacks;
}
/**
* returns the alternative value if the original value is empty
*
* The method if the value given by property <name> is empty
* the first value of the fallback name which is not empty is returned
*
* @param type $object
* @param type $name
* @return type
*/
function value($object, $name)
{
$value = CbSerializer::getObjectMember($object, $name);
if (empty($value)) {
foreach ($this->fallbacks as $fallback) {
$value = CbSerializer::getObjectMember($object, $fallback);
if (!empty($value)) {
break;
}
}
}
return $value;
}
protected $fallbacks = NULL;
}