File: Zend_Config-TheoryOfOperation.xml

package info (click to toggle)
zendframework 1.12.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 133,584 kB
  • sloc: xml: 1,311,829; php: 570,173; sh: 170; makefile: 125; sql: 121
file content (108 lines) | stat: -rw-r--r-- 6,170 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect1 id="zend.config.theory_of_operation">
    <title>Theory of Operation</title>

    <para>
        Konfigurations-Daten werden dem <classname>Zend_Config</classname>-Konstruktor als
        assoziatives Array zur Verfügung gestellt. Das Array kann mehrdimensional sein, um die
        Übergabe geordneter Daten zu unterstützen. Spezifische Adapter fungieren als Schnittstelle
        zwischen der Datenhaltung und dem <classname>Zend_Config</classname>-Konstruktor, indem sie
        die Daten für diesen als Array aufbereiten. Es können auch direkt aus dem eigenen Code
        Arrays an den <classname>Zend_Config</classname>-Konstruktor übergeben werden, ohne eine
        Adapter-Klasse zu benutzen. In manchen Situationen kann das angebracht sein.
    </para>

    <para>
        Jeder Konfigurationswert des Arrays wird zu einer Eigenschaft des
        <classname>Zend_Config</classname> Objektes. Der Schlüssel wird als Name der Eigenschaft
        verwendet. Wenn ein Wert selbst ein Array ist, wird die resultierende Eigenschaft des
        Objektes selbst als ein neues <classname>Zend_Config</classname> Objekt erstellt und mit den
        Array Daten geladen. Das findet rekursiv statt, sodas hirarchische Konfigurationswerte mit
        einer beliebigen Anzahl an Level erstellt werden können.
    </para>

    <para>
        <classname>Zend_Config</classname> implementiert die Interfaces
        <emphasis>Countable</emphasis> und <emphasis>Iterator</emphasis> um den einfachen Zugriff
        auf Konfigurationsdaten zu gewährleisten. Dementsprechend kann man die <ulink
            url="http://php.net/count"><methodname>count()</methodname></ulink>-Funktion und auch
        <acronym>PHP</acronym> Konstrukte wie <ulink
            url="http://php.net/foreach"><emphasis>foreach</emphasis></ulink> auf
        <classname>Zend_Config</classname>-Objekte anwenden.
    </para>

    <para>
        Standardmäßig gewährt <classname>Zend_Config</classname> nur Lesezugriff auf die Daten und
        der Versuch einer Wertzuweisung (wie z. B.
        <command>$config->database->host = 'example.com';</command>) löst eine Ausnahme aus. Dieses
        Standard-Verhalten kann mit Hilfe des Konstruktors aber so überschrieben werden, dass die
        Veränderung von Daten erlaubt ist. Wenn auch Änderungen erlaubt sind, unterstützt
        <classname>Zend_Config</classname> das entfernen von Werten (z.B.
        <methodname>unset($config->database->host)</methodname>). Die
        <methodname>readOnly()</methodname> Methode kann verwendet werden um festzustellen ob
        Änderungen an einem gegebenen <classname>Zend_Config</classname> Objekt erlaubt sind und
        die <methodname>setReadOnly()</methodname> kann verwendet werden um weitere Änderungen an
        einem <classname>Zend_Config</classname> Objekt, das erstellt wurde und Änderungen erlaubt,
        zu verhindern.
    </para>

    <note>
        <para>
            Es muss angemerkt werden, dass hierbei nur die Daten im Speicher verändert werden.
            Es wird keine Änderung an den Konfigurations-Daten auf dem Speichermedium
            vorgenommen. Werkzeuge zur Veränderung gespeicherter Konfigurations-Daten liegen
            nicht im Bereich von <classname>Zend_Config</classname>. Drittanbieter bieten
            bereits diverse Open-Source-Lösungen für das Erstellen und Verändern von
            Konfigurations-Datensätzen in verschienen Formaten.
        </para>
    </note>

    <para>
        Adapter-Klassen erben von der <classname>Zend_Config</classname>-Klasse, da sie ihre
        Funktionalität nutzen.
    </para>

    <para>
        Die Familie der <classname>Zend_Config</classname>-Klassen ermöglicht es, Daten in Sektionen
        einzuteilen. Beim Initialisieren eines <classname>Zend_Config</classname>-Adapter-Objektes
        können eine einzelne spezifizierte Sektion, mehrere spezifizierte Sektionen oder alle
        Sektionen (wenn keine spezifiziert ist) geladen werden.
    </para>

    <para>
        Die <classname>Zend_Config</classname>-Adapter-Klassen unterstützen ein Modell einfacher
        Vererbung, welches es ermöglicht, dass Konfigurations-Daten aus einer Sektion an eine Andere
        vererbt werden können. Dadurch kann die Notwendigeit doppelter Konfigurations-Daten für
        verschiedene Einsatzgebiete reduziert oder beseitigt werden. Eine erbende Sektion kann die
        von der Eltern-Sektion geerbten Werte auch überschreiben. Wie auch bei der Klassen-Vererbung
        in <acronym>PHP</acronym> kann eine Sektion von einer Eltern-Sektion geerbt werden, die
        wiederum von einer Großeltern-Sektion geerbt hat und so weiter. Mehrfaches Erben
        (Beispielsweise der Fall, dass Sektion C direkt von den Eltern-Sektionen A und B erbt)
        wird dagegen nicht unterstützt.
    </para>

    <para>
        Wenn zwei <classname>Zend_Config</classname> Objekte vorhanden sind, können diese in ein
        einzelnes Objekt zusammengeführt werden indem die <methodname>merge()</methodname> Funktion
        verwendet wird. Angenommen es gibt <varname>$config</varname> und
        <varname>$localConfig</varname>, kann <varname>$localConfig</varname> in
        <varname>$config</varname> zusammengeführt werden indem
        <command>$config->merge($localConfig);</command> aufgerufen wird. Die Elemente in
        <varname>$localConfig</varname> überschreiben gleichnamige Elemente in
        <varname>$config</varname>.
    </para>
    <note>
        <para>
            Das <classname>Zend_Config</classname> Objekt das die Zusammenführung durchführt
            muß so erstellt worden sein das es Änderungen erlaubt, indem dem Constructor
            <constant>TRUE</constant> als zweiter Parameter übergeben wird. Die
            <methodname>setReadOnly()</methodname> Methode kann dann verwendet werden um
            weitere Änderungen zu verhindern nachdem die Zusammenführung fertiggestellt ist.
        </para>
    </note>
</sect1>
<!--
vim:se ts=4 sw=4 et:
-->