Zend_CodeGenerator Beispiele
Example #1 Erzeugung von PHP Klassen
Das folgende Beispiel erzeugt eine leere Klasse mit einem Klassen-level DocBlock.
span style="color: #ff0000;">'shortDescription' => 'Beispiel einer erzeugten Klasse',
'longDescription' => 'Das ist eine mit Zend_CodeGenerator '
. 'erzeugte Klasse.',
'tags''name' => 'version',
'description' => '$Rev:$''name' => 'license',
'description' => 'New BSD',
),
),
));
$foo->setName('Foo'
Der obige Code führt zu dem folgenden:
/**
* Beispiel einer erzeugten Klasse
*
* Das ist eine mit Zend_CodeGenerator erzeugte Klasse.
*
* @version $Rev:$
* @license New BSD
*
*/
Example #2 Erzeugung von PHP Klassen mit Klassen-Eigenschaften
Aufbauend auf dem vorherigen Beispiel, fügen wir jetzt Eigenschaften in unsere erzeugte
Klasse ein.
span style="color: #ff0000;">'shortDescription' => 'Beispiel einer erzeugten Klasse',
'longDescription' => 'Das ist eine mit Zend_CodeGenerator '
. 'erzeugte Klasse.',
'tags''name' => 'version',
'description' => '$Rev:$''name' => 'license',
'description' => 'New BSD',
),
),
));
$foo->setName('Foo''name' => '_bar',
'visibility' => 'protected',
'defaultValue' => 'baz''name' => 'baz',
'visibility' => 'public',
'defaultValue' => 'bat''name' => 'bat',
'const''defaultValue' => 'foobarbazbat'
Das obige führt zu der folgenden Klassen-Definition:
/**
* Beispiel einer erzeugten Klasse
*
* Das ist eine mit Zend_CodeGenerator erzeugte Klasse.
*
* @version $Rev:$
* @license New BSD
*
*/'baz''bat';
const bat = 'foobarbazbat';
}
Example #3 Erzeugung von PHP Klassen mit Klassen-Methoden
Zend_CodeGenerator_Php_Class erlaubt es Methoden mit optionalem
Inhalt zur Klasse hinzuzufügen. Methoden können entweder als Array oder als konkrete
Instanzen von Zend_CodeGenerator_Php_Method hinzugefügt werden.
span style="color: #ff0000;">'shortDescription' => 'Beispiel einer erzeugten Klasse',
'longDescription' => 'Das ist eine mit Zend_CodeGenerator '
. 'erzeugte Klasse.',
'tags''name' => 'version',
'description' => '$Rev:$''name' => 'license',
'description' => 'New BSD',
),
),
));
$foo->setName('Foo''name' => '_bar',
'visibility' => 'protected',
'defaultValue' => 'baz''name' => 'baz',
'visibility' => 'public',
'defaultValue' => 'bat''name' => 'bat',
'const''defaultValue' => 'foobarbazbat'// Methoden als Array übergeben
'name' => 'setBar',
'parameters''name' => 'bar'),
),
'body' => '$this->_bar = $bar;' . "\n" . 'return $this;',
'docblock''shortDescription' => 'Setzt die bar Eigenschaft',
'tags''paramName' => 'bar',
'datatype' => 'string''datatype' => 'string',
)),
),
)),
),
// Methoden als konkrete Instanz übergeben
'name' => 'getBar',
'body' => 'return $this->_bar;',
'docblock''shortDescription' => 'Empfängt die bar Eigenschaft',
'tags''datatype' => 'string|null'
Das obige erzeugt die folgende Ausgabe:
/**
* Beispiel einer erzeugten Klasse
*
* Das ist eine mit Zend_CodeGenerator erzeugte Klasse.
*
* @version $Rev:$
* @license New BSD
*/'baz''bat';
const bat = 'foobarbazbat';
/**
* Setzt die bar Eigenschaft
*
* @param string bar
* @return string
*//**
* Empfängt die bar Eigenschaft
*
* @return string|null
*/
Example #4 Erzeugung von PHP Dateien
Zend_CodeGenerator_Php_File kann verwendet werden um den Inhalt
einer PHP Datei zu erzeugen. Man kann Klassen inkludieren als auch
eigene Inhalte. Wenn Klassen angegängt werden sollte man entweder eine konkrete Instanz
von Zend_CodeGenerator_Php_Class oder ein Array das die Klasse
definiert anhängen.
Das folgende Beispiel nimmt an das wir $foo mit einer der
Klassen-Definitionen der vorherigen Beispiele definiert haben.
span style="color: #ff0000;">'classes''docblock''shortDescription' => 'Foo Klassen Datei',
'tags''name' => 'license',
'description' => 'New BSD',
),
),
)),
'body' => 'define(\'APPLICATION_ENV\', \'testing\');',
));
Der Aufruf von generate() erzeugt den Code -- schreibt Ihn
aber nicht in die Datei. Man muß den Inhalt holen und Ihn selbst in eine Datei
schreiben. Als Beispiel:
span style="color: #ff0000;">'Foo.php', $code);
Das obige erzeugt die folgende Datei:
span style="color: #808080; font-style: italic;">/**
* Foo Klassen Datei
*
* @license New BSD
*/
/**
* Beispiel einer erzeugten Klasse
*
* Das ist eine mit Zend_CodeGenerator erzeugte Klasse.
*
* @version $Rev:$
* @license New BSD
*/'baz''bat';
const bat = 'foobarbazbat';
/**
* Set the bar property
*
* @param string bar
* @return string
*//**
* Retrieve the bar property
*
* @return string|null
*/'APPLICATION_ENV', 'testing');
Example #5 Sähen der Code Erzeugung einer PHP Datei über Reflection
Man kann PHP Code zu einer existierenden PHP
Datei hinzufügen indem der Code Generator verwendet wird. Um das Durchzuführen muß man
auf diesem zuerst Reflection ausführen. Die statische Methode
fromReflectedFileName() erlaubt es das zu tun.
span style="color: #ff0000;">"\n\$foo->bar();"
Example #6 Sähen der Erzeugung einer PHP Klasse über Reflection
Man kann Code zu einer bestehenden Klasse hinzufügen. Um das Durchzuführen muß die
statische fromReflection() Methode verwendet werden um die
Klasse in ein Generator Objekt zu mappen. Von dort, kann man zusätzliche Eigenschaften
oder Methoden hinzufügen und die Klasse neu erstellen.
span style="color: #ff0000;">'name' => 'setBaz',
'parameters''name' => 'baz'),
),
'body' => '$this->_baz = $baz;' . "\n" . 'return $this;',
'docblock''shortDescription' => 'Die baz Eigenschaft setzen',
'tags''paramName' => 'baz',
'datatype' => 'string''datatype' => 'string',
)),
),
)),
));
$code = $generator->generate();
|
|