File: Zend_Console_Getopt-Configuration.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 (275 lines) | stat: -rw-r--r-- 12,348 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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect1 id="zend.console.getopt.configuration">
    <title>Konfigurieren von Zend_Console_Getopt</title>

    <sect2 id="zend.console.getopt.configuration.addrules">
        <title>Regeln für das Hinzufügen von Optionen</title>

        <para>
            Man kann mehr Optionsregeln hinzufügen, zusätzlich zu denen die
            schon im <classname>Zend_Console_Getopt</classname> Constructor definiert wurden,
            durch Verwendung der <methodname>addRules()</methodname> Methode. Das Argument für
            <methodname>addRules()</methodname> ist das gleiche wie das erste Argument für den
            Constructor der Klasse. Es ist entweder eine Zeichenkette im Format der
            kurzen Syntax wie für das Definieren für Optionen definiert, oder ein
            assoziatives Array im Format der langen Syntax wie für das Definieren
            für Optionen definiert. Siehe
            <link linkend="zend.console.getopt.rules">Definieren von GetOpt Regeln</link>
            für Details über die Syntax für die Definition von Optionen.
        </para>

        <example id="zend.console.getopt.configuration.addrules.example">
            <title>Verwenden von addRules()</title>

            <programlisting language="php"><![CDATA[
$opts = new Zend_Console_Getopt('abp:');
$opts->addRules(
  array(
    'verbose|v' => 'Druckt zusätzliche Ausgaben'
  )
);
]]></programlisting>
        </example>

        <para>
            Das obige Beispiel zeigt das hinzufügen der <command>--verbose</command>
            Option mit einem Alias von <command>-v</command> zu einem Set von Optionen
            welche bereits im Aufruf durch den Constructor definiert wurden.
            Man kann kurze Format Optionen und lange Format Optionen in der
            gleichen Instanz von <classname>Zend_Console_Getopt</classname> vermischen.
        </para>
    </sect2>

    <sect2 id="zend.console.getopt.configuration.addhelp">
        <title>Hilfstexte hinzufügen</title>

        <para>
            Zusätzlich zum Definieren von Hilfstexten bei der Definition
            von Optionsregeln im langen Format, können Hilfstexte
            mit Optionsregeln verknüpft werden durch Verwendung der
            <methodname>setHelp()</methodname> Methode. Das Argument für die
            <methodname>setHelp()</methodname> Methode ist ein assoziatives Array, in welchen der
            Schlüssel ein Flag ist, und der Wert der betreffende Hilfetext.
        </para>

        <example id="zend.console.getopt.configuration.addhelp.example">
            <title>Verwenden von setHelp()</title>

            <programlisting language="php"><![CDATA[
$opts = new Zend_Console_Getopt('abp:');
$opts->setHelp(
    array(
        'a' => 'Apfel Option, ohne Parameter',
        'b' => 'Bananen Option, mit benötigtem Integer Parameter',
        'p' => 'Pfirsich Option, mit optionalem Zeichenketten Parameter'
    )
);
]]></programlisting>
        </example>

        <para>
            Wenn Optionen mit Aliasen definiert wurden, kann jeder dieser Aliase
            als Schlüssel für das assizoative Array verwendet werden.
        </para>

        <para>
            Die <methodname>setHelp()</methodname> Methode ist der einzige Weg um einen
            Hilfetext zu definieren wenn die Optionen mit der kurzen Syntax definiert
            wurden.
        </para>
    </sect2>

    <sect2 id="zend.console.getopt.configuration.addaliases">
        <title>Aliase für Optionen hinzufügen</title>

        <para>
            Aliase für Optionen können mit der <methodname>setAliases()</methodname> Methode
            definiert werden. Das Argument ist ein assoziatives Array, dessen
            Schlüssel ein zuvor definiertes Flag, und dessen Wert ein neuer
            Alias für dieses Flag ist. Diese Aliase werden mit jedem existierenden
            Alias für dieses Flag gemischt. Mit anderen Worten, die zuvor definierten
            Aliase sind noch immer in Verwendung.
        </para>

        <para>
            Ein Alias kann nur einmal definiert werden. Wenn versucht wird einen Alias nochmals zu
            definieren wird eine <classname>Zend_Console_Getopt_Exception</classname> geworfen.
        </para>

        <example id="zend.console.getopt.configuration.addaliases.example">
            <title>Verwenden von setAliases()</title>

            <programlisting language="php"><![CDATA[
$opts = new Zend_Console_Getopt('abp:');
$opts->setAliases(
    array(
        'a' => 'apple',
        'a' => 'apfel',
        'p' => 'pfirsich'
    )
);
]]></programlisting>
        </example>

        <para>
            Im obigen Beispiel sind, nach Definition der Aliase, <command>-a</command>,
            <command>--apple</command> und <command>--apfel</command> Aliase füreinander.
            Auch <command>-p</command> und <command>--pfirsich</command> sind füreinander
            Aliase.
        </para>

        <para>
            Die <methodname>setAliases()</methodname> Methode ist der einzige Weg um Aliase
            zu definieren wenn die Optionen mit der kurzen Syntax definiert wurden.
        </para>
    </sect2>

    <sect2 id="zend.console.getopt.configuration.addargs">
        <title>Argument Listen hinzufügen</title>

        <para>
            Standardmäßig verwendet <classname>Zend_Console_Getopt</classname>
            <varname>$_SERVER['argv']</varname> für die Analyse des Arrays von
            Kommandozeilen Argumenten. Alternativ kann das Array mit Argumenten
            als zweites Argument dem Constructor angegeben werden. Letztendlich
            können zusätzliche Argumente zu den bereits in Verwendung befindlichen
            hinzugefügt werden, durch Verwendung der <methodname>addArguments()</methodname>
            Methode, oder es kann das aktuelle Array von Argumenten
            ersetzt werden mit Hilfe der <methodname>setArguments()</methodname> Methode.
            In beiden Fällen ist der Parameter für diese Methoden ein einfaches
            Array von Zeichenketten, und die letztere Methode substituiert das Array für
            seine aktuellen Argumente.
        </para>

        <example id="zend.console.getopt.configuration.addargs.example">
            <title>Verwenden von addArguments() und setArguments()</title>

            <programlisting language="php"><![CDATA[
// Normalerweise verwendet der Constructor $_SERVER['argv']
$opts = new Zend_Console_Getopt('abp:');

// Ein Array zu den bestehenden Argumenten hinzufügen
$opts->addArguments(array('-a', '-p', 'p_parameter', 'non_option_arg'));

// Ein neues Array als Ersatz für die bestehenden Argumente
$opts->setArguments(array('-a', '-p', 'p_parameter', 'non_option_arg'));
]]></programlisting>
        </example>
    </sect2>

    <sect2 id="zend.console.getopt.configuration.config">
        <title>Konfiguration hinzufügen</title>

        <para>
            Der dritte Parameter des <classname>Zend_Console_Getopt</classname> Constructors
            ist ein Array von Optionen zur Konfiguration welche das Verhalten der
            zurückgegebenen Objektinstanz beeinflusst. Es können auch durch Verwendung
            der <methodname>setOptions()</methodname> Optionen für die Konfiguration definiert
            werden, oder es können auch individuelle Optionen mit der
            <methodname>setOption()</methodname> Methode verwendet werden.
        </para>

        <note>
            <title>Klarstellung des Ausdrucks "Option"</title>

            <para>
                Der Ausdruck "Option" wird für die Konfiguration der
                <classname>Zend_Console_Getopt</classname> Klasse verwendet um der Terminologie zu
                folgen die überall im Zend Framework benutzt wird. Das ist nicht das selbe wie die
                Kommandozeilen Optionen die von der <classname>Zend_Console_Getopt</classname>
                Klasse analysiert werden.
            </para>
        </note>

        <para>
            Die aktuell unterstützten Optionen sind durch Konstanten in der Klasse definiert.
            Diese Optionen, bzw deren konstanter Bezeichner (mit wörtlichem Wert in
            Großschreibweise) sind anbei gelistet:
        </para>

        <itemizedlist>
            <listitem>
                <para>
                    <constant>Zend_Console_Getopt::CONFIG_DASHDASH</constant> ("dashDash"),
                    wenn es <constant>TRUE</constant> ist, ermöglicht dieses spezielle Flag
                    <command>--</command> das Ende von Flags zu signieren. Kommendozeilen Argumente
                    welche dem Doppel-Bindestrich Zeichen folgen werden nicht als Option
                    interpretiert selbst wenn das Argument mit einem Bindestrich beginnt.
                    Diese Konfigurationsoption ist standardmäßig <constant>TRUE</constant>.
                </para>
            </listitem>

            <listitem>
                <para>
                    <constant>Zend_Console_Getopt::CONFIG_IGNORECASE</constant> ("ignoreCase"),
                    wenn es <constant>TRUE</constant> ist, werden Flags als Aliase voneinander
                    betrachtet wenn Sie sich nur in der Groß- oder Kleinschreibung unterscheiden.
                    Das bedeutet das <command>-a</command> und <command>-A</command> als
                    gleiche Flags angesehen werden. Diese Konfigurationsoption ist
                    standardmäßig <constant>FALSE</constant>.
                </para>
            </listitem>

            <listitem>
                <para>
                    <constant>Zend_Console_Getopt::CONFIG_RULEMODE</constant> ("ruleMode") kann
                    die Werte <constant>Zend_Console_Getopt::MODE_ZEND</constant> ("zend") und
                    <constant>Zend_Console_Getopt::MODE_GNU</constant> ("gnu") haben. Diese Option
                    sollte nicht verwendet werden ausser die Klasse wird erweiter um zusätzliche
                    Syntax Formen zu unterstützen. Die zwei Modi die in der Basisklasse
                    <classname>Zend_Console_Getopt</classname> unterstützt werden sind
                    eindeutig. Wenn die Angabe eine Zeichenkette ist, nimmt die Klasse
                    <constant>MODE_GNU</constant> an, sonst wird <constant>MODE_ZEND</constant>
                    angenommen. Aber wenn die Klasse erweitert wird, und zusätzliche Syntaxformen
                    hinzugefügt werden, kann der Modus durch Verwendung dieser Option definiert
                    werden.
                </para>
            </listitem>
        </itemizedlist>

        <para>
            Zusätzliche Konfigurationsoptionen können in zukünftigen Versionen dieser
            Klasse hinzugefügt werden.
        </para>

        <para>
            Die zwei Argumente der <methodname>setOption()</methodname> Methode sind ein Name einer
            Konfigurationsoption und ein Wert für die Option.
        </para>

        <example id="zend.console.getopt.configuration.config.example.setoption">
            <title>Verwenden von setOption()</title>

            <programlisting language="php"><![CDATA[
$opts = new Zend_Console_Getopt('abp:');
$opts->setOption('ignoreCase', true);
]]></programlisting>
        </example>

        <para>
            Das Argument für die <methodname>setOptions()</methodname> Methode ist ein
            assoziatives Array. Die Schlüssel dieses Arrays sind die Namen der
            Konfigurationsoptionen, und die Werte sind die Konfigurationswerte.
            Das ist also das Array Format welches auch im Constructor der Klasse
            verwendet wird. Die definierten Konfigurationswerte werden mit der
            aktuellen Konfiguration zusammengefügt; es müssen also nicht alle
            Optionen angegeben werden.
        </para>

        <example id="zend.console.getopt.configuration.config.example.setoptions">
            <title>Verwenden von setOptions()</title>

            <programlisting language="php"><![CDATA[
$opts = new Zend_Console_Getopt('abp:');
$opts->setOptions(
    array(
        'ignoreCase' => true,
        'dashDash'   => false
    )
);
]]></programlisting>
        </example>
    </sect2>
</sect1>