Byla vydána verze 1.93.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.
Svobodný operační systém ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, slaví 30. narozeniny.
Společnost Raspberry Pi má nově v nabídce flash disky Raspberry Pi Flash Drive: 128 GB za 30 dolarů a 256 GB za 55 dolarů.
Technologie Skip pro multiplatformní mobilní vývoj, která umožňuje vývojářům vytvářet iOS a Android aplikace z jediné Swift a SwiftUI kódové základny, se s vydáním verze 1.7 stala open source.
Na GitHubu byl zveřejněn algoritmus "Pro vás" sociální sítě 𝕏.
Byla vydána nová major verze 34.0.0 webového prohlížeče Pale Moon (Wikipedie) vycházejícího z Firefoxu. Přehled novinek v poznámkách k vydání.
Win8DE je desktopové prostředí pro Wayland, inspirované nechvalně proslulým uživatelským rozhraním Metro z Windows 8. Nabízí dlaždicové rozhraní s velkými tlačítky a jednoduchou navigací, optimalizované pro dotyková zařízení. Cílem projektu je přetvořit design operačního systému Windows 8 do funkčního a minimalistického rozhraní vhodného pro každodenní použití na Linuxu.
Laboratoře CZ.NIC vydaly Datovku 4.28.0 a Mobilní Datovku 2.6.0. Hlavní novinkou je ukládání rozpracovaných datových zpráv do konceptů. Datovka je svobodné multiplatformní aplikace pro přístup k datovým schránkám a k trvalému uchovávání datových zpráv v lokální databázi.
Unix Pipe Game je vzdělávací karetní hra zaměřená na děti a rodiče, která děti učí používat unixové příkazy prostřednictvím interaktivních úkolů. Klíčovým prvkem hry je využití symbolu | pro pipeline neboli 'rouru', který umožňuje propojit výstupy a vstupy jednotlivých unixových příkazů, v tomto případě vytištěných na kartičkách. Předpokládá se, že rodič má alespoň nějaké povědomí o unixových příkazech a jejich provazování pomocí |.
… více »PCIem je linuxový framework, který vytváří virtuální zařízení PCIe pomocí technik, které umožňují hostitelskému operačnímu systému rozpoznat tyto syntetické 'neexistující' karty jako fyzické zařízení přítomné na sběrnici. Framework PCIem je primárně zamýšlen jako pomůcka pro vývoj a testování ovladačů bez nutnosti použít skutečný hardware. Dle tvrzení projektu si fungování PCIem můžeme představit jako MITM (Man-in-the-Middle), který se nachází mezi ovladači a kernelem.
Tak jsem zase potřeboval něco naprogramovat. Člověk by si řekl, když nevím jak na to v bashi, použij něco silnějšího, třeba perl. Ale to bych nebyl já, kdybych to aspoň nezkusil. Takže máme nějaký textový soubor s daty z měření a v něm za komentářem jsou popisky jednotlivých sloupečků. Kdyby to byla jen jedna série s jedněmi popisky, tak je to naprosto jednoduché, ale těch sérií je víc a jak na potvoru každá má jiné popisky. No a já z toho chci vytvořit příkaz pro gnuplot s tím, že si uživatel může vybrat kterou sérii a který sloupeček chce zobrazit. To vyžaduje mít možnost načíst jednotlivé popisky do proměných a pak se přes indexy k nim dostat při zpracování parametrů na příkazovém řádku. Pro ilustraci máme soubor mereni.dat:
# blabla komentar # title: x,y,z # title: x,s1 # title: x,s2 # prvni serie 1, 2, 3 2, 3, 4 #druha serie 1, 3 1, 4 #treti serie 1, 2 1, 1
Načtení celého souboru po řádcích by bylo celkem jednoduché
j=0 while read i; do radky[j]="$i"; let j++; done <mereni.datale krajně pomalé a zbytečné a další zpracvání v bashi ještě pomalejší a nepohodlnější. Při pokusu to načíst už odfiltrované narazíme pochopitelně na problém
j=0 sed '/^# *title:/!d;s/^# *title: *//' mereni.dat |\ while read i; do radky[j]="$i"; let j++; doneprotože cyklus while proběhne jako subproces a změna env (proměná radky) zůstane v subprocesu a už ji nikdy neuvidíme. To je ale pěkně hloupé. Když jsem nad tím přemýšlel, tak už jsem to chtěl zabalit, ale pak přišlo na scénu IFS. (Teda abych pravdu řekl, tak je ještě možnost si to uschovat do tmp souboru, ale nebuďme malí a měkcí.)
IFS určuje oddělovač: The Internal Field Separator that is used for word splitting after expansion and to split lines into words with the read builtin command. The default value is ``<space><tab><newline>''. Ve spojení s bashovými poli která zpracovávají
a=("řetězec")
právě pomocí word spliting je myslím jasné, jak na to. Posledním zádrhelem je, jak nacpat do IFS právě jen a pouze konec řádku (mimochodem C-V C-M nebo Enter je \r tedy návrat vozíku a ne přechod na další řádek \n jak bych čekal), takže IFS="^M" vložené touto kombinací nefunguje, což mě málem přivedlo k myšlence, že je to rozbité. Není. Nejjednodušší je
IFS=" "Což při přepisu může být trošku matoucí takže uvažuji o "čitelnější" variantě
IFS="$(echo -e \"\\n\")"nebo
IFS="$(printf -e \"\\n\")"Brr, ale při přepisu někým jiným by v tom mohlo být míň chyb. Takže výsledkem může být něco takového
# natáhneme popisy titulků
IFS="$(echo -e \"\\n\")" titles=($(sed '/^# *title:/!d;s/^# *title: *//' mereni.dat))
# na jdenom řádku je to proto, abych nemusel obnovovat IFS=''
# k jednotlivým titulkům se pak dá snadno dostat pomocí
IFS=',' title=(${titles[$serie]})
def=" t '${title[$column]}'"
kde proměné serie a column získám obligátní cyklem zpracovávajícím paramery příkazového řádku.Dobrou noc milé děti.
Tiskni
Sdílej:
Diskuse byla administrátory uzamčena
s/nebuďme malý/nebuďme malí/ s/bashovými poly/bashovými poli/ s/rozbyté/rozbité/ s/Nejjednodužší/Nejjednodušší/A teď k věci. Zdaleka nejjednodušší způsob, jak dostat do IFS jen \n, je
IFS=$'\n':-) Ale jinak pěkné, s tou rourou by mi asi docela trvalo, než by mi to došlo.
To by mě zajímalo jestli by to bylo tak jednoduché v "normálním" editoru viz.Proč nemám rád VIM. Asi těžko to bude jednodušší než stisknout dvě klávesy :% kliknout prostředním tlačítkem a entr
To s tím $'\n' jsem zase neznal já. Když ten bash(1) je tak rozsáhlý a já myslel, že v sekci QUOTING se nedočtu nic zajímavého
.
IFS=$' \t\n'
Je fakt, že takhle to vypadá jako bych se pokoušel o most obfuscated verzi jednoduchého IFS=$'\n'
P.S.: Furt se něco učím.
set, resp. set | grep IFS
.