Zend_Feed-CustomFeed.xml 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.feed.custom-feed">
  5. <title>独自のフィードクラスおよびエントリクラス</title>
  6. <para>
  7. 独自のフォーマットを提供したい、
  8. あるいは要素が自動的に所定の名前空間に配置されるなどの素敵な機能を追加したい、
  9. といった場合は <classname>Zend_Feed</classname> クラスを拡張して対応します。
  10. </para>
  11. <para>
  12. 以下に Atom エントリクラスを拡張する例を示します。
  13. このクラスでは、独自の名前空間 <emphasis>myns:</emphasis> を使用しています。
  14. また、<methodname>registerNamespace()</methodname> がコールされていることに注意しましょう。
  15. このクラスの使用者は、名前空間について心配する必要がなくなります。
  16. </para>
  17. <example id="zend.feed.custom-feed.example.extending">
  18. <title>独自の名前空間を使用しての Atom エントリクラスの拡張</title>
  19. <programlisting language="php"><![CDATA[
  20. /**
  21. * この独自エントリクラスは、自動的にフィード URI を識別 (オプション) して
  22. * 名前空間を追加します
  23. */
  24. class MyEntry extends Zend_Feed_Entry_Atom
  25. {
  26. public function __construct($uri = 'http://www.example.com/myfeed/',
  27. $xml = null)
  28. {
  29. parent::__construct($uri, $xml);
  30. Zend_Feed::registerNamespace('myns',
  31. 'http://www.example.com/myns/1.0');
  32. }
  33. public function __get($var)
  34. {
  35. switch ($var) {
  36. case 'myUpdated':
  37. // myUpdated を myns:updated に変換します
  38. return parent::__get('myns:updated');
  39. default:
  40. return parent::__get($var);
  41. }
  42. }
  43. public function __set($var, $value)
  44. {
  45. switch ($var) {
  46. case 'myUpdated':
  47. // myUpdated を myns:updated に変換します
  48. parent::__set('myns:updated', $value);
  49. break;
  50. default:
  51. parent::__set($var, $value);
  52. }
  53. }
  54. public function __call($var, $unused)
  55. {
  56. switch ($var) {
  57. case 'myUpdated':
  58. // myUpdated を myns:updated に変換します
  59. return parent::__call('myns:updated', $unused);
  60. default:
  61. return parent::__call($var, $unused);
  62. }
  63. }
  64. }
  65. ]]></programlisting>
  66. <para>
  67. そしてこのクラスを使用すると、インスタンスを作成したらすぐに
  68. <property>myUpdated</property> プロパティを設定できます。
  69. </para>
  70. <programlisting language="php"><![CDATA[
  71. $entry = new MyEntry();
  72. $entry->myUpdated = '2005-04-19T15:30';
  73. // メソッド型のコールは __call 関数が処理します
  74. $entry->myUpdated();
  75. // プロパティ型のコールは __get 関数が処理します
  76. $entry->myUpdated;
  77. ]]></programlisting>
  78. </example>
  79. </sect1>
  80. <!--
  81. vim:se ts=4 sw=4 et:
  82. -->