Design (GitHub) je 2D CAD pro GNOME. Instalovat lze i z Flathubu. Běží také ve webovém prohlížeči.
Příspěvek na blogu herního enginu Godot představuje aplikaci Xogot přinášející Godot na iPad a iPhone. Instalovat lze z App Storu. Za Xogotem stojí Miguel de Icaza (GitHub) a společnost Xibbon.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za březen (YouTube).
ESP-IDF (Espressif IoT Development Framework), tj. oficiální vývojový framework pro vývoj aplikací na mikrokontrolérech řady ESP32, byl vydán v nové verzi 6.0. Detaily na portálu pro vývojáře.
DeepMind (Alphabet) představila novou verzi svého multimodálního modelu, Gemma 4. Modely jsou volně k dispozici (Ollama, Hugging Face a další) ve velikostech 5-31 miliard parametrů, s kontextovým oknem 128k až 256k a v dense i MoE variantách. Modely zvládají text, obrázky a u menších verzí i audio. Modely jsou optimalizované pro běh na desktopových GPU i mobilních zařízeních, váhy všech těchto modelů jsou uvolněny pod licencí Apache 2.0. Návod na spuštění je už i na Unsloth.
Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 3. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).
Průkopnická firma FingerWorks kolem roku 2000 vyvinula vícedotykové trackpady s gesty a klávesnice jako TouchStream LP. V roce 2005 ji koupil Apple, výrobu těchto produktů ukončil a dotykové technologie využil při vývoji iPhone. Multiplatformní projekt Apple Magic TouchstreamLP nyní implementuje funkcionalitu TouchStream LP na současném Apple Magic Trackpad, resp. jejich dvojici. Diskuze k vydání probíhá na Redditu.
Byla vydána nová verze 10.3 sady aplikací pro SSH komunikaci OpenSSH. Přináší řadu bezpečnostních oprav, vylepšení funkcí a oprav chyb.
Cloudflare představil open source redakční systém EmDash. Jedná se o moderní náhradu WordPressu, která řeší bezpečnost pluginů. Administrátorské rozhraní lze vyzkoušet na EmDash Playground.
Bratislava OpenCamp 2026 zverejnil program a spustil registráciu. Štvrtý ročník komunitnej konferencie o otvorených technológiách prinesie 19 prednášok na rôzne technologické témy. Konferencia sa uskutoční v sobotu 25. apríla 2026 v priestoroch FIIT STU v Bratislave.
Mám plain text:
[Date.UTC(2014, 11, 23, 5, 12, 0, 0), 3],
[Date.UTC(2014, 11, 23, 5, 14, 0, 0), 3],
[Date.UTC(2014, 11, 23, 5, 16, 0, 0), 2],
[Date.UTC(2014, 11, 23, 5, 18, 0, 0), 2],
[Date.UTC(2014, 11, 23, 5, 20, 0, 0), 2],
[Date.UTC(2014, 11, 23, 5, 22, 0, 0), 2],
[Date.UTC(2014, 11, 23, 5, 24, 0, 0), 2],
[Date.UTC(2014, 11, 23, 5, 26, 0, 0), 2],
[Date.UTC(2014, 11, 23, 5, 28, 0, 0), 1],
[Date.UTC(2014, 11, 23, 5, 30, 0, 0), 1],
[Date.UTC(2014, 11, 23, 5, 32, 0, 0), 1],
[Date.UTC(2014, 11, 23, 5, 34, 0, 0), 1],
[Date.UTC(2014, 11, 23, 5, 36, 0, 0), 1],
[Date.UTC(2014, 11, 23, 5, 38, 0, 0), 1],
[Date.UTC(2014, 11, 23, 5, 40, 0, 0), 0],
A potřeboval bych odstranit řádky výše zvýrazněné kurzívou, aby to vypadalo takto:
[Date.UTC(2014, 11, 23, 5, 12, 0, 0), 3],
[Date.UTC(2014, 11, 23, 5, 14, 0, 0), 3],
[Date.UTC(2014, 11, 23, 5, 16, 0, 0), 2],
[Date.UTC(2014, 11, 23, 5, 26, 0, 0), 2],
[Date.UTC(2014, 11, 23, 5, 28, 0, 0), 1],
[Date.UTC(2014, 11, 23, 5, 38, 0, 0), 1],
[Date.UTC(2014, 11, 23, 5, 40, 0, 0), 0],
Konkrétně potřebuji porovnávat poslední číselný údaj a v případě souvislého opakování ponechat pouze první a poslední záznam.
Dá se to relativně jednoduše zvládnout pomocí sed či awk? Pokud ne, asi bych to řešil mechanicky v bashi (načítání řádků, porovnávání hodnoty, vymazání nadbytečného řádku a pořád dokola, dokud bude co mazat).
Řešení dotazu:
cat soubor | sort -k8 -u -r >soubor1 tac soubor | sort -k8 -u -r >soubor2 #paste -d '\n' soubor1 soubor2 >vysledek paste -d '\n' soubor1 soubor2 | uniq >vysledek
On ten plain text má stovky kB a číselný údaj v posl. sloupci se pohybuje mezi 0 - 5, střídavě nahoru a dolu. "unique" to pročistí tak důkladně, že z těch stovek kB zbude pár řádků.
perl -00 -pe 's/(\N* (\d+)\],\n).*\n(\N* \2\],\n)/$1$3/msg'
perl -ne ' /(\d+)\],/; print $pred_radek if $1!=$pred or $pred2!=$pred; $pred2=$pred; $pred=$1; $pred_radek=$_'vytiskni řádek jestli se předešlý nebo následující řádek liší v čísle před
],
Ps. samozřejmě by bylo přehlednější napsat Perl script než tento "one-liner"
perl -ne ' /(\d+)\],/; print if 1..1; print $pred_radek if $1!=$pred or $pred2!=$pred; $pred2=$pred; $pred=$1; $pred_radek=$_'
0], jinak ho to tiskne, tak bych spíš doporučoval něco jako:
perl -ne 'BEGIN{$pred=-1}; /(\d+)\],/; print $pred_radek if $1!=$pred or $pred2!=$pred; $pred2=$pred; $pred=$1;$pred_radek=$_'
#
problém by ještě nastal kdyby "poslední" řádek nekončil \n, pak by se nevytiskl
sed -re 'H;x;/([0-9]+)\].*\1\]/d'
[Date.UTC(2014, 11, 25, 10, 36, 36, 0), 1],
[Date.UTC(2014, 11, 25, 10, 38, 38, 0), 1],
[Date.UTC(2014, 11, 25, 10, 40, 40, 0), 1],
[Date.UTC(2014, 11, 25, 10, 42, 42, 0), 1],
[Date.UTC(2014, 11, 25, 10, 44, 44, 0), 0],
[Date.UTC(2014, 11, 25, 10, 50, 50, 0), 0],
[Date.UTC(2014, 11, 25, 10, 52, 52, 0), 1],
[Date.UTC(2014, 11, 25, 10, 54, 54, 0), 0],
[Date.UTC(2014, 11, 25, 15, 42, 42, 0), 0],
[Date.UTC(2014, 11, 25, 15, 44, 44, 0), 1],
[Date.UTC(2014, 11, 25, 15, 46, 46, 0), 3],
[Date.UTC(2014, 11, 25, 10, 36, 36, 0), 1],
[Date.UTC(2014, 11, 25, 10, 42, 42, 0), 1],
[Date.UTC(2014, 11, 25, 10, 44, 44, 0), 0],
[Date.UTC(2014, 11, 25, 10, 50, 50, 0), 0],
[Date.UTC(2014, 11, 25, 10, 52, 52, 0), 1],
[Date.UTC(2014, 11, 25, 10, 52, 52, 0), 1],
[Date.UTC(2014, 11, 25, 10, 54, 54, 0), 0],
[Date.UTC(2014, 11, 25, 15, 42, 42, 0), 0],
[Date.UTC(2014, 11, 25, 15, 44, 44, 0), 1],
[Date.UTC(2014, 11, 25, 15, 44, 44, 0), 1],
[Date.UTC(2014, 11, 25, 15, 46, 46, 0), 3],
Tiskni
Sdílej: