Organizace Open Container Initiative (OCI) (Wikipedie), projekt nadace Linux Foundation, vydala Runtime Specification 1.3 (pdf), tj. novou verzi specifikace kontejnerového běhového prostředí. Hlavní novinkou je podpora FreeBSD.
Nový open source router Turris Omnia NG je v prodeji. Aktuálně na Allegro, Alternetivo, Discomp, i4wifi a WiFiShop.
Na YouTube a nově také na VHSky byly zveřejněny sestříhané videozáznamy přednášek z letošního OpenAltu.
Jednou za rok otevírá společnost SUSE dveře svých kanceláří široké veřejnosti. Letos je pro vás otevře 26. listopadu v 16 hodin v pražském Karlíně. Vítáni jsou všichni, kdo se chtějí dozvědět více o práci vývojářů, prostředí ve kterém pracují a o místní firemní kultuře. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem inženýři v Praze pracují, jak spolupracují se zákazníky, partnery i studenty, proč mají rádi open source a co
… více »Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za říjen (YouTube).
Jeff Quast otestoval současné emulátory terminálu. Zaměřil se na podporu Unicode a výkon. Vítězným emulátorem terminálu je Ghostty.
Amazon bude poskytovat cloudové služby OpenAI. Cloudová divize Amazon Web Services (AWS) uzavřela s OpenAI víceletou smlouvu za 38 miliard USD (803,1 miliardy Kč), která poskytne majiteli chatovacího robota s umělou inteligencí (AI) ChatGPT přístup ke stovkám tisíc grafických procesů Nvidia. Ty bude moci využívat k trénování a provozování svých modelů AI. Firmy to oznámily v dnešní tiskové zprávě. Společnost OpenAI také nedávno
… více »Konference Prague PostgreSQL Developer Day 2026 (P2D2) se koná 27. a 28. ledna 2026. Konference je zaměřena na témata zajímavá pro uživatele a vývojáře. Příjem přednášek a workshopů je otevřen do 14. listopadu. Vítáme témata související s PostgreSQL či s databázemi obecně, a mohou být v češtině či angličtině.
Byl vydán Devuan 6 Excalibur. Přehled novinek v poznámkách k vydání. Kódové jméno Excalibur bylo vybráno podle planetky 9499 Excalibur. Devuan (Wikipedie) je fork Debianu bez systemd. Devuan 6 Excalibur vychází z Debianu 13 Trixie. Devuan 7 ponese kódové jméno Freia.
Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu poprvé překročil 3 %, aktuálně 3,05 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 27,18 %. Procesor AMD používá 67,10 % hráčů na Linuxu.
Někdy i užitečné výplody z mozku závislého linuxáka.
Po poměrně rychlém odchodu od PHP z důvodů, které by vydaly na další zápisek, jsem se rozhodl začít programovat perlím frameworku Catalyst. Jedním z prvních opravdových problémů, který jsem musel vyřešit, byla podpora češtiny, respektive kódování UTF-8. Ve defaultním stavu si o ní totiž můžete nechat jen zdát.
Hned po vygenerování nové aplikace funguje pouze jedna věc a tou je vypisování dat v UTF-8 z databáze. Kde však UTF-8 nefunguje jak má?
Mnoho stránek sice o tom, jak UTF-8 zprovoznit píše, ve výsledku jsou ale informace neúplné a musíte si je složit z více zdrojů, abyste dosáhli rozumného výsledku. Po asi dvouhodinovém boji jsem dosáhl kýženého výsledku a to aplikací následujícího:
use utf8 všude, kde se pracuje se stringy (obvykle controllery)lib/MyApp/View/HTML.pm vložit do volání metody config parametr ENCODING => 'UTF-8'lib/MyApp/Model/Database.pm vložit do parametru connection_info parametr pg_enable_utf8 => 1 (případně mysql_enable_utf8 ap.)lib/MyApp.pm přidat do use Catalyst qw/.../ modul Unicode__PACKAGE__->config(...) podle následujícího vzoru:
__PACKAGE__->config({
'Controller::HTML::FormFu' => {
constructor => {
tt_args => {
ENCODING => 'UTF-8',
},
},
},
'View:TT' => {
ENCODING => 'UTF-8',
},
});Po aplikaci těchto úprav byste se měli dočkat korektního zobrazení češtiny ze všech možných zdrojů.
Při psaní článku jsem využil Using Unicode in Catalyst Applications, HTML::FormFu Unicode manual a diskuse utf8 in mysql a Catalyst unicode woes.
Offtopic: kdybych tušil, že je možné vyvíjet webové aplikace tak snadno jako v Catalystu, opustil bych PHP už mnohem dříve. Pokud jste to ještě nezkusili, vřele doporučuji! Já osobně se učím na knížce od Johnatana Rockwaye s příznačným názvem Catalyst. Má sice dost chyb, pro mě, jako pro začátečníka, je však nejschůdnější. P.S.: Kniha přepokládá znalost Perlu a architektury Model-View-Controller.
Tiskni
Sdílej:
Množství modulů je bohužel někdy taky nevýhoda; člověk pak neví, který si má vybrat aby nezjistil, že bude za týden označen jako OBSOLETE...
Ja si navic upravoval ten Unicode plugin do Catalystu, protoze prevadi do unicode
pouze $c->request->params a uz ne "query_params" a "body_params"
Jinak si rikam zlaty PHP oproti Perlu, i kdyz jsem na PHP kdysi nadaval, ale narozdil od perlu aspon umi objekty, vyjimky apod. V perlu sice neco jako objecky, vyjimky taky jsou, ale bohuzel jen "jako".
Ani nemluve o tom, ze Catalyst ma obcas v oblibe nahlasit jen "Unknown error" pri syntakticke chybe, zadny cislo radku kde je chyba nic - proste peklo.
Kdybych nebyl donucen okolnostma, tak se Catalystu obloukem vyhnu a budu pouzivat RubyOnRails nebo nejaky Pythoni framework (Pylons, Django apod.) - (clovek si pak usetri spousta prace a casu) - se vsema uvdenyma mam zkusenosti, takze vim o cem mluvim.
Tomas
V perlu sice neco jako objecky, vyjimky taky jsou, ale bohuzel jen "jako".Nejen jako. Opět: pokud někdo nějakou věc nepoužívá ve svém frameworku, tak je úplně jedno, jaký to je jazyk.
jeste jsem napriklad nepotkal funkcni verzi neceho odpovidajici
try {} catch {} konstrukci z jinych jazyku - to je to cemu rikam vyjimky.
Error.pm? Syntaxe je v podstatě identická s jinými jazyky (kus kódu z jednoho mého projektu):
try {
# check whether the input is correct
if($startpoint eq $endpoint) {
throw RoutingException('same-startpoint-endpoint')
}
...
}
catch RoutingException with {
my $e = shift;
switch ($e->getMessage()) {
case 'same-startpoint-endpoint' { $g->setStatus($e->getMessage(), 'The startpoint and endpoint is identic.') }
...
}
};
Někde si udělám třídu, která bude dědit po Error::Simple a implementovat getMessage(). Toť vše; funkcionalita mi příjde stejná jako v jiných jazycích
otherwise, což je ekvivalent "catch všechno ostatní" na závěr výpisu. A samozřejmě finally.
Výhodou tohoto "jako-přístupu" je, že Perl Vám na rozdíl od jiných jazyků nenutí jeden jediný typ výjimek. Pokud chcete výjimky jednoduché do jednoduchého programu, použijete obyčejné die a eval, pokud chcete nejlepší a nejnovější všeumějící, použijete nějaký tlustý modul na takové výjimky, pokud chcete makové výjimky tak si uděláte jednoduše svou vlastní konstrukci mák { ... } nudle { ... } buchty { ... };. Podobně je to s objekty samotnými a dalšími aspekty.
Jinak u tohoto příkladu bych se na getMessage vykašlal, a rovnou udělal další podtřídy, pak nemusíte porovnávat řetězce. A náhradou switch je ve verzi 5.10 zabudovaný given...when.
$dispatch_map = {
AAA => sub { ... },
BBB => sub { ... },
'*' => sub { ... },
};
eval { ... };
if ($@) {
my $key = ref $@ || $@;
$key = '*' unless exists $dispatch_map ->{$key};
die $@ unless exists $dispatch_map ->{$key};
$dispatch_map ->{$key} ->($@);
}
Prave ze modul Error a podobne nefunguji.
zkuste si:
use Error qw(:try);
sub a {
try {
return 1;
}
catch Error with {
return 3;
}
otherwise {
return 4;
}
finally {
return 5;
};
return 0;
}
print a(),"\n";
-- tohle vrati "0" - presto ze by se to k "return 0" vubec nemelo logicky dostat.
v ostatnich jazycich je return navrat z funkce, kdezto v perlu bude return navrat z bloku pro obsluhu vyjimky, a pokud v blocich try/catch nemuzu pouzit return, tak me to prave dost omezuje, protoze to prave nefunguje, tak jako v onstatnich jazycich, kde je to podporovano nativne.
sub a {
try {
RETURN 1;
}
catch Error with {
RETURN 3;
}
otherwise {
RETURN 4;
}
finally {
RETURN 5;
};
return 0;
}
print a(),"\n";
1) vim co dela return i eval, preci jen uz perl par let pouzivam.
2) nelibi se mi, ze mi tu nekdo nadava do blbcu, namisto aby poradil, pokud skutecne existuje nejake reseni. Holt nadavat umi kazdy blbec, poradi uz malokdo, abych tak pouzil Vase vyrazy.
3) Do dokumentace jsem samozrejme koukal mnohokrat, zhavil jsem google, ale bez uspechu.
4) uvedeny kod mi neprijde moc funkcni, a "RETURN" velkymi pismeny jsem teda jeste nepotkal, ani nevim kde bych to nasel v dokumentaci.
perl -e 'use Error qw(:try); sub a { try { RETURN 1; } catch Error with { RETURN 3; } otherwise { RETURN 4; } finally { RETURN 5; }; return 0; }'
syntax error at -e line 1, near "RETURN 1"
syntax error at -e line 1, near "RETURN 3"
syntax error at -e line 1, near "RETURN 4"
syntax error at -e line 1, near "RETURN 5"
ad 2) Mne se zase nelibi, pokud nekdo neopravnene kritizuje neco jen proto, ze tomu nerozumi.
ad 4) Ten kod mi take neprijde funkcni, protoze RETURN je v baliku Error::Return, ktery tam nenatahujete.
ad 2) to byla jen reakce na toho "blbce";), omlouvam se
Jinaj jsem (zatim) presvedcen, ze rozumim tomu jak funguje "return", "eval", modul Error i Error::Return (o kterem jsem doted netusil) a dalsi pouzite konstrukce
Ale vratim se uvedemu kodu a k tomu, ze se nechova jako vyjimky v jinych jazycich:
perl -e 'use Error qw(:try); use Error::Return; use Error::Return; sub a { try { RETURN 1; } catch Error with { RETURN 3; } otherwise { RETURN 4; } finally { RETURN 5; }; return 0; } print a,"\n"'
vrati 1, ale mel by vratit 5, protoze posledni co by mel provest je blok "finally".
Urcite? Todle mi prijde uz celkem dost zavisle na jazyku (provedlo by se to treba pri volani execve()?), nicmene ani to by nemel byt problem - podivejte se na kod Error/Return.pm - je to asi 5 radku, takze vynutit si chovani, na jake jste zvykly by nemel byt problem. Jinak ja osobne jsem rad, ze se perl nechova jako jine jazyky, takhle je totiz mnohem ohebnejsi.
smysl try {} finally {} je prave v tom, ze blok finally je volan vzdy.
Jako clovek, ktery pouzival nejakou dobu python, jsem vyjimky zvykly pouzivat, takze hledam obdobu v perlu, samozrejme, ze si muzu upravit tohle chovani, ale je to o tom, ze si to musim napsat narozdil od jinych jazyku kde je to jejich soucast.
Perl ma samozrejme jine vyhody oproti ostatnim jazykum, ale ma taky bohuzel svoje nevyhody.
Dostávate sa do konfliktu medzi "return" a "finally". Chcem vás vidieť, ako debugujete, keď aj try, aj finally budú obsahovať nejakú šialenú logiku a finally bude meniť návratovú hodnotu ...
chovanie, ako spomínate, by malo zmysel pri takejto konštrukcii:
sub aaa {
...
} finally {
return 5;
}
finally blok proste slouzi ke "cleanup kodu", aby se tento kod nemusel opisovat vsude, ale aby mel clovek jistotu ze bude proveden.
create_tmp_files();
try {
nejaky_kod....
return 0;
}
catch ..... with {
obsluha vsech moznych chyb
return 1;
}
finally {
delete_temporary_files();
}
-- cleanup kod "delete_temporary_files" je volan pouze na jedinem miste a mel by byt zavolan za kazdych okolnosti.
ale jestli nechapete k cemu slouzi try {} finally {} tak je to pak tezky
while () {
} continue {
}
Jaky konflikt?
blok finally se ma zavolat pri returnu, continue, beaku apod. Jaky by pak mel blok finally smysl? to je prave duvod proc se pouziva, abys mel jistotu, ze se dany clean-up kod skutecne provede.
Je to podobne jako destruktor u objektu, taky se vola pri returnu, breaku, continue a obecne opusteni daneho bloku platnosti objektu.
Nicmene ty vyjimky v pythonu se taky chovaji dost podivne, napriklad v pripade nize, se treba finally vubec neprovede. To radsi jednodusse zapamatovatelne perlovske "kdyz vyskocim z funkce finally se nevola" nez si pro kazdou funkci opoustejici funkci zjistovat, zda finally zavola.
import os
try:
raise
except:
print "except"
os.execv('/bin/date', ['date'])
else:
print "Else"
finally:
print "finaly"
Jako clovek, ktery pouzival nejakou dobu python, jsem vyjimky zvykly pouzivatVy jste zvyklý je využívat v pythonu, ale uvědomte si, že python není pupek světa, nesežral všechnu moudrost, atp. zkrátka, že výjimky jsou trochu širší téma. Pokud hledáte v perlu python, tak jste na tom podobně, jak ti co hledají v linuxu windows. Budete furt jen remcat, že to "není dost dobrý". A z věcného hlediska je dosti diskutabilní, jestli když dám do catch bloku return, jestli se má volat blok finally nebo nemá. Co by ten return měl podle Vás jiného dělat než skončit _funkci_ (uvědomte si, že ve funkci může být try-catch bloků několik a navíc vnořených)? Ukončit blok catch, a přejít do bloku finally, nedejbože s tím, že návratovou hodnotu zahodí?? Pěkně děkuji za takovou "logiku". Tomu bych se širokým obloukem vyhnul, protože nechci způsobovat migrénu těm co to po mně budou číst. A ještě k tomu navíc nechápu, proč bych měl, když už používám výjimky, vracet nějaké náhodné návratové hodnoty typu 1, 10, 5, -4... funkce má vrátit výsledek nějakého výpočtu, a pokud v ní nastane výjimka, tak návratová hodnota má jít do kytek a má se řešit ta výjimka.
1) Uvedomuji si ze python neni pupek sveta, ale to perl taky ne.
2) "return" ve finally bloku je logicky nesmysl, ja tim pouze naznacoval, ze block "finally" neni vubec zavolan.
3) smysl finally bloku je prave spusteni "clean-up" kodu pri jakemkoliv opusteni bloku try/catch - tozn. i "return", jaky by pak mel blok finally smysl?
Prijde mi to jako samozrejme chovani - java a ostatni jazyky to maji take tak:
http://java.sun.com/docs/books/tutorial/essential/exceptions/finally.html
.
Jazyky Ruby ani Python mě nijak zvlášť neoslovily.
Ja myslis,
Me osobne se libi kazdy z techto jazyku - perl, python, ruby - kazdy pro neco jinyho
Ale nejvic me zaujako ruby, protoze to je vlastne kombinace perlu, pythonu a smalltalku,
a myslim, ze to dobre zkombinovali. Navic v kombinaci s kvalitou frameworku rubyOnRails je to muj favorit;)
Python a ruby jsou vcelku srovnatelny, a protoze jsou znacne mladsi jazyky nez perl, tak maji krome objektu a vyjimek
ale taky nativni podporu generatoru, iteratoru, decoratoru a dalsich vymozenosti primo v syntaxi jazyka, takze ten kod je rychleji napsany a prehlednejsi.
srovnatelny s nimi bude perl6, ktery je kompletne prepsany, ale to je zatim budoucnost (a otazka jak to bude s kompatibilitou).
čekal jsem něco jiného: viz. webarchiv :-|
rad bych se zeptal na nekolik veci ohledne Catalystu. (jako deleslouzici perlista mam k nejakym takovym nastrojum blize nez k php, python, java)
1. cetl jsem, ze je mozno pouzivat interni http-server catalystu a nebo ze to jede i pres apache. Co pouzivate, muzete doporucit? Me by bylo milejsi, kdybych mohl pouzit ten vestaveny http server.
2. jak je to s databezemi, vyuziva to sqlite a i mysql a pgsql. Mate s tim zkusenosti. Kterou pouzivate. Je mozno sahat na nejaka data i mimo databazi - napr. informace uschovane v nejakych ascii-souborech
3. Jaka je zatez servru? Perl tihne obcas k tomu zatizit cpu - bezi to pekne rychle ale kdyz bezi na servru jeste neco jineho, tak je to znat. Muzete to potvrdit? (psal jste, ze jste drive pracoval v php oblasti) takze to muzete event. srovnat.
4. Na odpovidajicich strankach catalystu pisou i o podpore ajaxu. Mate s tim nejake zkusenosti.
K Ajaxu jsem se zatím nedostal, v knize je ale popsán, tak se jím budu jistě brzo zabývat. Nějaká podpora každopádně existuje.
Interní server je opravdu příjemná feature, zvlášť pro debugging. Vestavěný server lze použít i v produkčním prostředí -- drobná nevýhoda je však, že je jednovláknový, tudíž je třeba jich mít puštěných víc na různých portech a dělat load ballancing. Nedoporučuje se používat přímo CGI, to spíše už mod_perl v Apachi. Podporované databáze jsou minimálně sqlite, mysql, postgres, oracle a myslím ještě DB2 od IBM. Osobně používám postgres, je to však o zvyku a možnostech na serveru.
Data z plaintextových souborů se dají číst stejně jako z databáze, jen je třeba napsat si na to vlastní Model.