Stanislav Aleksandrov předložil patch rozšiřující KWin (KDE Plasma) na 3D virtuální desktopové prostředí (videoukázka v mp4).
Digg (Wikipedie), "místo, kde můžete sdílet a objevovat to nejlepší z internetu – a nejen to", je zpět. Ve veřejné betě.
Po .deb balíčcích Mozilla nově poskytuje také .rpm balíčky Firefoxu Nightly.
Vývojové prostředí IntelliJ IDEA slaví 25. narozeniny (YouTube).
Vedení společnosti NVIDIA údajně povolilo použití milionů knih ze známého 'warez' archivu Anna's Archive k výcviku umělé inteligence, ačkoliv vědělo, že archiv tyto knihy nezískal legální cestou. Žaloba, ve které se objevují i citace interních dokumentů společnosti NVIDIA, tvrdí, že NVIDIA přímo kontaktovala Anna's Archive a požadovala vysokorychlostní přístup k datům knihovny.
Grafický správce balíčků Myrlyn pro SUSE a openSUSE, původně YQPkg, dospěl do stabilní verze 1.0.0. Postaven je nad libzypp a Qt 6. Projekt začal na SUSE Hack Weeku 24.
Vývojáři se podařilo vytvořit patch pro Wine, díky kterému je možné na linuxovém stroji nainstalovat a spustit Adobe Photoshop (testováno s verzemi Photoshopu PS2021 a PS2025). Dalším patchem se podařilo umožnit dokonce instalaci téměř celého Adobe Creative Cloud Collection 2023, vyjma aplikací Adobe XD a Adobe Fresco. Patch řeší kompatibilitu s windowsovými subsystémy MSHTML - jádrem prohlížeče Internet exporer, a MSXML3 - parserem
… více »Hackeři zaútočili na portál veřejných zakázek a vyřadili ho z provozu. Systém, ve kterém musí být ze zákona sdíleny informace o veřejných zakázkách, se ministerstvo pro místní rozvoj (MMR) nyní pokouší co nejdříve zprovoznit. Úřad o tom informoval na svém webu a na sociálních sítích. Portál slouží pro sdílení informací mezi zadavateli a dodavateli veřejných zakázek.
Javascriptová knihovna jQuery (Wikipedie) oslavila 20. narozeniny, John Resig ji představil v lednu 2006 na newyorském BarCampu. Při této příležitosti byla vydána nová major verze 4.0.0.
Singularity je rootkit ve formě jaderného modulu (Linux Kernel Module), s otevřeným zdrojovým kódem dostupným pod licencí MIT. Tento rootkit je určený pro moderní linuxová jádra 6.x a poskytuje své 'komplexní skryté funkce' prostřednictvím hookingu systémových volání pomocí ftrace. Pro nadšence je k dispozici podrobnější popis rootkitu na blogu autora, případně v článku na LWN.net. Projekt je zamýšlen jako pomůcka pro bezpečnostní experty a výzkumníky, takže instalujte pouze na vlastní nebezpečí a raději pouze do vlastních strojů 😉.
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…
Pomôže zaradiť tac?
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.)
zvolil sem blbej priklad kdy druhe nahrazeni obsahuje string prvniho
slo mi opravdu o 2 rozdilne nejen nahrazovane ale i nahrazujici, ne vse za hovno
skoda, ale i tak casto sem v skriptech pro multiodstraneni radeji pouzil sed nez nekolikrat prepisovat promenou pres single manipulaci, takze aspon to ted vim ze muzu a jeste jednou diky :)
Tiskni
Sdílej: