Přesunutí ukázkového obsahu do adresáře „ukázka“ a vytvoření symbolického odkazu „vstup“, který na něj ukazuje.
Uživatel si může symbolický odkaz smazat a udělat si místo něj adresář „vstup“ nebo odkaz nasměrovat jinam.
2 xmlns="https://trac.frantovo.cz/xml-web-generator/wiki/xmlns/strana"
3 xmlns:m="https://trac.frantovo.cz/xml-web-generator/wiki/xmlns/makro">
4 <nadpis>Skriptování</nadpis>
5 <perex>Na stránku můžeme vložit výstup skriptů.</perex>
8 <text xmlns="http://www.w3.org/1999/xhtml">
11 Na stránkách můžeme používat skripty.
12 Spouští se při generování a jejich standardní výstup se vloží do stránky.
13 Třeba doprostřed textu ostavce nebo do jiného elementu.
18 Tyto stránky byly vygenerované v systému
19 <span title="tento text pochází ze skriptu"><m:skript jazyk="bash">uname -o</m:skript></span>.
24 Díky skriptování můžeme stránky obohatit o prakticky libovolný obsah –
25 jak prostý text, tak i XHTML fragmenty.<m:podČarou>
26 Zapíná se pomocí atributu <code>výstup="xhtml"</code> a generátor pak kontroluje správné formátování –
27 nestane se vám, že byste omylem vygenerovali stránky s překříženými nebo neuzavřenými značkami.
28 Výchozím jmenným prostorem je XHTML a je dostupný i jmenný prostor pro makra (<code>m</code>).
32 Skriptování ale může být nebezpečné, pokud byste spustili generátor na stránkách,
33 které psal někdo nedůvěryhodný a vložil do nich škodlivý kód.
34 Kromě toho, ukázková sada stránek by měla být přeložitelná kdekoli a mít minimum závislostí
35 (ne každý musí mít nainstalovaný Perl nebo Python či další podporované interprety).
36 Proto je skriptování ve výchozím stavu vypnuté – je potřeba ho povolit v souboru <code>web.conf</code>.
39 <h2>Podporované jazyky</h2>
41 V současnosti jsou podporované tyto jazyky:
52 <m:skript jazyk="perl" výstup="xhtml"><![CDATA[
56 open(JAVA, "<", $ENV{"XWG_SKRIPTOVANI_JAVA"}) or die $!;
59 if (/podporovanýJazyk\.put\("(\w+)",\s*"(.*)"\);/) {
60 print "<tr><td><code>$1</code></td><td><code>$2</code></td></tr>\n";
67 <h3>Perl – ukázka</h3>
68 <p>Jazyky použité nebo citované na této stránce:</p>
70 Lepšího výsledku bychom samozřejmě dosáhli pomocí XPath dotazu,
71 ale toto je příklad na Perl :-)
73 <pre><m:skript jazyk="perl"><![CDATA[
77 open(XML, "<", $ENV{"XWG_STRANKA_SOUBOR"}) or die $!;
81 if (/m:skript\s+jazyk="(\w+)"/) {
87 print "$skripty{$_}×\t $_\n";
91 <h3>BASH – ukázka</h3>
92 <pre><m:skript jazyk="bash"><![CDATA[
95 echo -n "Operační systém: ";
97 echo -n "SHA-1 otisk zdrojáku této stránky: ";
98 sha1sum "$XWG_STRANKA_SOUBOR" | cut -f 1 -d " ";
103 <pre style="max-height: 200px;"><m:skript jazyk="php"><![CDATA[
110 <h2>Proměnné prostředí</h2>
112 Ve skriptech máme dostupné následující proměnné prostředí:
123 <!-- Pokud načítáme skript ze souboru, je atribut jazyk nepovinný. -->
124 <m:skript jazyk="perl" výstup="xhtml" src="skriptování-proměnné.pl"/>
132 <m:pre jazyk="xml"><![CDATA[<m:skript jazyk="bash">
133 echo "URI: $XWG_STRANKA_URI";
134 echo "Soubor: $XWG_STRANKA_SOUBOR";
135 echo "Nadpis: $XWG_STRANKA_NADPIS";
136 echo "Perex: $XWG_STRANKA_PEREX";
137 </m:skript>]]></m:pre>
141 <pre><m:skript jazyk="bash"><![CDATA[
142 echo "URI: $XWG_STRANKA_URI" | sed "s#/mnt/sshfs/[^/]*/#/#" | sed s/\\/home\\/$USER/\\/home\\/xwg/g;
143 echo "Soubor: $XWG_STRANKA_SOUBOR" | sed "s#/mnt/sshfs/[^/]*/#/#" | sed s/\\/home\\/$USER/\\/home\\/xwg/g;
144 echo "Nadpis: $XWG_STRANKA_NADPIS";
145 echo "Perex: $XWG_STRANKA_PEREX";
148 <h2 id="makraZeSkriptů">Makra ze skriptů</h2>
150 XML generované skriptem může také obsahovat makra, která se následně interptetují.
151 <m:skript jazyk="bash" výstup="xhtml"><![CDATA[
152 echo '<m:skript jazyk="bash">'; # Ty zrůdo! :-)
153 echo 'echo "Takže můžeš skriptovat, když skriptuješ,";';
156 nebo dělat něco užitečnějšího.
159 <m:skript jazyk="perl" výstup="xhtml"><![CDATA[
163 my $adresar = "vstup/makra";
165 print "<m:diagram nadpis='Uživatelská makra v adresáři $adresar'>\n";
166 print " node [shape=\"box\"];\n";
167 print " koren [label=\"Uživatelská makra\"];\n";
169 opendir(DIR, $adresar) or die $!;
171 while (readdir(DIR)) {
173 # Měli bychom ošetřit zvláštní znaky v názvech souborů,
174 # abychom nezpůsobili chybu GraphVizu.
175 print " n$i [label=\"$_\"];\n";
176 print " koren -> n$i;\n";
180 print "</m:diagram>";
184 <p>…třeba vygenerovat tento diagram následujícím perlovským skriptem:</p>
186 <m:pre jazyk="perl"><![CDATA[
190 my $adresar = "vstup/makra";
192 print "<m:diagram nadpis='Uživatelská makra v adresáři $adresar'>\n";
193 print " node [shape=\"box\"];\n";
194 print " koren [label=\"Uživatelská makra\"];\n";
196 opendir(DIR, $adresar) or die $!;
198 while (readdir(DIR)) {
200 # Měli bychom ošetřit zvláštní znaky v názvech souborů,
201 # abychom nezpůsobili chybu GraphVizu.
202 print " n$i [label=\"$_\"];\n";
203 print " koren -> n$i;\n";
207 print "</m:diagram>";
208 closedir(DIR);]]></m:pre>
211 Který vložíme zabalený v <code><![CDATA[<m:skript jazyk="perl" výstup="xhtml"> … </m:skript>]]></code> do stránky.
214 Známá chyba: ve skriptech zatím nefungují poznámky pod čarou (a není jisté, jestli kdy fungovat budou – pravděpodobně by to vyžadovalo vícefázové zpracování).
217 <h2>Makra ve skriptech</h2>
220 Uvnitř zdrojového kódu skriptu můžeme používat jiná makra.
224 <m:pre jazyk="xml"><![CDATA[<pre>
225 <m:skript jazyk="perl">
226 print "Náš podnik se jmenuje <m:firma/>";
234 <pre><m:skript jazyk="perl">
235 print "Náš podnik se jmenuje <m:firma/>";
239 Můžete si tak vytvořit makra pro opakující se části
240 a používat je jak v textu stránek, tak ve skriptech nebo diagramech.<m:podČarou>
241 Jen pozor na ošetření zvláštních znaků – pokud text takové znaky obsahuje,
242 je dobré ho zabalit ještě do jedné značky, která se postará o <em>escapování</em>
243 pro daný kontext (skriptovací jazyk a prostředí v něm – např. apostrofy vs. uvozovky).
248 Jen pro připomenutí: nejedná se o nějaké primitivní zástupky a nahrazování textu
249 – makra můžou být parametrizovaná, obsahovat atributy (např. pád a číslo) nebo vnořené elementy
250 a na základě této parametrizace vytvářet odlišný výstup, který je následně předán skriptu.
253 <pre><m:skript jazyk="bash">
254 echo "S naší <m:firma pád="7"/> budete jistě spokojeni!";
255 echo "Stejně jako my jsme spokojeni s operačním systémem `uname -o`.";
262 <!-- Pozor: ve zvýrazňovači syntaxe Pygmentize je chyba – neumí diakritiku – správně je: pád="7" -->
263 <m:pre jazyk="xml"><![CDATA[<pre>
264 <m:skript jazyk="bash">
265 echo "S naší <m:firma pad="7"/> budete jistě spokojeni!";
266 echo "Stejně jako my jsme spokojeni s operačním systémem `uname -o`.";
271 Skripty v těchto příkladech nejsou příliš užitečné, protože pouze vypisují text,
272 který by šlo vložit přímo do XML stránky
273 – předpokládá se, že ve svých skriptech budete dělat něco zajímavějšího :-)
276 <h2>Skripty v makrech</h2>
278 Uvnitř definic maker můžeme volat<m:podČarou>
279 Ovšem trochu jiným způsobem, než ve stránkách –
280 nacházíme se totiž v <em>programu</em> (XSL šablona definující makro)
281 nikoli v <em>datovém souboru</em> (XML stránka).
283 jiná makra – mj. skripty.
284 Toho jsme využili v makru, které generuje tabulku verzí z mercurialu
285 – ten umí vypsat historii úložiště v XML, které následně snadno zpracujeme v XSLT.
291 Toto makro naleznete v souboru <code>vstup/makra/hg-verze.xsl</code>.
294 <h2>Vnořování maker</h2>
296 Trochu jiný případ je vnořování maker na stránce.
297 Např. si chceme vypsat vybrané internetové služby:
300 <m:skript jazyk="perl"><![CDATA[
304 print "Port\tSlužba\tProtokol\n";
305 open(S, "<", "/etc/services") or die $!;
307 if (/(\w+)\s+(21|22|25|80)\/(tcp)/) {
308 print "$2\t$1\t$3\n";
315 Pro vygenerování použijeme dvě makra – tabulku a skript – která vložíme do textu stránky:
318 <m:pre jazyk="xml"><![CDATA[
320 <m:skript jazyk="perl"><![CDATA[
321 print "Port\tSlužba\tProtokol\n";
322 open(S, "<", "/etc/services") or die $!;
324 if (/(\w+)\s+(21|22|25|80)\/(tcp)/) {
325 print "$2\t$1\t$3\n";
328 ]]]]>><![CDATA[</m:skript>
329 </m:tabulka>]]></m:pre>
332 Ve skriptu v tomto případě negenerujeme XHTML značky, ale CSV (s tabulátory)
333 a o převod na XHTML tabulku se postará XSL šablona.
337 Nebo to taky můžeme napsat na jeden řádek:
338 cat /etc/services | perl -ne 'if (/(\w+)\s+(21|22|25|80)\/(tcp)/) { print "$2\t$1\t$3\n";}'
339 a vložit do tabulky jako BASH skript :-)
343 Podobně bychom mohli postupovat i u <a href="#makraZeSkriptů">diagramu</a> –
344 negenerovat skriptem značky makra, ale pouze jeho obsah – zadání diagramu, nebo jen jeho část.
345 Někdy se ale může hodit ve skriptu nastavovat atributy elementů nebo elementy vytvářet dynamicky.
349 Skriptování lze použít i pro generování zdrojového kódu, který bude následně zvýrazněn
350 pomocí značky <code><m:pre jazyk="…"/></code>.
351 Toho využíváme na stránce <m:a href="zdrojáky">Zdrojové kódy</m:a> v případě SQL a XML ukázek.
352 Skript můžeme použít mj. i ke zkrácení zdrojáku – když chceme vypsat jen jeho relevantní část.