Zend_CodeGenerator-Introduction.xml 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.codegenerator.introduction">
  5. <title>導入</title>
  6. <para>
  7. <classname>Zend_CodeGenerator</classname>は、
  8. 新しいコードを作成するばかりではなく、既存のコードを更新するためにも、
  9. オブジェクト指向インターフェースを用いた任意のコードを生成する機能を提供します。
  10. 現在の実装は<acronym>PHP</acronym>コードを生成することに限られますが、
  11. 他の仕事のためのコード生成をさせるために基底クラスを簡単に拡張することができます:
  12. JavaScript、設定ファイル、apache vhosts、その他。
  13. </para>
  14. <sect2 id="zend.codegenerator.introduction.theory">
  15. <title>Theory of Operation</title>
  16. <para>
  17. 最も代表的な使用例では、単にコード・ジェネレーター・クラスのインスタンスを生成して、
  18. それに適切な設定を渡すか、またはインスタンス化のあと設定します。
  19. コードを生成するために、単にオブジェクトをechoするか、
  20. その<methodname>generate()</methodname>メソッドを呼びます。
  21. </para>
  22. <programlisting language="php"><![CDATA[
  23. //構成をコンストラクタに渡す
  24. $file = new Zend_CodeGenerator_Php_File(array(
  25. 'classes' => array(
  26. new Zend_CodeGenerator_Php_Class(array(
  27. 'name' => 'World',
  28. 'methods' => array(
  29. new Zend_CodeGenerator_Php_Method(array(
  30. 'name' => 'hello',
  31. 'body' => 'echo \'Hello world!\';',
  32. )),
  33. ),
  34. )),
  35. )
  36. ));
  37. //インスタンス化のあと設定
  38. $method = new Zend_CodeGenerator_Php_Method();
  39. $method->setName('hello')
  40. ->setBody('echo \'Hello world!\';');
  41. $class = new Zend_CodeGenerator_Php_Class();
  42. $class->setName('World')
  43. ->setMethod($method);
  44. $file = new Zend_CodeGenerator_Php_File();
  45. $file->setClass($class);
  46. //生成されたファイルのレンダリング
  47. echo $file;
  48. //またはファイルへの書き出し:
  49. file_put_contents('World.php', $file->generate());
  50. ]]></programlisting>
  51. <para>
  52. 上記のサンプルは両方とも同じ結果でレンダリングされます:
  53. </para>
  54. <programlisting language="php"><![CDATA[
  55. <?php
  56. class World
  57. {
  58. public function hello()
  59. {
  60. echo 'Hello world!';
  61. }
  62. }
  63. ]]></programlisting>
  64. <para>
  65. もう一つの一般的な使用例は、既存のコードを更新することです。
  66. たとえばメソッドをクラスに加えるために。
  67. この場合には、最初にreflectionを用いて既存のコードを調べて、
  68. 次に新しいメソッドを加えなければいけません。
  69. <link linkend="zend.reflection">Zend_Reflection</link>を導入することによって、
  70. <classname>Zend_CodeGenerator</classname>はつまらないほどこれを単純にします。
  71. </para>
  72. <para>
  73. 例えば、上記をファイル"<filename>World.php</filename>"に保存して、すでにincludeしたとしましょう。
  74. それから下記のようにできます。
  75. </para>
  76. <programlisting language="php"><![CDATA[
  77. $class = Zend_CodeGenerator_Php_Class::fromReflection(
  78. new Zend_Reflection_Class('World')
  79. );
  80. $method = new Zend_CodeGenerator_Php_Method();
  81. $method->setName('mrMcFeeley')
  82. ->setBody('echo \'Hello, Mr. McFeeley!\';');
  83. $class->setMethod($method);
  84. $file = new Zend_CodeGenerator_Php_File();
  85. $file->setClass($class);
  86. //生成されたファイルのレンダリング
  87. echo $file;
  88. //または、より良いですが、元のファイルに書き戻します。:
  89. file_put_contents('World.php', $file->generate());
  90. ]]></programlisting>
  91. <para>
  92. クラスファイルの結果はこのようになります:
  93. </para>
  94. <programlisting language="php"><![CDATA[
  95. <?php
  96. class World
  97. {
  98. public function hello()
  99. {
  100. echo 'Hello world!';
  101. }
  102. public function mrMcFeeley()
  103. {
  104. echo 'Hellow Mr. McFeeley!';
  105. }
  106. }
  107. ]]></programlisting>
  108. </sect2>
  109. </sect1>