Evropská komise naléhavě vyzvala členské státy EU, aby kvůli ochraně nezletilých na internetu urychlily zavádění unijní aplikace pro ověřování věku a zajistily její dostupnost do konce roku. Členské státy mohou zavést aplikaci EU pro ověřování věku jako samostatnou aplikaci nebo ji integrovat do takzvané evropské peněženky digitální identity.
Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.
Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.
Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.
Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.
Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.
Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.
Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.
Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.
VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.
Tak jsem uvnitř podmínky grepu potřeboval vyhodnotit nějakou složitější věc a měl jsem možnost napsat to jako annonymní sub a nebo do. Položil jsem si otázku co bude rychlejší?
Vnitřek podmínky grepu vypadal nějak podobně takhle:
my $attr = $_;
my $successors = $successors{$attr};
$successors
and do {
my $res;
$res = exists $successors->{$_} and last
foreach (predecessors($attr));
!$res
}
my $attr = $_;
my $successors = $successors{$attr};
$successors
and sub {
exists $successors->{$_} && return 0
foreach predecessors($attr);
1
}->()
Výsledný kód jsem trošku benchmarkoval a verze se sub je až o 50% pomalejší (samozřejmě v závislosti na okolní režiji). Ale proč? Odpověď je celkem jednoduchá, annonymní subrutina se pokaždé znovu skompiluje. (Trošku zjednodušuji, ona se ve skutečnosti jednou předkompiluje a pak se jí mění syntaktický kontext, ale ve výsledku je pro každé zavolání vnitřní smyčky vytvořená nová subrutina. Kdybych si ji někam ukládal tak bude pokaždé na jiné adrese, atd.) Dá se tomu nějak zabránit? Jistě, vytvořit immutable annonymní subrutinu a Perl je tak chytrý, že ji skompiluje jen jednou.
my $attr = $_;
my $successors = $successors{$attr};
$successors
and sub {
exists $_[0]->{$_} && return 0
foreach predecessors($_[1]);
1
}->($successors, $attr)
Takový kód je pak prakticky stejně rychlý jako do. Co je na tom zajímavého? Snad jen to, že do v perlu se tak hezky chová, skompiluje se jen jednou i když obsahuje proměnné v syntaktickém kontextu a je tedy rychlejší než použití annonymního sub.
Pokud si chcete taky pohrát, tak zde je text kompletního benchmarku:
#!/usr/bin/env perl
use strict;
use Benchmark qw(:all :hireswallclock);
my $count = 100;
my %successors = map +($_, {$_ => undef}), 1..$count;
sub predecessors {($_[0]-1) .. ($_[0]+1)}
sub none (&@) {
&{$_[0]} && return 0 foreach @_[1..$#_];
1
}
cmpthese(-2, {
'do' => sub {
do {my $attr = $_;
my $successors = $successors{$attr};
do {
my $res;
foreach (predecessors($attr)) {
$res = exists $successors->{$_} and last
}
!$res
}
} foreach 1 .. $count;
},
'sub' => sub {
do {my $attr = $_;
my $successors = $successors{$attr};
sub {
exists $successors->{$_} && return 0
foreach predecessors($attr);
1
}->()
} foreach 1 .. $count;
},
'subimmu' => sub {
do {my $attr = $_;
my $successors = $successors{$attr};
sub {
exists $_[0]->{$_} && return 0
foreach predecessors($_[1]);
1
}->($successors, $attr)
} foreach 1 .. $count;
},
'none' => sub {
do {
my $successors = $successors{$_};
none {$successors->{$_}} predecessors($_);
} foreach 1 .. $count;
},
'evalblock' => sub {
do {my $attr = $_;
my $successors = $successors{$attr};
eval {
my $res;
foreach (predecessors($attr)) {
$res = exists $successors->{$_} and last
}
!$res
}
} foreach 1 .. $count;
},
'evalstr' => sub {
do {my $attr = $_;
my $successors = $successors{$attr};
eval '
my $res;
foreach (predecessors($attr)) {
$res = exists $successors->{$_} and last
}
!$res
'
} foreach 1 .. $count;
},
});
Pro zajímavost jsou doplněny ještě další varianty. Není překvapením, že blokové použití evalu je stejně rychlé jako do nebo immutable sub. Trochu jsem byl zklamán rychlostí při použití krásné elegantní šablonované funkce none. Tam se vlastně stejně jako při normálním annonymním sub pokaždé znovu skompiluje první parametr a jestě ke všemu se tato subrutina volá uvnitř foreach, takže to ve výsledku dopadne hůř. No a nejhorší je eval stringu, nic divného, že 
P.S.: Nakonec jsem se do úplně vyhnul a použil jednu z vlastností if, že vrací hodnotu podmínky. No co, aspoň jsem nahlédl do chování perlu zase o kousek hloub. Ekvivalent shora uvedených kódů pak nakonec vypadá asi takhle:
if (my $successors = $successors{$_}){
my $res;
$res = exists $successors->{$_} and last
foreach (predecessors($_));
!$res
}Ano, to je celý vnitřek podmínky grepu, ušetřím ještě jednu alokaci proměnné, což je podle mých měření dokonce víc než zavolání sub
Tiskni
Sdílej:
do nerobí to isté, čo sub. Ako píšu v dokumentácií, Not really a function..
do jednoducho vyhodnotí blok.
sub vytvorí anonymnú funkciu, ktorej kopíruje kontext (pre ostatných, google: perl closures)