Cloudflare, tj. společnost poskytující "cloudové služby, které zajišťují bezpečnost, výkon a spolehlivost internetových aplikací", má výpadek.
Letos se uskuteční již 11. ročník soutěže v programování Kasiopea. Tato soutěž, (primárně) pro středoškoláky, nabízí skvělou příležitost procvičit logické myšlení a dozvědět se něco nového ze světa algoritmů – a to nejen pro zkušené programátory, ale i pro úplné začátečníky. Domácí kolo proběhne online od 22. 11. do 7. 12. 2025 a skládá se z 9 zajímavých úloh různé obtížnosti. Na výběru programovacího jazyka přitom nezáleží – úlohy jsou
… více »Byla vydána nová verze 2.52.0 distribuovaného systému správy verzí Git. Přispělo 94 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.
VKD3D-Proton byl vydán ve verzi 3.0. Jedná se fork knihovny vkd3d z projektu Wine pro Proton. Knihovna slouží pro překlad volání Direct3D 12 na Vulkan. V přehledu novinek je vypíchnuta podpora AMD FSR 4 (AMD FidelityFX Super Resolution 4).
Poštovní klient Thunderbird byl vydán v nové verzi 145.0. Podporuje DNS přes HTTPS nebo Microsoft Exchange skrze Exchange Web Services. Ukončena byla podpora 32bitového Thunderbirdu pro Linux.
U příležitosti státního svátku 17. listopadu probíhá na Steamu i GOG.com již šestý ročník Czech & Slovak Games Week aneb týdenní oslava a také slevová akce českých a slovenských počítačových her.
Byla vydána nová verze 9.19 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze například nový balíček BirdNET-Go, tj. AI řešení pro nepřetržité monitorování a identifikaci ptáků.
Byla vydána nová verze 3.38 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.10 souvisejícího programovacího jazyka Dart (Wikipedie).
Organizace Apache Software Foundation (ASF) vydala verzi 28 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Byl vydán Debian 13.2, tj. druhá opravná verze Debianu 13 s kódovým názvem Trixie. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.
Většinou prograuju v Perlu, ale zároveň po očku sleduju Python. Můj pocit z něj se vyvýjí v takových vlnách, chvilku se mi líbí hodně, chvilku méně a tak pořád dokola. Některé věci se mi v něm líbí, ale poslední dobou je pocit spíše rozpačitý. Jeho syntaxe je, jak bych to jen řekl, příliš košatá. Ony se dělají vtípky na to, že Perlový zdroják je před komprimací k nerozeznání od stavu po komprimaci. Hloupej vtípek, ale syntaxe Perlu je vlastně strašně jednoduchá až primitivní, to se ale o Pythonu nedá říct ani omylem. Už jen těch klíčových slov! I když ke klíčovým slovům Perlu přihodím všechny ty podivné znaky se speciálním významem, tak to nebudu ani na desetině syntaktických prvků Pythonu. Jo, já vím, Lisp je Lisp, ale Perl má taky něco do sebe. (No a radši nebudu ani zmiňovat dc, že) A proč to všechno píšu?
Dnes ráno se mi nějak nechtělo spát at tak jsem sedl k počítači a z nudy jsem si jen tak programoval. V manuálu perlsub je taková malá ukázka, jak si vytvořit syntaktický cukr ala Python try/except. Cybí tam to finally a tak jsem si to tam dodělal. A tím jsme se vrátili k tomu úvodu. V Pythonu na to musíte mít tři klíčová slova, v Perlu si to naprogramujete.
Takže text modulu TryExceptionFinally.pm
package TryExceptFinally;
use strict;
use warnings;
use Exporter qw(import);
use Scalar::Util qw(reftype);
our @EXPORT = qw(try except finally);
sub try (&@) {
my ($try, %subs) = @_;
eval { &$try };
no warnings 'uninitialized';
if ($@ and reftype $subs{except} eq 'CODE') {
local $_ = $@;
&{$subs{except}};
}
&{$subs{finally}} if reftype $subs{finally} eq 'CODE';
}
sub except (&@) { 'except', @_ }
sub finally (&) { 'finally', @_ }
1;a ukázkový kód
#!/usr/bin/env perl
use strict;
use warnings;
use TryExceptFinally;
try {
die "hard";
} except {
print "Ouch, I was die $_"
} finally {
print "Finally!\n"
};
try {
print "Live\n";
} except {
print "Ouch, I was die $_"
} finally {
print "Finally!\n"
};
try {
print "Live\n";
} finally {
print "Finally without except!\n"
};
try {
die "hard";
} finally {
print "Finally without except!\n"
};
try {
die "hard";
} except {
print "Ouch, I was die $_ and no finally!\n"
};No a jednotlivé typy vyjímek místo několika bloků exception, se zabalí do jednoho, třeba takto
try {
code
} except {
/type1/ && do {
code
1 } ||
/type2/ && do {
code
1 } ||
/type3/ && do {
code
1 } ||
do { # else
code
}
}
Tiskni
Sdílej:
Takže se těším na příklad, jak zachytit třeba přerušení programy z klávesnice, nebo jak v Perlu ošetřit pomocí výjimek chyba v syntaxi natahovaného modulu.
Takže šup šup do práce, ještě tohle zbývá na rovocennost s Pythonem.
P.S.: Jinak ale klobouk dolů, tohle kouzlo s Perlem se mi líbí, i když Perl kritizuju, kde můžu. Mám rád jazyky, kde základní věci jsou v syntaxi jazyka a ne emulovány něčím jiným.

$SIG{INT} = sub { throw "Uplne zbytocna vynimka"; };
eval {require module && module->import(use_params)}
if ($@) {
$@ =~ /syntax error/ and print "syntx error in module\n"
or print "somethink error when try use module: $@"
}a pythonish way užívající to hezké try/excepttry {
require module && module->import(use_params)
} except {
/syntax error/ and print "syntx error in module \n"
or print "somethink error when try use module: $@"
}Pokud chceš aby to fungovalo stejně jako běžné use, tak to ještě zavřeš do BEGIN bloku. No a exception jako objekt máme taky, takže si ve svých modulech/třídách nadefinuješ vlastní hierarchii a je vymalováno, prakticky nic co jde udělat v pythonu není problém udělat perlu, něco jde elegantněji něco naopak. Třeba generátory se v perlu nepíšou tak jednoduše jak pythonu pomocí yeld, ale na druhou stranu v pythonu máš jen jeden typ objektů, který je ekvivalentem blessnutého hashe v perlu. V podstatě všechny objekty, třídy, jmenné prostory, funkce, ... jsou v pythonu objekty typu blessnutý hash (pythonní dict), to je trochu chudé, ne? Just joking, na druhou z toho plynou pythonu některé výhody, to nesporně
Třeba mi přijde, že python má potenciál být rychlejší, než perl. Skutečnost je taková jaká je.
Jinak to zachycování výjimek pomocí signálů (chápu to správně, že jsou to signály?) má tu nevýhodu, že je nedostane thread, kterého se to týká, nebo ano? V případě klávesnice to asi nevadí.Vzhledm k tomu, že je to signál zaslaný procesu (zaslaný terminálem), nevím, jak by jste to chtěl udělat jinak. I v pythonu keyboard interupt musí fungovat stejně. V perlu asi nějak takto:
eval {
local $SIG{INT} = sub { die "Keyboard interupt"; };
code
};
if ($@) {
$@ =~ /Keyboard interupt/ and print "Don't disrupt me!\n"
or die $@
}A to samozřejmě je thread safe, i když netuším podle čeho se určí, jestli ten signál zpracuje ten který thread.Jinak dokážou ty výjimky taky to co python, to znamená mít v sobě informaci o call stacku, tedy o řádcích programu, kde chyba nastala, a o všech podprogramech ze kterého se tento řádek volal?Ano, jestliže si tam tu informaci přidáte. Standardní výjimky jsou textové, protože jsou tam od doby, kdy ještě ani perl nebyl objektový. Vlastní výjimky si člověk může udělat objektové a call stack si tam doplnit. Standardní textová výjimka nekončící na EOL je vždy doplněna o informaci, kde k ní došlo. Není problém (až na určité spomalení) si nad každou funkcí udělat eval wrapper a všechny výjimky odchytávat, měnit na objektové a doplňovat o call stack. V pythonu to už udělali za vás. V tomhle je python lepší, o tom žádná. Možná je na to v perlu už udělaný nějaký modul, nebo nějaká vlastnost, která jde zapnout, zatím jsem po tom nepátral.
python je postaven na jmenných prostorech, stejně tak jako každý dynamický jazyk, ať už vezmu php, smalltalk, nebo třeba objective c.a nebo třeba perl, to je přece jasné. A je taky celkem logické, že to v těch jazycích implementovali pomocí prostředků toho samého jazyka. Proč se s tím implementovat dvakrát, že. Takže v perlu jsou jmenné prostory hash a v pythonu objekt a ten je v podstatě dict. Mimochodem, perlový
local. To jde udělat i v pythonu, ale zdaleka to nejde tak jednoduše pomocí jednoho klíčového slova jako v perlu. Jak říkám, každý jazyk je v něčem lepší a v něčem horší.
Informácie o kontexte: miesto die používať Carp::confess.
Samotný die umožňuje aj iný parameter ako scalar
die new XYZ::Exception;Ono, aj catch sa dá implmentovať štýlom
try {}
catch qr/aaa/ => {}
catch 'AAA::Exception' => {}
...
Btw, keď spomínate local, také jeho použitie na "dočasné" prekrytie ľubovoľnej funkcie môže byť zaujímavé 
Od včera mi bohužiaľ panikári kernel, takže len naznačím rozpracovanú myšlienku:
sub try (&;@) {
my (my ($try, %subs) = @_;
return new Exception::Block ($try, \ %subs) if defined wantarray;
...
}
# priklad použitia
my $block = try { ... } catch A => { ... } catch qr/B) => { ... };
$block->('www.abclinuxu.cz');
$block->('www.example.com');
$block->catch (A => sub { ... })->('...');
ono, programovať multithreadovo treba vedieť, osobne si myslím, že 9 z 10tich ľudí živiacich sa programovaním to neovláda. Takisto výnimky, tiež ich treba ovládať.Tak to ani zdaleka není to o čem jsem mluvil.Informácie o kontexte: miesto
diepoužívaťCarp::confess.
Carp::confess produkuje textový výstup, který by se pro další zpracování musel parsovat a to je vždy nespolehlivé. Také to neřeší systémové výjimky generované přímo perlem. V těch die nahradíte celkem těžko. To první jde samozřejmě nahradit vhodnými objektovými výjimkami, které si call back naplní do své vnitřní struktury pomocí caller a mohou být dále strojově zpracovány. To druhé je trochu jiné kafe a žádný elegantní způsob mě nenapadá.SamotnýNějak mi uniká k čemu by to jako mělo být dobré.dieumožňuje aj iný parameter ako scalardie new XYZ::Exception;Ono, aj catch sa dá implmentovať štýlomtry {} catch qr/aaa/ => {} catch 'AAA::Exception' => {} ...Btw, keď spomínatelocal, také jeho použitie na "dočasné" prekrytie ľubovoľnej funkcie môže byť zaujímavéOd včera mi bohužiaľ panikári kernel, takže len naznačím rozpracovanú myšlienku:
sub try (&;@) { my (my ($try, %subs) = @_; return new Exception::Block ($try, \ %subs) if defined wantarray; ... } # priklad použitia my $block = try { ... } catch A => { ... } catch qr/B) => { ... }; $block->('www.abclinuxu.cz'); $block->('www.example.com'); $block->catch (A => sub { ... })->('...');
Nějak mi uniká k čemu by to jako mělo být dobré.Napr situácia, keď funkcia/metóda štandardne ošetruje niektoré/všetky výnimky, správne pre 90% použití. Zvyšných 10% definuje svoje vlastné ošetrenia.
with. To taky není žádný velký problém a dělalo by to přibližně tohle. Pak my přijde jako čistější vytvořit potomka příslušného objektu.