Zend_CodeGenerator-Introduction.xml 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.codegenerator.introduction">
  5. <title>Einführung</title>
  6. <para>
  7. <classname>Zend_CodeGenerator</classname> bietet die Möglichkeit jeglichen Code zu erstellen
  8. indem ein Objekt Orientiertes Interface verwendet wird, um sowohl neuen Code zu erstellen
  9. als auch bestehenden Code upzudaten. Wärend die aktuelle Implementation darin limitiert ist
  10. <acronym>PHP</acronym> Code zu erstellen, kann die Basisklasse einfach erweitert werden um
  11. Code Erzeugung für andere Zwecke zu bieten: JavaScript, Konfigurationsdateien, Apache
  12. VHosts, usw.
  13. </para>
  14. <sect2 id="zend.codegenerator.introduction.theory">
  15. <title>Theorie der Anwendung</title>
  16. <para>
  17. Der typischste Fall ist die Instanzierung einer Code Erzeugungs Klasse und entweder der
  18. Übergabe der entsprechenden Konfiguration oder der Konfiguration nach dessen
  19. Erstellung. Um Code zu erstellen, muß man einfach das Objekt ausgeben, oder dessen
  20. <methodname>generate()</methodname> Methode aufrufen.
  21. </para>
  22. <programlisting language="php"><![CDATA[
  23. // Konfiguration an den Construktor übergeben:
  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 \'Hallo Welt!\';',
  32. )),
  33. ),
  34. )),
  35. )
  36. ));
  37. // Konfiguration nach der Initialisierung
  38. $method = new Zend_CodeGenerator_Php_Method();
  39. $method->setName('hello')
  40. ->setBody('echo \'Hallo Welt!\';');
  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. // Die erzeugte Datei darstellen
  47. echo $file;
  48. // oder Sie in eine Datei schreiben:
  49. file_put_contents('World.php', $file->generate());
  50. ]]></programlisting>
  51. <para>
  52. Beide der obigen Beispiele werden das gleiche Ergebnis darstellen:
  53. </para>
  54. <programlisting language="php"><![CDATA[
  55. <?php
  56. class World
  57. {
  58. public function hello()
  59. {
  60. echo 'Hallo Welt!';
  61. }
  62. }
  63. ]]></programlisting>
  64. <para>
  65. Ein anderer üblicher Anwendungsfall ist die Aktualisierung von bestehendem Code -- zum
  66. Beispiel eine Methode zu einer Klasse hinzufügen. In so einem Fall, muß man zuerst
  67. den bestehenden Code betrachten, indem Reflection verwendet wird, und dann die neue
  68. Methode hinzufügen. <classname>Zend_CodeGenerator</classname> macht das sehr trivial,
  69. indem <link linkend="zend.reflection">Zend_Reflection</link> verwendet wird.
  70. </para>
  71. <para>
  72. Als Beispiel nehmen wir an dass das obige in der Datei "<filename>World.php</filename>"
  73. abgespeichert wurde, und wir diese bereits inkludiert haben. Wir könnten dann das
  74. folgende tun:
  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 \'Hallo, Mr. McFeeley!\';');
  83. $class->setMethod($method);
  84. $file = new Zend_CodeGenerator_Php_File();
  85. $file->setClass($class);
  86. // Die erzeugte Datei darstellen
  87. echo $file;
  88. // Oder besser, es in die originale Datei zurückschreiben:
  89. file_put_contents('World.php', $file->generate());
  90. ]]></programlisting>
  91. <para>
  92. Die resultierende Klasse würde wie folgt aussehen:
  93. </para>
  94. <programlisting language="php"><![CDATA[
  95. <?php
  96. class World
  97. {
  98. public function hello()
  99. {
  100. echo 'Hallo Welt!';
  101. }
  102. public function mrMcFeeley()
  103. {
  104. echo 'Hallo, Mr. McFeeley!';
  105. }
  106. }
  107. ]]></programlisting>
  108. </sect2>
  109. </sect1>