|
|
|||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||
| Modifikátor | Popis |
|---|---|
| :P5, :Perl5 | zapne starou verzi regulárních výrazů |
| :ratchet | bez backtrackingu |
| :i, :ignorecase | nehledí na velikost písmen |
| :m, :ignoremark | nehledí na různé druhy interpunkce |
| :g, :global | provede porovnání vícekrát |
| :ov, :overlap | provede porovnávání vícekrát, ale navíc i s překrývajícími se výskyty |
| :s, :sigspace | bílé znaky nebudou ignorovány |
| :7x, :x(7) | matchovat 7× |
| :7th, :nth(7) | 7. match |
| :nth(2,4,6...*) | matchuje sudé výskyty |
| :ex, :exhaustive | matchuje všemi způsoby (přesvědčit se lze v proměnné @()) |
Perl 6 navíc umožňuje definici vlastních modifikátorů. Pro obsáhlejší informace o modifikátorech lze doporučit nahlédnutí do dokumentace.
Klíčové slovo grammar deklaruje jmenný prostor pro pravidla. Názorněji si představme grammar jako analogii package. package obsahuje metody, podobně grammar obsahuje nějaké regulární výrazy.
Uveďme si hodně umělý příklad na validaci emailové adresy, na kterém ale uvidíme, jak se výše uvedené používá. Používá se Backus-Naurova normální forma.
grammar Email::Simple {
regex email {<uzivatel> @ <server> \. <koncovka>}
token uzivatel {[\w\.\-]+}
token server {[\w\.\-]+}
token koncovka {cz|com|info}
}
Nyní se můžeme vně jmenného prostoru například na regex email odvolávat jako na Email::Simple::email. Jak tedy ověříme správnost emailu?
if $email ~~ /Email::Simple::email/ {
say "OK";
}
Podívejme se, jaké nové operátory nám Perl 6 přináší. Již jsme se s některými setkali v minulém dílu a nyní se věnujme dalším. Na úvod je dobré se alespoň letmo podívat na kompletní přehled operátorů, kde uvidíme desítky úplně nových.
Nově lze zřetězit operátory pro porovnávání. Lze tak vytvořit následující podmínku.
if (1 <= 5 < 10){
say "OK";
}
Operátor X je tzv. metaoperátor, což je velmi zajímavá věc. Základní použití je následující.
say ((1, 2) X (4, 5)).perl; # tiskne ((1, 3), (1, 4), (2, 3), (2, 4))
Použití však je daleko širší, neboť lze specifikovat, jakým operátorem mají interagovat každé dva prvky. Implicitně je to čárka. Lze ale použít i jiné operátory. Operátor uvedeme za X.
say ((1, 2) X~ (3, 4)).perl # tiskne ("13", "14", "23", "24")
say ((1, 2) X* (3, 4)).perl # tiskne (3, 4, 6, 8)
say ((1, 2) X== (3, 4)).perl # tiskne (Bool::False, Bool::False, Bool::False, Bool::False)
Stojí za zamyšlení, jak bychom libovolný z uvedených příkladů napsali v Perlu 5.
Pro operace po složkách lze stejným způsobem použít operátor Z. Vždy spolu interagují ntý prvek v pravém seznamu a ntý prvek v levém seznamu. Podívejme se, jak efektně můžeme v Perlu 6 sčítat vektory nebo tvořit hashe.
say ((1, 2) Z+ (3, 4)).perl # tiskne (4, 6)
%hash = @zavodnici Z=> @jejich_osobni_rekordy # vytvoří hash
V Perlu 6 máme následující typy operátorů.
| Operátor s operandy | Typ |
|---|---|
| 7 + 7 | infix |
| +7 | prefix |
| $p++ | postfix |
| <7 8 9> | circumfix |
| @p[7] | postcircumfix |
Jak bychom například vytvořili a použili operátor pro zaokrouhlování (za předpokladu, že máme funkci round)?
multi sub prefix:<°> (Rat $arg) {
return round($arg);
}
say °3.14;
Měli bychom ale také specifikovat prioritu právě definovaného operátoru a asociaci. To uděláme v případě priority pomocí slov equiv, tighter, looser vzhledem k již existujícím operátorům a pomocí assoc s parametrem left, right nebo none. Například takto.
multi sub infix:<°> is equiv(&infix:<*>){ ... }
multi sub infix:<°> is tighter(&infix:<*>){ ... }
multi sub infix:<°> is looser(&infix:<*>){ ... }
multi sub infix:<°> is assoc("left"){ ... }
Pomocí multi můžeme také přetěžovat již existující operátory.
Perl 6 zavádí nový třítečkový operátor pro rozsahy s líným vyhodnocováním. Díky němu můžeme elegantně generovat různé aritmetické a geometrické posloupnosti.
1, 2, 4 ... * # generuje posloupnost mocnin dvou
1, 3, 9 ... * # generuje posloupnost mocnin tří
0, 2 ... * # generuje posloupnost sudých čísel
1, 3 ... * # generuje posloupnost lichých čísel
5, 4 ... * # generuje posloupnost čísel od 5 do minus nekonečna
1.1, 1.2 ... 5.3 # generuje posloupnost čísel od 1,1 do 5,3 s krokem 0.1
Co když chceme omezenou posloupnost, ale nevíme z hlavy poslední člen? Co například mocniny dvou do 10000?
1, 2, 4 ... 10000
To bohužel fungovat nebude, protože vygenerovaný člen je vždy porovnáván s posledním na rovnost. Příklad tedy vygeneruje nekonečnou posloupnost. Avšak existuje trik, který ji ukončit dokáže, i když poslední člen nevíme.
1, 2, 4 ... * >= 10000
Místo >= lze použít i jiný operátor. Tato konstrukce je zkratkou za uzávěr -> $a {$a >= 10000}. Totéž lze nezkráceně napsat takto.
1, 2, 4 ... -> $a {$a >= 10000}
Když chceme generovat posloupnost, která není ani aritmetická ani geometrická, musíme ji definovat jako lambda funkci. Vzpomeňme si, jak jsme psali podprogram na výpočet Fibonacciho posloupnosti. Takto ji přiřadíme do pole v Perlu 6.
my @fibonacci := 0, 1, -> $a, $b {$a + $b} ... *;
S trochou magie lze totéž přepsat takto.
my @fibonacci := 0, 1, * + * ...^ *
Výsledek po operaci ... lze samozřejmě přiřadit do pole.
@mocniny_dvou = 1, 2, 4 ... *;
Prvních 6 elementů vytiskneme takto.
say @mocniny_dvou[^6];
Podívejme se v bodech na několik zajímavých změn.
|
Nejsou žádné diskuzní příspěvky u dané položky. Příspívat do diskuze mohou pouze registrovaní uživatelé. | |
17.5.2013 7:15 /MaReK Olšavský
Blender, jeden z nejvíce známých F/L/OSS programů, se postupně etabluje v 3D tisku, díky malému 3D Printing Toolboxu. Dostupnost toolboxu, pro oblíbený nástroj, by mohla pomoci v rozšíření již dostupné technologie, které se predikuje multimiliardový trh.
Přidat komentář
17.5.2013 7:15 /MaReK Olšavský
Německá společnost SerNet připravila balíky se Sambou 4 pro běžně používané distribuce. Cesty k repozitářům budou bezplatně zaslány po registraci emailem.
Přidat komentář
16.5.2013 7:11 /MaReK Olšavský
Jak pomohl F/L/OSS vítězství Baracka Husseina Obamy v prezidentské volbě shrnul Steven J. Vaughan-Nichols. Využit byl Amazon Web Services s Ubuntu a za celý cloud projekt zpracovával průměrně 10 000 požadavků za vteřinu.
Přidat komentář
16.5.2013 7:11 /MaReK Olšavský
Vývojáři KDE nezahálí a krátce po vydání KDE 4.10.3 jsou známé plány pro KDE 4.11. Další verze by měla přinést KIO-slave pro MTP, opravu chování KWin při fullscreen běhu aplikací, přepis některý Plasmoidů do QML a další.
Přidat komentář
16.5.2013 7:11 /MaReK Olšavský
Tip: Použití gmailu jako relay pro Sendmail by mohlo pomoci uživatelům laptopů, kteří nemají pro každý účet SMTP a používání SMTP od ISP je pro ně problematické, jelikož se pohybují mezi různými poskytovateli připojení.
Přidat komentář
15.5.2013 7:08 /MaReK Olšavský
Modul s kamerou/fotoaparátem pro Raspberry Pi je v prodeji, za cca £17. Modul je podorován distribucí Raspbian.
Přidat komentář
15.5.2013 7:08 /MaReK Olšavský
S příchodem herní konzole NVidia Shield na trh, vybavenou mikroprocesorem Tegra 4, 2 GB RAM a displejem s vysokým rozlišením 1280×720 px, se rozšíří nabídka Androidích herních zařízení. Na Kickstarteru úspěšná Ouya nebude mít jednoduchou pozici hned na začátku prodejů.
Přidat komentář
15.5.2013 7:08 /MaReK Olšavský
Na nebezpečí při používání Skype upozorňuje článek na webu The H. Teoreticky může Microsoft číst a analyzovat veškerou komunikaci procházející servery, ale je možné vybrat z takového informačního šumu relevantní informace?
Přidat komentář
18.5.2013 17:55 /
Martin Kumst
Re: zaheslování bash scriptu nebo složky
18.5.2013 7:44 /
---
Re: Prosím o pomoc či radu
15.5.2013 19:21 /
Filip Vaněček
Cesty k souborům při používání coolurl
13.5.2013 6:50 /
Radim Kolář
Zabbix
8.5.2013 6:07 /
MaReK Olšavský
Web Upd8