Andreas Kling oznámil, že jelikož už se nevěnuje nezávislému operačnímu systému SerenityOS, ale výhradně jeho webovému prohlížeči Ladybird, přičemž vyvíjí primárně na Linuxu, SerenityOS opustí a Ladybird bude nově samostatný projekt (nový web, repozitář na GitHubu).
Po dvou měsících vývoje byla vydána nová verze 0.13.0 programovacího jazyka Zig (GitHub, Wikipedie). Přispělo 73 vývojářů. Přehled novinek v poznámkách k vydání.
Na čem aktuálně pracují vývojáři GNOME a KDE? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE.
Před 70 lety, 7. června 1954, ve věku 41 let, zemřel Alan Turing, britský matematik, logik, kryptoanalytik a zakladatel moderní informatiky.
NiceGUI umožňuje používat webový prohlížeč jako frontend pro kód v Pythonu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána ve verzi 2024.6. Z novinek lze vypíchnout lepší integraci LLM (OpenAI, Google AI, Ollama) nebo podporu Matter 1.3.
IKEA ve Spojeném království hledá zaměstnance do své nové pobočky. Do pobočky v počítačové hře Roblox. Nástupní mzda je 13,15 liber na hodinu.
Alyssa Rosenzweig se v příspěvku na svém blogu Vulkan 1.3 na M1 za 1 měsíc rozepsala o novém Vulkan 1.3 ovladači Honeykrisp pro Apple M1 splňujícím specifikaci Khronosu. Vychází z ovladače NVK pro GPU od Nvidie. V plánu je dále rozchodit DXVK a vkd3d-proton a tím pádem Direct3D, aby na Apple M1 s Asahi Linuxem běžely hry pro Microsoft Windows.
Byla vydána (𝕏) květnová aktualizace aneb nová verze 1.90 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Ve verzi 1.90 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Byla vydána (Mastodon, 𝕏) nová verze 2024.2 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení.
find . -type d -print | ( while read oldname; do newname=`echo $oldname | sed s/[-_]//g`; mv "$oldname" "$newname"; done) find . -type f -print | ( while read oldname; do newname=`echo $oldname | sed s/[-_]//g`; mv "$oldname" "$newname"; done)Pre istotu navrhujem miesto "mv" vyskúšať "echo mv".
find . -type d -print | ( while read oldname; do newname=`echo $oldname | sed s/[-_]//g`; mv "$oldname" "$newname"; done) find . -type f -print | ( while read oldname; do newname=`echo $oldname | sed s/[-_]//g`; mv "$oldname" "$newname"; done)
Vždyť to^^^ vůbec nefunguje. Ani trochu. Příklad:
mkdir -p /tmp/blah/a-b/c-d cd /tmp/blah touch a-b/c-d/e-f
Tak. A teď to zkusme spustit:
mv: '.' a './.' jsou jeden a tentýž soubor mv: nelze získat informace o './a-b/c-d': Adresář nebo soubor neexistuje mv: nelze přesunout './ab/c-d/e-f' do './ab/cd/ef': Adresář nebo soubor neexistuje
(I kdyby to fungovalo, posteskl bych si pořád ještě nad
mv
, když nedojde ke změně názvu, včetně adresáře ./
,|
ased
(a subshellu) na něco, co umí Bash (${name//@(_|-)}
),Tohle funguje, přinejmenším na výše uvedeném příkladu…
find . -type d -print | tac | ( while read oldname; do newname=`echo $oldname | sed s/[-_]//g`; echo mv "$oldname" "$newname"; done) mv ./a-b/c-d ./ab/cd mv ./a-b ./ab mv . .
Stačil by -depth
, jak jsem psal níže.
(Řešení nemusí být perfektní, nicméně paměťové nároky by neměly záviset lineárně na počtu nalezených cest (tac
) a neměly by se zbytečně spouštět procesy sed
a mv
na každou cestu; mv
není potřeba všude a sed
není potřeba vůbec.)
find -depth | while read name; do base="${name##*/}" new_base="${base//@(_|-)}" if [[ "${new_base}" != "${base}" ]]; then echo mv "${name}" "${name%/*}/${new_base}" fi done
echo
a spustit to naostro.extglob
. (Dnes už bývá implicitně zapnutý.)No to je ale smůla. (Fakt nevím, co jiného se na tohle dá odpovědět.)
Pokud jsi si jistý, že (1) máš zapnutý extglob
(shopt -s extglob
) a (2) jsi ve správném adresáři, asi to budeš muset nějak debuggovat. Co třeba
find -depth
, co to vypíše?base
a new_base
, jestli mají očekávanou hodnotu a jestli se liší, kdy se mají lišit?"zato" == "zatohle"
, to by potom šlo:
something='nahraď nahraďještě nahraď' echo "${something//nahraď?(ještě)/hovno}"Bohužel jsem nenašel v dokumentaci ani takovou věc jako možnost vložit matchovaný řetězec (nebo jeho část) do náhrady, jak to umí třeba programy pracující s regexpy (
sed
). Nedivil bych se, kdyby to Bash už někde ve zdrojáku měl, zatímco manuálová stránka o tom ještě mlčí.
(Dost dlouho například nebylo zdokumentované „vektorové“ nahrazování u polí, typu…
names=({a,b,c,d}.txt) echo "${names[@]}" echo "${names[@]/%.txt/.sql}"…, i když už notnou dobu fungovalo. Teď už to v manuálové stránce je.)
Tiskni Sdílej: