2
0

Zend_CodeGenerator-Reference.xml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <sect1 id="zend.codegenerator.reference">
  4. <title>Referencias de Zend_CodeGenerator</title>
  5. <sect2 id="zend.codegenerator.reference.abstracts">
  6. <title>Clases Abstractas e Interfaces</title>
  7. <sect3 id="zend.codegenerator.reference.abstracts.abstract">
  8. <title>Zend_CodeGenerator_Abstract</title>
  9. <para>
  10. La clase base desde la cual heredan todos las clases
  11. CodeGenerator proporciona la funcionalidad mínima necesaria.
  12. Su API es la siguiente:
  13. </para>
  14. <programlisting role="php"><![CDATA[
  15. abstract class Zend_CodeGenerator_Abstract
  16. {
  17. final public function __construct(Array $options = array())
  18. public function setOptions(Array $options)
  19. public function setSourceContent($sourceContent)
  20. public function getSourceContent()
  21. protected function _init()
  22. protected function _prepare()
  23. abstract public function generate();
  24. final public function __toString()
  25. }
  26. ]]></programlisting>
  27. <para>
  28. El constructor primero llama a <code>_init()</code>
  29. (que se deja vacía para implementar extenciones a clases
  30. concretas), se pasa entonces el parámetro <code>$options</code>
  31. a <code>setOptions()</code>, y finalmente se llama a
  32. <code>_prepare()</code> (nuevamente, a ser implementada por
  33. extensión de una clase)
  34. </para>
  35. <para>
  36. Al igual que la mayoría de las clases en Zend Framework,
  37. <code>setOptions()</code> compara una opción clave con setters
  38. existentes en la clase, y pasa el valor de ese método
  39. si lo encuentra.
  40. </para>
  41. <para>
  42. <code>__toString()</code> es marcado como final, y proxies a
  43. <code>generate()</code>.
  44. </para>
  45. <para>
  46. <code>setSourceContent()</code> y
  47. <code>getSourceContent()</code> están destinados ya sea para
  48. fijar el valor por defecto del contenido para el código a ser
  49. generado, o para sustituir dicho contenido una vez que se
  50. completen todas las tareas de generación.
  51. </para>
  52. </sect3>
  53. <sect3 id="zend.codegenerator.reference.abstracts.php-abstract">
  54. <title>Zend_CodeGenerator_Php_Abstract</title>
  55. <para>
  56. <classname>Zend_CodeGenerator_Php_Abstract</classname> extiende
  57. <classname>Zend_CodeGenerator_Abstract</classname>, y añade
  58. algunas propiedades para localizar su contenido si es que ha
  59. cambiado, así como el nivel de identación que debe aparecer
  60. antes del contenido generado. Su API es la siguiente:
  61. </para>
  62. <programlisting role="php"><![CDATA[
  63. abstract class Zend_CodeGenerator_Php_Abstract
  64. extends Zend_CodeGenerator_Abstract
  65. {
  66. public function setSourceDirty($isSourceDirty = true)
  67. public function isSourceDirty()
  68. public function setIndentation($indentation)
  69. public function getIndentation()
  70. }
  71. ]]></programlisting>
  72. </sect3>
  73. <sect3 id="zend.codegenerator.reference.abstracts.php-member-abstract">
  74. <title>Zend_CodeGenerator_Php_Member_Abstract</title>
  75. <para>
  76. <classname>Zend_CodeGenerator_Php_Member_Abstract</classname>
  77. es una clase base para generar los miembros de clase --
  78. propiedades y métodos -- y brinda accesos y mutadores para
  79. establecer visibilidad; ya sea el miembro abstracto o no,
  80. estático o definitivo; y el nombre del miembro.
  81. Su API es la siguiente:
  82. </para>
  83. <programlisting role="php"><![CDATA[
  84. abstract class Zend_CodeGenerator_Php_Member_Abstract
  85. extends Zend_CodeGenerator_Php_Abstract
  86. {
  87. public function setAbstract($isAbstract)
  88. public function isAbstract()
  89. public function setStatic($isStatic)
  90. public function isStatic()
  91. public function setVisibility($visibility)
  92. public function getVisibility()
  93. public function setName($name)
  94. public function getName()
  95. }
  96. ]]></programlisting>
  97. </sect3>
  98. </sect2>
  99. <sect2 id="zend.codegenerator.reference.concrete">
  100. <title>Clases Concretas de CodeGenerator</title>
  101. <sect3 id="zend.codegenerator.reference.concrete.php-body">
  102. <title>Zend_CodeGenerator_Php_Body</title>
  103. <para>
  104. <classname>Zend_CodeGenerator_Php_Body</classname> se destina
  105. para generar código procedural arbitrario para incluir dentro
  106. de un archivo. Como tal, usted simplemente establece contenidos
  107. para el objeto, y éste devolverá el contenido cuando usted
  108. invoque a <code>generate()</code>.
  109. </para>
  110. <para>
  111. La API de la clase es la siguiente:
  112. </para>
  113. <programlisting role="php"><![CDATA[
  114. class Zend_CodeGenerator_Php_Body extends Zend_CodeGenerator_Php_Abstract
  115. {
  116. public function setContent($content)
  117. public function getContent()
  118. public function generate()
  119. }
  120. ]]></programlisting>
  121. </sect3>
  122. <sect3 id="zend.codegenerator.reference.concrete.php-class">
  123. <title>Zend_CodeGenerator_Php_Class</title>
  124. <para>
  125. <classname>Zend_CodeGenerator_Php_Class</classname> Está
  126. destinado a generar clases PHP. La funcionalidad básica sólo
  127. genera la clase PHP en si misma, así como opcionalmente el PHP
  128. DocBlock. Las clases pueden implementarse o heredarse de otras
  129. clases, y pueden ser marcadas como abstractas.
  130. Utilizando otras clases generadoras de código, también puede
  131. agregar constantes de clase, propiedades y métodos.
  132. </para>
  133. <para>
  134. La API de la clase es la siguiente:
  135. </para>
  136. <programlisting role="php"><![CDATA[
  137. class Zend_CodeGenerator_Php_Class extends Zend_CodeGenerator_Php_Abstract
  138. {
  139. public static function fromReflection(
  140. Zend_Reflection_Class $reflectionClass
  141. )
  142. public function setDocblock(Zend_CodeGenerator_Php_Docblock $docblock)
  143. public function getDocblock()
  144. public function setName($name)
  145. public function getName()
  146. public function setAbstract($isAbstract)
  147. public function isAbstract()
  148. public function setExtendedClass($extendedClass)
  149. public function getExtendedClass()
  150. public function setImplementedInterfaces(Array $implementedInterfaces)
  151. public function getImplementedInterfaces()
  152. public function setProperties(Array $properties)
  153. public function setProperty($property)
  154. public function getProperties()
  155. public function getProperty($propertyName)
  156. public function setMethods(Array $methods)
  157. public function setMethod($method)
  158. public function getMethods()
  159. public function getMethod($methodName)
  160. public function hasMethod($methodName)
  161. public function isSourceDirty()
  162. public function generate()
  163. }
  164. ]]></programlisting>
  165. <para>
  166. El método <code>setProperty()</code> acepta un array de
  167. información que puede ser utilizada para generar una instancia
  168. <classname>Zend_CodeGenerator_Php_Property</classname> -- o
  169. simplemente una instancia de
  170. <classname>Zend_CodeGenerator_Php_Property</classname>.
  171. Análogamente, <code>setMethod()</code> acepta o un array de
  172. información para generar una instancia de
  173. <classname>Zend_CodeGenerator_Php_Method</classname> o una
  174. instancia concreta de esa clase.
  175. </para>
  176. <para>
  177. Se debe observar que <code>setDocBlock()</code> espera una
  178. instancia de
  179. <classname>Zend_CodeGenerator_Php_DocBlock</classname>.
  180. </para>
  181. </sect3>
  182. <sect3 id="zend.codegenerator.reference.concrete.php-docblock">
  183. <title>Zend_CodeGenerator_Php_Docblock</title>
  184. <para>
  185. <classname>Zend_CodeGenerator_Php_Docblock</classname> puede
  186. ser utilizada para generar PHP docblocks arbitrarios,
  187. incluidas todas las características estándar de docblock:
  188. descripciones cortas y largas y además los tags de anotaciones.
  189. </para>
  190. <para>
  191. Los tags de anotación pueden establecerse utilizando los métodos
  192. <code>setTag()</code> y <code>setTags()</code>; cada una de
  193. estas toman o un array describiendo el tag que puede ser pasado
  194. al constructor
  195. <classname>Zend_CodeGenerator_Php_Docblock_Tag</classname>, o
  196. una instancia de esa clase.
  197. </para>
  198. <para>
  199. La API de la clase es la siguiente:
  200. </para>
  201. <programlisting role="php"><![CDATA[
  202. class Zend_CodeGenerator_Php_Docblock extends Zend_CodeGenerator_Php_Abstract
  203. {
  204. public static function fromReflection(
  205. Zend_Reflection_Docblock $reflectionDocblock
  206. )
  207. public function setShortDescription($shortDescription)
  208. public function getShortDescription()
  209. public function setLongDescription($longDescription)
  210. public function getLongDescription()
  211. public function setTags(Array $tags)
  212. public function setTag($tag)
  213. public function getTags()
  214. public function generate()
  215. }
  216. ]]></programlisting>
  217. </sect3>
  218. <sect3 id="zend.codegenerator.reference.concrete.php-docblock-tag">
  219. <title>Zend_CodeGenerator_Php_Docblock_Tag</title>
  220. <para>
  221. <classname>Zend_CodeGenerator_Php_Docblock_Tag</classname> está
  222. destinado a crear tags de anotaciones arbitrarias
  223. para su inclusión en PHP docblocks.
  224. Se espera que los tags (etiquetas) contengan un nombre
  225. (la porción que sigue inmediatamente después del símbolo '@')
  226. y una descripción (todo lo que sigue después del nombre del
  227. tag).
  228. </para>
  229. <para>
  230. La API de la clase es la siguiente:
  231. </para>
  232. <programlisting role="php"><![CDATA[
  233. class Zend_CodeGenerator_Php_Docblock_Tag
  234. extends Zend_CodeGenerator_Php_Abstract
  235. {
  236. public static function fromReflection(
  237. Zend_Reflection_Docblock_Tag $reflectionTag
  238. )
  239. public function setName($name)
  240. public function getName()
  241. public function setDescription($description)
  242. public function getDescription()
  243. public function generate()
  244. }
  245. ]]></programlisting>
  246. </sect3>
  247. <sect3 id="zend.codegenerator.reference.concrete.php-docblock-tag-param">
  248. <title>Zend_CodeGenerator_Php_DocBlock_Tag_Param</title>
  249. <para>
  250. <classname>Zend_CodeGenerator_Php_DocBlock_Tag_Param</classname>
  251. es una versión especializada de
  252. <classname>Zend_CodeGenerator_Php_DocBlock_Tag</classname>,
  253. y representa un parámetro del método.
  254. El nombre del tag es por lo tanto ("param"), pero debido
  255. al formato de este tag de anotación, es necesaria información
  256. adicional a fin de generarla: el nombre del parámetro y el tipo
  257. de datos que representa.
  258. </para>
  259. <para>
  260. La API de la clase es la siguiente:
  261. </para>
  262. <programlisting role="php"><![CDATA[
  263. class Zend_CodeGenerator_Php_Docblock_Tag_Param
  264. extends Zend_CodeGenerator_Php_Docblock_Tag
  265. {
  266. public static function fromReflection(
  267. Zend_Reflection_Docblock_Tag $reflectionTagParam
  268. )
  269. public function setDatatype($datatype)
  270. public function getDatatype()
  271. public function setParamName($paramName)
  272. public function getParamName()
  273. public function generate()
  274. }
  275. ]]></programlisting>
  276. </sect3>
  277. <sect3 id="zend.codegenerator.reference.concrete.php-docblock-tag-return">
  278. <title>Zend_CodeGenerator_Php_DocBlock_Tag_Return</title>
  279. <para>
  280. Al igual la variante del tag docblock,
  281. <classname>Zend_CodeGenerator_Php_Docblock_Tab_Return</classname>
  282. es una variante de un tag de anotación para representar el
  283. valor de retorno del método. En este caso, el nombre del tag de
  284. anotación es conocido ("return"), pero requiere un tipo de
  285. retorno.
  286. </para>
  287. <para>
  288. La API de la clase es la siguiente:
  289. </para>
  290. <programlisting role="php"><![CDATA[
  291. class Zend_CodeGenerator_Php_Docblock_Tag_Param
  292. extends Zend_CodeGenerator_Php_Docblock_Tag
  293. {
  294. public static function fromReflection(
  295. Zend_Reflection_Docblock_Tag $reflectionTagReturn
  296. )
  297. public function setDatatype($datatype)
  298. public function getDatatype()
  299. public function generate()
  300. }
  301. ]]></programlisting>
  302. </sect3>
  303. <sect3 id="zend.codegenerator.reference.concrete.php-file">
  304. <title>Zend_CodeGenerator_Php_File</title>
  305. <para>
  306. <classname>Zend_CodeGenerator_Php_File</classname> se utiliza
  307. para generar el contenido íntegro de un archivo que contiene
  308. código PHP. El archivo puede contener clases o código PHP
  309. arbitrario, así como un archivo de nivel docblock si así lo
  310. desea.
  311. </para>
  312. <para>
  313. Cuando se agregan clases al archivo, necesitará pasar o un
  314. array de información para pasar al constructor
  315. <classname>Zend_CodeGenerator_Php_Class</classname>, o una
  316. instancia de esa clase. De manera similar, con docblocks,
  317. usted tendrá que pasar información para que lo consuma
  318. el constructor
  319. <classname>Zend_CodeGenerator_Php_Docblock</classname>
  320. o una instancia de la clase.
  321. </para>
  322. <para>
  323. La API de la clase es la siguiente:
  324. </para>
  325. <programlisting role="php"><![CDATA[
  326. class Zend_CodeGenerator_Php_File extends Zend_CodeGenerator_Php_Abstract
  327. {
  328. public static function fromReflectedFilePath(
  329. $filePath,
  330. $usePreviousCodeGeneratorIfItExists = true,
  331. $includeIfNotAlreadyIncluded = true)
  332. public static function fromReflection(Zend_Reflection_File $reflectionFile)
  333. public function setDocblock(Zend_CodeGenerator_Php_Docblock $docblock)
  334. public function getDocblock()
  335. public function setRequiredFiles($requiredFiles)
  336. public function getRequiredFiles()
  337. public function setClasses(Array $classes)
  338. public function getClass($name = null)
  339. public function setClass($class)
  340. public function setFilename($filename)
  341. public function getFilename()
  342. public function getClasses()
  343. public function setBody($body)
  344. public function getBody()
  345. public function isSourceDirty()
  346. public function generate()
  347. }
  348. ]]></programlisting>
  349. </sect3>
  350. <sect3 id="zend.codegenerator.reference.concrete.php-member-container">
  351. <title>Zend_CodeGenerator_Php_Member_Container</title>
  352. <para>
  353. <classname>Zend_CodeGenerator_Php_Member_Container</classname>
  354. es usado internamente por
  355. <classname>Zend_CodeGenerator_Php_Class</classname>
  356. para seguir la pista de los los miembros de la clase --
  357. a propiedades y métodos por igual. Estos están indexados por
  358. nombre, utilizando las instancias concretas de los miembros
  359. como valores.
  360. </para>
  361. <para>
  362. La API de la clase es la siguiente:
  363. </para>
  364. <programlisting role="php"><![CDATA[
  365. class Zend_CodeGenerator_Php_Member_Container extends ArrayObject
  366. {
  367. public function __construct($type = self::TYPE_PROPERTY)
  368. }
  369. ]]></programlisting>
  370. </sect3>
  371. <sect3 id="zend.codegenerator.reference.concrete.php-method">
  372. <title>Zend_CodeGenerator_Php_Method</title>
  373. <para>
  374. <classname>Zend_CodeGenerator_Php_Method</classname> describe
  375. un método de clase, y puede generar tanto el código y el
  376. docblock para el método. La visibilidad y condición estática,
  377. abstracta, o se puede indicar como final, por su clase padre,
  378. <classname>Zend_CodeGenerator_Php_Member_Abstract</classname>.
  379. Finalmente, pueden especificarse los parámetros y valor de
  380. retorno para el método.
  381. </para>
  382. <para>
  383. Pueden establecerse los parámetros usando
  384. <code>setParameter()</code> o <code>setParameters()</code>.
  385. En cada caso, un parámetro debe ser un array de información
  386. para pasar al constructor
  387. <classname>Zend_CodeGenerator_Php_Parameter</classname> o una
  388. instancia de esa clase.
  389. </para>
  390. <para>
  391. La API de la clase es la siguiente:
  392. </para>
  393. <programlisting role="php"><![CDATA[
  394. class Zend_CodeGenerator_Php_Method
  395. extends Zend_CodeGenerator_Php_Member_Abstract
  396. {
  397. public static function fromReflection(
  398. Zend_Reflection_Method $reflectionMethod
  399. )
  400. public function setDocblock(Zend_CodeGenerator_Php_Docblock $docblock)
  401. public function getDocblock()
  402. public function setFinal($isFinal)
  403. public function setParameters(Array $parameters)
  404. public function setParameter($parameter)
  405. public function getParameters()
  406. public function setBody($body)
  407. public function getBody()
  408. public function generate()
  409. }
  410. ]]></programlisting>
  411. </sect3>
  412. <sect3 id="zend.codegenerator.reference.concrete.php-parameter">
  413. <title>Zend_CodeGenerator_Php_Parameter</title>
  414. <para>
  415. <classname>Zend_CodeGenerator_Php_Parameter</classname>
  416. puede ser utilizada para especificar parámetros del método.
  417. Cada parámetro puede tener una posición (si no están
  418. especificados, se usarán en el orden que estén registrados en
  419. el método), son oblogatorios un valor por defecto, un tipo de
  420. datos y un nombre de parámetro.
  421. </para>
  422. <para>
  423. La API de la clase es la siguiente:
  424. </para>
  425. <programlisting role="php"><![CDATA[
  426. class Zend_CodeGenerator_Php_Parameter extends Zend_CodeGenerator_Php_Abstract
  427. {
  428. public static function fromReflection(
  429. Zend_Reflection_Parameter $reflectionParameter
  430. )
  431. public function setType($type)
  432. public function getType()
  433. public function setName($name)
  434. public function getName()
  435. public function setDefaultValue($defaultValue)
  436. public function getDefaultValue()
  437. public function setPosition($position)
  438. public function getPosition()
  439. public function generate()
  440. }
  441. ]]></programlisting>
  442. </sect3>
  443. <sect3 id="zend.codegenerator.reference.concrete.php-property">
  444. <title>Zend_CodeGenerator_Php_Property</title>
  445. <para>
  446. <classname>Zend_CodeGenerator_Php_Property</classname> describe
  447. una propiedad de clase, que puede ser tanto una constante o una
  448. variable. En cada caso, la propiedad puede tener un valor
  449. predeterminado asociado con ella. Además, la visibilidad de
  450. las propiedades de la variable puede ser establecida por la
  451. clase padre,
  452. <classname>Zend_CodeGenerator_Php_Member_Abstract</classname>.
  453. </para>
  454. <para>
  455. La API de la clase es la siguiente:
  456. </para>
  457. <programlisting role="php"><![CDATA[
  458. class Zend_CodeGenerator_Php_Property
  459. extends Zend_CodeGenerator_Php_Member_Abstract
  460. {
  461. public static function fromReflection(
  462. Zend_Reflection_Property $reflectionProperty
  463. )
  464. public function setConst($const)
  465. public function isConst()
  466. public function setDefaultValue($defaultValue)
  467. public function getDefaultValue()
  468. public function generate()
  469. }
  470. ]]></programlisting>
  471. </sect3>
  472. </sect2>
  473. </sect1>