Наконец, вы можете наследовать классы Zend_Feed, если хотите обеспечить
собственный формат или такие детали, как автоматическое управление элементами,
которые должны находиться в специальном пространстве имен.
Здесь приведен пример специального класса публикации Atom, который управляет
публикациями в собственным пространстве имен myns:. Обратите
внимание, что он автоматически делает вызов registerNamespace(),
так что конечным пользователям не нужно беспокоиться о пространствах имен.
Пример 12.7. Расширение класса публикации Atom с добавлением специальных пространств имен
<?php
/**
* Специальный класс публикации знает URI ленты и может автоматически
* добавлять дополнительные пространства имен
*/
class MyEntry extends Zend_Feed_EntryAtom
{
public function __construct($uri = 'http://www.example.com/myfeed/',
$xml = null)
{
parent::__construct($uri, $xml);
Zend_Feed::registerNamespace('myns', 'http://www.example.com/myns/1.0');
}
public function __get($var)
{
switch ($var) {
case 'myUpdated':
// преобразование myUpdated в myns:updated.
return parent::__get('myns:updated');
default:
return parent::__get($var);
}
}
public function __set($var, $value)
{
switch ($var) {
case 'myUpdated':
// преобразование myUpdated в myns:updated.
parent::__set('myns:updated', $value);
break;
default:
parent::__set($var, $value);
}
}
}
?>
Далее для использования этого класса просто создаете его экземпляр и устанавливаете
свойство myUpdated:
<?php $entry = new MyEntry(); $entry->myUpdated = '2005-04-19T15:30'; ?>