Zend_Server_Reflection.xml 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <sect1 id="zend.server.reflection">
  2. <title>Zend_Server_Reflection</title>
  3. <sect2 id="zend.server.reflection.introduction">
  4. <title>Введение</title>
  5. <para>
  6. <code>Zend_Server_Reflection</code> предоставляет стандарный
  7. механизм для выполнения интроспекции функций и классов для
  8. использования с серверными классами. Он основан на Reflection API
  9. в PHP 5 и расширяет его для предоставления методов
  10. получения типов и описаний параметров и возвращаемых значений,
  11. полного списка прототипов функций и методов (т.е. комбинации всех
  12. возможных валидных вызовов), описаний функций/методов.
  13. <!--
  14. Zend_Server_Reflection provides a standard mechanism for performing
  15. function and class introspection for use with server classes. It is
  16. based on PHP 5's Reflection API, and extends it to provide methods
  17. for retrieving parameter and return value types and descriptions, a
  18. full list of function and method prototypes (i.e., all possible
  19. valid calling combinations), and function/method descriptions.
  20. -->
  21. </para>
  22. <para>
  23. Обычно этот функционал будет использоваться только разработчиками
  24. серверных классов для данного фреймворка.
  25. <!--
  26. Typically, this functionality will only be used by developers of
  27. server classes for the framework.
  28. -->
  29. </para>
  30. </sect2>
  31. <sect2 id="zend.server.reflection.usage">
  32. <title>Использование</title>
  33. <para>
  34. Основное использование простое:
  35. <!--
  36. Basic usage is simple:
  37. -->
  38. </para>
  39. <programlisting language="php"><![CDATA[<?php
  40. require_once 'Zend/Server/Reflection.php';
  41. $class = Zend_Server_Reflection::reflectClass('My_Class');
  42. $function = Zend_Server_Reflection::reflectFunction('my_function');
  43. // Получение прототипов
  44. $prototypes = $reflection->getPrototypes();
  45. // Обход полученных прототипов
  46. foreach ($prototypes as $prototype) {
  47. // Получение типа возращаемого прототипом значения
  48. echo "Return type: ", $prototype->getReturnType(), "\n";
  49. // Получение параметров прототипа
  50. $parameters = $prototype->getParameters();
  51. echo "Parameters: \n";
  52. foreach ($parameters as $parameter) {
  53. // Получение типа параметра
  54. echo " ", $parameter->getType(), "\n";
  55. }
  56. }
  57. // Получение пространства имен для класса, функции или метода
  58. // Пространства имен могут быть установлены во время инстанцирования (второй аргумент),
  59. // или с помощью метода setNamespace()
  60. $reflection->getNamespace();
  61. ]]></programlisting>
  62. <para>
  63. <code>reflectFunction()</code> возвращает объект
  64. <code>Zend_Server_Reflection_Function</code>,
  65. <code>reflectClass</code> возвращает объект
  66. <code>Zend_Server_Reflection_Class</code>. Обратитесь к
  67. документации API чтобы узнать, какие методы доступны в
  68. этих объектах.
  69. <!--
  70. <code>reflectFunction()</code> returns a
  71. <code>Zend_Server_Reflection_Function</code> object;
  72. <code>reflectClass</code> returns a
  73. <code>Zend_Server_Reflection_Class</code> object. Please refer to
  74. the API documentation to know what methods are available to each.
  75. -->
  76. </para>
  77. </sect2>
  78. </sect1>
  79. <!--
  80. vim:se ts=4 sw=4 et:
  81. -->