1 <sect1 id="zend.feed.custom-feed">
2 <title>Własne klasy kanału i wpisu</title>
5 Ostatecznie możesz rozszerzyć klasę <code>Zend_Feed</code> jeśli chcesz
6 stworzyć swój własny format lub zapewnić automatyczną obsługę elementów,
7 które działają w innej przestrzeni nazw.
11 Oto przykład własnej klasy wpisu Atom która obsługuje własną przestrzeń
12 nazw <code>myns:</code> wpisów. Zauważ, że ona także wywołuje za Ciebie
13 metodę <code>registerNamespace()</code>, dzięki czemu użytkownik końcowy
14 nie musi w ogóle martwić się o przestrzenie nazw.
17 <example id="zend.feed.custom-feed.example.extending">
18 <title>Rozszerzanie klasy wpisu Atom z własnymi przestrzeniami nazw</title>
19 <programlisting role="php"><![CDATA[
21 * Własna klasa wpisu może automatycznie nadawać adres URI (opcjonalnie)
22 * oraz automatycznie dodawać dodatkowe przestrzenie nazw.
24 class MyEntry extends Zend_Feed_Entry_Atom
27 public function __construct($uri = 'http://www.example.com/myfeed/',
30 parent::__construct($uri, $xml);
32 Zend_Feed::registerNamespace('myns',
33 'http://www.example.com/myns/1.0');
36 public function __get($var)
40 // Tłumaczy myUpdated na myns:updated.
41 return parent::__get('myns:updated');
44 return parent::__get($var);
48 public function __set($var, $value)
52 // Tłumaczy myUpdated na myns:updated.
53 parent::__set('myns:updated', $value);
57 parent::__set($var, $value);
61 public function __call($var, $unused)
65 // Tłumaczy myUpdated na myns:updated.
66 return parent::__call('myns:updated', $unused);
69 return parent::__call($var, $unused);
77 Teraz aby użyć tej klasy, musisz po prostu bezpośrednio utworzyć jej
78 instancję i przypisać wartość właściwości <code>myUpdated</code>:
80 <programlisting role="php"><![CDATA[
81 $entry = new MyEntry();
82 $entry->myUpdated = '2005-04-19T15:30';
84 // wywołanie w stylu metody jest obsługiwane przez funkcję __call
86 // wywołanie w stylu właściwości jest obsługiwane przez funkcję __get