Zend_Config-TheoryOfOperation.xml 5.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. <sect1 id="zend.config.theory_of_operation">
  2. <title>Aspectos Teóricos</title>
  3. <para>
  4. Los datos de configuración se hacen accesibles al constructor <code>Zend_Config</code>
  5. a través de un array asociativo, que puede ser multidimensional, para permitir
  6. organizar los datos desde lo general a lo específico. Las clases de adaptador concretas
  7. permiten construir una tabla asociativa para el constructor de <code>Zend_Config</code>
  8. a partir de un sistema de almacenamiento de datos de configuración. Algunos scripts
  9. de usuario pueden proveer esos arrays directamente al constructor Zend_Config,
  10. sin usar una clase adaptador, lo cual puede ser apropiado en ciertas ocasiones.
  11. </para>
  12. <para>
  13. Cada valor del array de datos de configuración se convierte en una propiedad del objeto <code>Zend_Config</code>.
  14. La clave es usada como el nombre de la propiedad. Si un valor es un array por sí solo, entonces la propiedad
  15. de objeto resultante es creada como un nuevo objeto
  16. <code>Zend_Config</code>, cargado con los datos del array. Esto ocurre recursivamente, de forma
  17. que una jerarquía de datos de configuración puede ser creada con cualquier número de niveles.
  18. </para>
  19. <para>
  20. <code>Zend_Config</code> implementa las interfaces <code>Countable</code> e <code>Iterator</code>
  21. para facilitar el aceso sencillo a los datos de configuración.
  22. Así, uno puede usar la función <ulink url="http://php.net/count"><code>count()</code></ulink>
  23. y constructores PHP como
  24. <ulink url="http://php.net/foreach"><code>foreach</code></ulink> sobre objetos
  25. <code>Zend_Config</code>.
  26. </para>
  27. <para>
  28. Por defecto, los datos de configuración permitidos a través de <code>Zend_Config</code>
  29. son de sólo lectura, y una asignación (e.g.,
  30. <code>$config-&gt;database-&gt;host = 'example.com'</code>)
  31. provoca que se lance una excepción. Este comportamiento por defecto puede ser sobrescrito a través
  32. del constructor, sin embargo, para permitir la modificación de valores de datos. Además, cuando
  33. las modificaciones están permitidas, <code>Zend_Config</code> soporta el borrado de elementos (unset) (i.e. <code>unset($config-&gt;database-&gt;host);</code>). El método
  34. <code>readOnly()</code> puede ser usado para determinar si las modificaciones a un objeto <code>Zend_Config</code>
  35. están permitidas y el método <code>setReadOnly()</code> puede ser usado para evitar cualquier modificación
  36. posterior a un objeto <code>Zend_Config</code> que fue creado con permiso de modificaciones.
  37. <note>
  38. <para>
  39. Es importante no confundir tales modificaciones en memoria con guardar los datos de configuración a un
  40. medio de almacenamiento específico. Las herramientas para crear y modificar datos de configuración para
  41. distintos medios de almacenamiento están fuera del alcance de <code>Zend_Config</code>.
  42. Existen soluciones third-party de código abierto con el propósito de crear y modificar
  43. datos de configuración de distintos medios de almacenamiento.
  44. </para>
  45. </note>
  46. </para>
  47. <para>
  48. Las clases del adaptador heredan de la clase <code>Zend_Config</code> debido a que utilizan su funcionalidad.
  49. </para>
  50. <para>
  51. La familia de clases <code>Zend_Config</code> permite organizar en secciones
  52. los datos de configuración. Los objetos de adaptador <code>Zend_Config</code>
  53. pueden ser cargados con una sola sección especificada, múltiples secciones especificadas,
  54. o todas las secciones (si no se especifica ninguna).
  55. </para>
  56. <para>
  57. Las clases del adaptador <code>Zend_Config</code> soportan un modelo de herencia única
  58. que permite que los datos de configuración hereden de una sección de datos de configuración a otra.
  59. Esto es provisto con el fin de reducir o eliminar la necesidad de duplicar datos de configuración por
  60. distintos motivos. Una sección heredada puede también sobrescribir los valores que hereda de su sección
  61. padre. Al igual que la herencia de clases PHP, una sección puede heredar de una sección padre,
  62. la cual puede heredar de una sección abuela, etc..., pero la herencia múltiple
  63. (i.e., la sección C heredando directamente de las secciones padre A y B) no está permitida.
  64. </para>
  65. <para>
  66. Si tiene dos objetos <code>Zend_Config</code>, puede combinarlos en un único
  67. objeto usando la función <code>merge()</code>. Por ejemplo, dados <code>$config</code> y
  68. <code>$localConfig</code>, puede fusionar datos de <code>$localConfig</code> a <code>$config</code> usando
  69. <code>$config-&gt;merge($localConfig);</code>. Los ítemes en <code>$localConfig</code> sobrescribirán
  70. cualquier item con el mismo nombre en <code>$config</code>.
  71. <note>
  72. <para>
  73. El objeto <code>Zend_Config</code> que está ejecutando el merge debe haber sido construido
  74. para permitir modificaciones, pasando <code>true</code> como el segundo parámetro del constructor.
  75. El método <code>setReadOnly()</code> puede entonces ser usado para evitar cualquier
  76. modificación posterior después de que el merge se haya completado.
  77. </para>
  78. </note>
  79. </para>
  80. </sect1>
  81. <!--
  82. vim:se ts=4 sw=4 et:
  83. -->