Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
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
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: