Zend_Tool_Framework-WritingProviders.xml 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 16656 -->
  4. <sect1 id="zend.tool.framework.writing-providers">
  5. <title>Zend_Tool_Frameworkを利用してプロバイダを作成する</title>
  6. <para>
  7. 一般的に、プロバイダそれ自体は、
  8. コマンドラインでクライアント(またはそれ以外)をディスパッチすることを求めるいくらかの能力をバンドルするための、
  9. 開発者のためのシェル以外の何物でもありません。
  10. <acronym>MVC</acronym>アプリケーションの中での「コントローラ」と似ています。
  11. </para>
  12. <sect2 id="zend.tool.framework.writing-providers.basic">
  13. <title>プロバイダを作成するための基本命令</title>
  14. <para>
  15. 例えば、サード・パーティのコンポーネントが働かせる
  16. データファイルのバージョンを示す能力を開発者が加えたければ、
  17. 開発者が実装する必要があるクラスが1つだけあります。
  18. もしコンポーネントが<classname>My_Component</classname>と呼ばれるなら、
  19. <property>include_path</property>上のどこかに<filename>HelloProvider.php</filename>という名前のファイルで
  20. <classname>My_Component_HelloProvider</classname>という名のクラスを作成するでしょう。
  21. このクラスは<classname>Zend_Tool_Framework_Provider_Interface</classname>を実装します、
  22. そして、このファイルの本体は以下のように見えなければならないだけです:
  23. </para>
  24. <programlisting language="php"><![CDATA[
  25. class My_Component_HelloProvider
  26. implements Zend_Tool_Framework_Provider_Interface
  27. {
  28. public function say()
  29. {
  30. echo 'Hello from my provider!';
  31. }
  32. }
  33. ]]></programlisting>
  34. <para>
  35. 上記のコードが与えられて、
  36. コンソール・クライアントを通じて開発者がこの機能にアクセスしたけれ、
  37. 呼び出しはこのように見えるでしょう:
  38. </para>
  39. <programlisting language="sh"><![CDATA[
  40. % zf say hello
  41. Hello from my provider!
  42. ]]></programlisting>
  43. </sect2>
  44. <sect2 id="zend.tool.framework.writing-providers.advanced">
  45. <title>先進の開発情報</title>
  46. <para>
  47. 上記の例の "Hello World" は、単純なコマンドとして有名です、
  48. しかし、より進んだ何かについてはどうでしょうか?
  49. スクリプトを書くこととツーリングの必要性が高まるにつれ、
  50. 変数を扱う能力を必要とすると気付くかもしれません。
  51. だいたいのファンクション・シグニチャにはパラメータがあるように、
  52. ツーリング・リクエストはパラメータを受け入れることもできます。
  53. </para>
  54. <para>
  55. 各々のツーリング・リクエストがクラス内でメソッドに分離されることができると、
  56. ツーリング・リクエストのパラメータはきわめて周知の立場で分離されることもできます。
  57. プロバイダのアクション・メソッドのパラメータは、
  58. クライアントがそのプロバイダとアクションの組合せを呼ぶとき、
  59. 利用することを望む同じパラメータを含むことができます。
  60. たとえば、あなたが上記の例で名前を扱いたいならば、
  61. あなたは多分オブジェクト指向コードでこうするでしょう:
  62. </para>
  63. <programlisting language="php"><![CDATA[
  64. class My_Component_HelloProvider
  65. implements Zend_Tool_Framework_Provider_Interface
  66. {
  67. public function say($name = 'Ralph')
  68. {
  69. echo 'Hello' . $name . ', from my provider!';
  70. }
  71. }
  72. ]]></programlisting>
  73. <para>
  74. それから上記の例は、コマンドライン<command>zf say hello Joe</command>によって呼ぶことができます。
  75. "Joe" は、メソッド呼び出しのパラメータとして、プロバイダに供給されます。
  76. また注意すべきこととして、
  77. パラメータが任意だとあなたがわかるように、
  78. <command>zf say hello</command>がさらに機能して、名前 "Ralph" にデフォルト設定するように、
  79. コマンドライン上で選択できることを意味します。
  80. </para>
  81. <para>
  82. あなたが実装したいかもしれないもう一つの面白い特徴は、<emphasis>pretendability</emphasis>です。
  83. Pretendabilty は、
  84. まるでそれがリクエストされたアクションとプロバイダの組み合わせを実行しているようなふりをして、
  85. 実際にそれを実行せずに、それが実行するで<emphasis>あろう</emphasis>ことについて沢山の情報をユーザーに与えることが
  86. プロバイダにできるようにします。
  87. これ以外の場合にはユーザーが実行したくないかもしれない重いデータベースや、
  88. ファイルシステム修正をするときに重要な小道具であるかもしれません。
  89. </para>
  90. <para>
  91. Pretendability は簡単に実装できます。
  92. このフィーチャーには2つの要素があります:
  93. 1) プロバイダが「ふりをする」能力を持つことを示します。
  94. 2) 現在のリクエストが本当に、
  95. 「ふりをする」よう要求されたことを確実にするために、リクエストをチェックします。
  96. このフィーチャーは下記のコードサンプルで示されます。
  97. </para>
  98. <programlisting language="php"><![CDATA[
  99. class My_Component_HelloProvider
  100. extends Zend_Tool_Framework_Provider_Abstract
  101. implements Zend_Tool_Framework_Provider_Pretendable
  102. {
  103. public function say($name = 'Ralph')
  104. {
  105. if ($this->_registry->getRequest()->isPretend()) {
  106. echo 'I would say hello to ' . $name . '.';
  107. } else {
  108. echo 'Hello' . $name . ', from my provider!';
  109. }
  110. }
  111. }
  112. ]]></programlisting>
  113. </sect2>
  114. </sect1>