|
|||||||||||||||||||||||||||||||||||||||||||||||
Menu
Distributions (131)
bootable [55]
commercial [7] no-commercial [42] unclassified [20] [7]
Software (10844)
|
Perl (40) - Dodatky k modulům40. díl téměř dokončuje kapitolu o modulech. Hlavními tématy jsou určení cest k adresářům s moduly, speciální procedura AUTOLOAD a něco více k zavádění modulů. Z modulů nám tak zbyde už jen archiv CPAN, který si zaslouží vlastní díl.
Cesty k modulůmPoužijeme-li ve svém skriptu příkaz use Modul;, Perl implicitně tento modul hledá v adresářích, které jsou uvedené v poli @INC. Obsahem @INC jsou totiž uložené cesty k modulům. @INC je už přednastavené, ale mnohdy je třeba ho ještě ručně upravit. Typicky to nastane tehdy, pokud máme někde vlastní úložiště modulů. Je několik způsobů, jak obsah pole @INC ovlivnit. Prvním z nich je pragma lib, pomocí níž s polem @INC můžeme manipulovat. Podívejme se na tento úsek kódu, který demostruje použití lib.
$, = "\n"; Na první místo pole @INC byla přidána cesta /home/instal/perl/lib. Pokusíme-li se nyní načíst nějaký modul, prvním místem, kde ho bude Perl hledat bude právě /home/instal/perl/lib. A navíc, pokud existuje adresář /home/instal/perl/lib/architektura/auto, bude přidán i ten. Bude mít dokonce ještě větší prioritu, protože moduly psané na míru pro konkrétní architekturu mají pochopitelně přednost před moduly obecnými. Názvem architektury je architektura vašeho stroje, tedy například i586-linux. Poznámka: Poměrně častým problémem při editaci @INC je přidávání adresáře, ve kterém je program. Nelze napsat pouze use lib '.';, protože když pak tento program spouštíme z jiného adresáře, '.' reprezentuje právě jej a nikoliv adresář, ve kterém je umístěn program. Nelze tedy zadat napevno '.'. Problém však vyřešíme odseparováním cesty z proměnné $0 a importem v bloku BEGIN.
BEGIN { Použitím klíčového slova no namísto use naopak adresář z @INC odstraníme. Ještě předtím, než je pole @INC změněno, je vytvořena jeho kopie @lib::ORIG_INC. Vždy tak můžeme získat původní @INC. Poznámka: Možná vás napadlo, že by cestu do pole @INC mělo jít přidat i obyčejným přidáním prvku na začátek tohoto pole. Proč to děláme tak složitě?
unshift(@INC, "/nova/cesta/k/modulum");
Tak jednoduché to bohužel není. Jak bude vysvětleno dále v tomto díle, import pomocí use se provádí už při kompilaci. Protože ale přiřazujeme cestu až za běhu, modul nalezen nebude. Řešením by teoreticky bylo použití příkazu require nebo uzavření příkazu unshift do bloku BEGIN. Ale proč to dělat, když zde máme pragmu lib... Jsou i jiné možnosti, jak dostat do @INC další adresář. Například volba -I při spouštění programu. Přepínač -I přijímá seznam, takže jej lze uvést i vícekrát.
$ perl -I/home/instal/perl/lib -I/media/sources/perl5.8.8/libs prog.pl
Cesty k modulům lze také uchovávat v proměnné prostředí PERL5LIB, případně PERLLIB. To je výhodné zejména tehdy, pokud potřebujeme nějakou cestu přidat dlouhodobě. Stačí jen umístit do konfiguračního souboru shellu řádek podobný následujícímu.
export PERL5LIB=/nova/cesta/k/modulum
Speciální blokyPerl rozpoznává takzvaný globální konstruktor modulu (blok BEGIN) a globální destruktor modulu (blok END). V podstatě to jsou zvláštní podprogramy s rezervovanými názvy. Lze je užít v libovolném perlovém programu. BEGINNe náhodou se bloku BEGIN říká konstruktor. Příkazy uvnitř něj jsou totiž určené k inicializaci. Kód, zapsaný uvnitř BEGIN se provede v okamžiku překladu. Typické je to pro import modulů. Snadno se o tom můžeme přesvědčit pokusem. Dále v tomto článku poznáme další funkci na zavedení souboru - funkci require. Ta importuje soubor až za běhu programu (tedy v době, kdy už je po překladu). Vytvořme si dva programy. V prvním z nich budeme funkci require volat v bloku BEGIN a v druhém mimo něj. Dále přeložme tyto dva programy pomocí příkazu perlcc (ten převede program pouze do binární spustitelné podoby - tedy přibližně to, co udělá gcc z programu v C). Teď jsou ve stavu, kdy skončil překlad, ale ještě nezačal běh. Znamená to, že soubor s require v bloku BEGIN by měl obsahovat vkládaný soubor a tudíž by měl být větší. ENDObsah bloku END se vykoná bezprostředně před ukončením běhu programu. Přitom vůbec nezáleží, zda byl program úspěšný. Tedy i v případě volání funkce die. Opět je zde název destruktor na místě.
print "Vystup programu\n"; Zajímavé je, že bloků jména BEGIN či END může být více v jediném souboru. Potom záleží na jejich pořadí. Bloky BEGIN jsou vykonávány od začátku souboru ke konci, bloky END naopak.
END { print "V bloku END 1\n" } Poslední zmíněné pravidlo je patrné z výstupu tohoto kódu.
$ perl bloky.pl Existují ještě další 2 speciální bloky s podobným významem. Jsou to CHECK a INIT. Tyto bloky slouží k zachycení fáze mezi překladem a během programu. Pořadí vykonávání jednotlivých částí programu je následující:
Zavedení moduluExistují všeho všudy 2 příkazy na zavedení externího souboru do programu. Jsou to use a require. Mnohé nám o nich napoví to, jaký k sobě mají vzájemně vztah. Zde jsou 3 způsoby, jakými můžeme use použít.
use Modul; Tyto zápisy lze přepsat tak, že nahradíme use za require. Předchozím ekvivalentní zápisy pak vypadají takto.
BEGIN { require Modul; import Modul; } Jak je ze zmíněných analogických příkazů patrné, require jsme umístili do bloku BEGIN, aby se vykonával už při překladu. Z toho nám krásně vyplynul hlavní rozdíl mezi use a require. Příkaz use zavádí modul už v době překladu. Oproti tomu require soubory importuje za běhu programu. Je-li parametrem zaváděcích příkazů slovo bez uvozovek, hledá se stejnojmenný soubor s příponou .pm, ve kterém jsou nahrazeny znaky :: za lomítko. Řetězec Math::BigFloat je podle tohoto pravidla převeden na soubor Math/BigFloat.pm. Ten je hledán v adresářích uvedených v poli @INC. Další možností je uvést parametr do uvozovek. Pak se v adresářích @INC hledá soubor, jehož název přesně bez úprav odpovídá tomuto řetězci. Parametrem příkazů use nebo require může být i číslo verze interpretu Perlu. Program je pak spuštěn jen v případě, že požadovaná verze je starší nebo stejná než aktuální verze interpretu. Jinak se zobrazí chybová zpráva.
Perl v6.0.0 required--this is only v5.8.6, stopped at require.pl line 1.
Procedura AUTOLOADPokud definujeme podprogram s názvem AUTOLOAD, spustí se tehdy, pokud voláme nedefinovanou proceduru. Název volané neexistující procedury je uvnitř podprogramu AUTOLOAD dostupný v proměnné $AUTOLOAD. Argumenty volané procedury jsou pomocí @_, tedy opět jako argumenty, předány do AUTOLOAD.
sub AUTOLOAD { Protože jsme žádný podprogram blabla nedefinovali, spustí se AUTOLOAD a výsledkem bude hláška Procedura main::blabla neexistuje!. Pro zajímavost uveďme bez dalšího komentáře použití AUTOLOAD s funkcí system. Ta nebyla dosud v seriálu popsána, ale její funkci lze z programu intuitivně vytušit.
sub AUTOLOAD { Příště se podíváme na archiv CPAN.
Related article
Perl (1) - Dávka teorie na úvod Perl (2) - Úvod do syntaxe Perl (3) - Proměnné Perl (4) - Čísla a řetězce Perl (5) - Podmínky Perl (6) - Pravdivostní výrazy Perl (7) - Vstup poprvé Perl (8) - Některé základní vestavěné funkce Perl (9) - Cykly Perl (10) - Další řídící struktury Perl (11) - Pole - úvod Perl (12) - Pole - základní operace Perl (13) - Hashe Perl (14) - Další nástroje pro seznamy Perl (15) - Výchozí proměnná, heredoc, symbolické odkazy Perl (16) - Regulární výrazy - začínáme Perl (17) - Regulární výrazy - kotvy Perl (18) - Regulární výrazy - množiny znaků Perl (19) - Regulární výrazy - opakování a kvantifikátory Perl (20) - Regulární výrazy - magické závorky Perl (21) - Regulární výrazy - nahrazování Perl (22) - Regulární výrazy - přepínače Perl (23) - Regulární výrazy - rozšířené vzory Perl (24) - Regulární výrazy - příklady Perl (25) - Regulární výrazy - závěr Perl (26) - Podprogramy Perl (27) - Prototypy Perl (28) - Rozsahy platnosti proměnných Perl (29) - Úvod k práci se soubory Perl (30) - Práce se soubory Perl (31) - Testování souborů Perl (32) - Jiné typy souborů Perl (33) - Formátování výstupu - printf Perl (34) - Formátování výstupu - formáty Perl (35) - Vestavěný debugger Perl (36) - Grafické debuggery Perl (37) - Začínáme s moduly Perl (38) - Rozhraní modulu Perl (39) - Pragma Perl (41) - CPAN Perl (42) - Argumenty příkazového řádku Perl (43) - Přepínače Perl (44) - Dlouhé přepínače Perl (45) - Odkazy Perl (46) - Užití odkazů a anonymní data Perl (47) - Složitější datové struktury Perl (48) - Libovolně složité datové struktury Perl (49) - Tabulky symbolů a typegloby Perl (50) - Uzávěry a iterátory Perl (51) - Signály Perl (52) - Externí příkazy Perl (53) - Režim nakažení Perl (54) - Fork Perl (55) - Eval Perl (56) - Volby příkazu perl Perl (57) - Jednořádkové skripty Perl (58) - OOP - úvod Perl (59) - OOP - typické použití Perl (60) - OOP - dědičnost Perl (61) - OOP - přínos a užití dědičnosti Perl (62) - OOP - přetěžování Perl (63) - OOP - závěr Perl (64) - Projekt - čtečka sportovních výsledků Perl (65) - Projekt - získání dat Perl (66) - Projekt - výběr zápasů a podrobnosti Perl (67) - Projekt - dokončujeme modul Perl (68) - Projekt - zobrazení zápasů Perl (69) - Projekt - online přenos Perl (70) - Plain Old Documentation Perl (71) - Navazování proměnných Perl (72) - Navazování složitějších datových typů Perl (73) - DBM Perl (74) - Sockety Perl (75) - Obsluha více klientů Perl (76) - Síťová hra v kostky Perl (77) - Služby internetu Perl (78) - Databáze - úvod Perl (79) - Databáze - manipulace s daty Perl (80) - Databáze - závěrečné poznámky Perl (81) - CGI - příprava webového serveru Perl (82) - CGI - první skripty Perl (83) - CGI - získávání dat od uživatele Perl (84) - CGI - usnadnění tvorby skriptů pomocí modulu CGI Perl (85) - CGI - generování dokumentu modulem CGI Perl (86) - CGI - cookies Perl (87) - CGI - příklad aplikace Perl (88) - CGI - závěr Perl (89) - Mason - snadné psaní webů Perl (90) - Mason - speciální bloky Perl (91) - Mason - handlery Perl (92) - Mason - závěr Perl (93) - Catalyst - MVC framework pro Perl Perl (94) - Catalyst - základy pro psaní aplikace Perl (95) - Catalyst - šablony Perl (96) - Catalyst - spolupráce s databází Perl (97) - Curses - tvorba textových uživatelských rozhraní Perl (98) - Curses - pozicování a okna Perl (99) - Curses - měření rychlosti psaní Perl (100) - Curses - použití hotových widgetů Perl (101) - Curses - jednoduchý textový editor Perl (102) - Rozšiřování Perlu pomocí XS Perl (103) - Rozšiřování Perlu pomocí SWIG Perl (104) - Testování rychlosti Perl (105) - Testování programových jednotek Perl (106) - Debugování pomocí komentářů Perl (107) - Moose - moderní objektový systém Perl (108) - Moose - základní vlastnosti Perl (109) - Moose - role Perl (110) - Moose - meta API Perl (111) - Pokročilá práce se seznamy Perl (112) - Práce s PDF Perl (113) - Práce s archivy Perl (114) - Tk - úvod Perl (115) - Tk - umísťování widgetů Perl (116) - Tk - základní widgety Perl (117) - Tk - některé pokročilejší widgety Perl (118) - Tk - čas a události Perl (119) - Tk - CD man Perl (120) - Wx - základní práce s widgety Perl (121) - Wx - události Perl (122) - Gtk2 - úvod Perl (123) - Gtk2 - základní práce s obrázky Perl (124) - Gtk2 - události a čas Perl (125) - Gtk2 - vlastní widgety Perl (126) - Gtk2 - textové okno a práce s pozicemi Perl (127) - Gtk2 - hierarchické seznamy Perl (128) - Gtk2 - dialogy Perl (129) - Gtk2 - skládání widgetů Perl (130) - Gtk2 - menu a toolbary Perl (131) - Gtk2 - transparentní okna, tray ikona, výběr souborů Perl (132) - Gtk2 - drag&drop, druid Perl (133) - Gtk2 - úpravy vzhledu aplikací pomocí rc Perl (134) - Gtk2 - Glade Interface Designer Perl (135) - XML - čtení a zápis Perl (136) - XML - DOM a SAX přístupy Perl (137) - Vlákna Perl (138) - Memoizace - cachování podprogramů Perl (139) - Profilling - efektivní odhalování pomalých míst v programu Perl (140) - Profilling - píšeme si vlastní profiler / debugger Perl (141) - Formátování kódu, deparsování, perltidy Perl (142) - Způsoby konfigurování Perl (143) - Struktura datových typů, správa paměti Perl (144) - POE - událostmi řízené programování Perl (145) - POE - aplikace typu klient-server Perl (146) - Perl 6 - jazyk budoucnosti Perl (147) - Perl 6 - regulární výrazy, nové operátory Perl (148) - Perl Culture Perl (149) - Závěr Pozvánka na Český Perl Workshop Perl 5.22.0 a vše okolo Perl 5.24.0 a vše okolo Previous Show category (serial) Next
|
Szukanie oprogramowania
|
|||||||||||||||||||||||||||||||||||||||||||||
©Pavel Kysilka - 2003-2024 | maillinuxsoft.cz | Design: www.megadesign.cz |