raylib (Wikipedie), tj. multiplatformní open-source knihovna pro vývoj grafických aplikací a her, byla vydána ve verzi 6.0.
Nové verze AI modelů. Společnost OpenAI představila GPT‑5.5. Společnost DeepSeek představila DeepSeek V4.
Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 164 (pdf) a Hello World 29 (pdf).
Bylo oznámeno, že webový prohlížeč Opera GX zaměřený na hráče počítačových her je už také na Flathubu and Snapcraftu.
Akcionáři americké mediální společnosti Warner Bros. Discovery dnes schválili převzetí firmy konkurentem Paramount Skydance za zhruba 110 miliard dolarů (téměř 2,3 bilionu Kč). Firmy se na spojení dohodly v únoru. O část společnosti Warner Bros. Discovery dříve usilovala rovněž streamovací platforma Netflix, se svou nabídkou však neuspěla. Transakci ještě budou schvalovat regulační orgány, a to nejen ve Spojených státech, ale také
… více »Canonical vydal (email, blog, YouTube) Ubuntu 26.04 LTS Resolute Raccoon. Přehled novinek v poznámkách k vydání. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 11. vydání s dlouhodobou podporou (LTS).
V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Gitea (Wikipedie) byla vydána v nové verzi 1.26.0. Přehled novinek v příspěvku na blogu.
Ve středu 29. dubna 2026 se v pražské kanceláři SUSE v Karlíně uskuteční 7. Mobile Linux Hackday, komunitní setkání zaměřené na Linux na mobilních zařízeních, kernelový vývoj i uživatelský prostor. Akce proběhne od 10:00 do večerních hodin. Hackday je určen všem zájemcům o praktickou práci s Linuxem na telefonech. Zaměří se na vývoj aplikací v userspace, například bankovní aplikace, zpracování obrazu z kamery nebo práci s NFC, i na úpravy
… více »LilyPond (Wikipedie) , tj. multiplatformní svobodný software určený pro sazbu notových zápisů, byl vydán ve verzi 2.26.0. Přehled novinek v aktualizované dokumentaci.
Byla vydána nová verze 11.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 237 vývojářů. Provedeno bylo více než 2 500 commitů. Přehled úprav a nových vlastností v seznamu změn.
Řešení dotazu:
find -newerBt '2016-06-01' ! -newerBt '2016-06-02'
find . -type f | while read -r file
do
stat "${file}" | grep ^Change:\ ....-..-0.\ > /dev/null && echo ${file}
done
find . -type f | while read -r file
do
#stat "${file}"
stat "${file}" | grep ^Modify:\ ....-..-01\ > /dev/null && echo ${file}
done
Teď můžu pokračovat ...
Nejsem si jistý, co přesně myslíte formulací "rozhodit do Daily a Monthly", ale není to něco jako
for f in *.7z; do
dir=$(date -d @$(stat -c %Y $f) +%Y/%m/%d)
mkdir -p "$dir"
mv -vi "$f" "${dir}/"
done
Přesně mám na mysli toto:
Každý den se mi zálohují servery na své disky (je to rychlé) a následně se ty jejich zálohy kopírují na linuxový backup disk.
Skripty na těch serverech (Windows/Linux) neumí standardně dělat Monthly, jen Daily. A předělávat všechny skripty by byla otrava.
Proto na cílovém záložním serveru chci zálohy stěhovat do složky Monthly, abych si mohl udržovat 2 měsíce záloh ( zbytek se postupně odmazává), ale 6 měsíců záloh měsíčních, vždy první den v měsíci.
Je to i z kapacitních důvodů a takto je to po mě vyžadováno.
Vše mám pořešené, jen to kopírování 1.v měsíci jsem doposud neměl a nějak jsem se v tom zrácel.
Řešení výše je funkční, tvoje vyzkouším.
Moc děkuji za pomoc. Už jsem se s tím trápil celkem dlouho (po chvilkách cca měsíc).
Třeba to někomu dalšímu pomůže taky.
/srv/backup/$HOSTNAME/$YYYY-$MM-$DD/, takže hned je vidět ze kdy a odkud záloha je.
Co se stane, když se prvního ta záloha nepovede a bude chybět? Budeš mít pak dvouměsíční díru v zálohách? Spíš než dle data bych to řešil pořadím. Prostě první záloha v měsíci se zachová, ostatní se smažou. Takže pokud prvního zálohování selže, tak se zachová záloha z druhého a zbytek jde pryč.
Další otázka je, co se má stát, pokud zálohování přestane fungovat (nebo se servr odstraní). Smažou se postupně všechny zálohy, nebo prostě zůstane posledních šest měsíčních záloh? Co se stane s nejaktuálnější zálohou? Pokud by poslední záloha byla z 31. dne v měsíci a zachovala by se jen měsíční záloha z 1. dne v měsíci, znamená to ztrátu dat za poslední měsíc.
IN=/home/user
for f in $IN/*.7z; do
dir=$(date -d @$(stat -c %Y $f) +%Y/%m/%d)
echo $dir
#mkdir -p "$dir"
#mv -vi "$f" "${dir}/"
done
Výsledkem je výpis datumů ze všech souborů, které se na uvedené cestě nacházejí. Takže teď už jen vybrat ten d=01 a je to.
for f in ${IN}/*.7z; do
if [ "$(date -d @$(stat -c %Y $f) +%d" = 01 ]; then
...
fi
done
for f in ${IN}/*.7z; do
if [ "$(date -d @$(stat -c %Y $f) +%d)" = 01 ]; then
echo $f
fi
done
Píše Line 2: [01 Command not found Line 2: [02 Command not found Line 2: [03 Command not found Line 2: [04 Command not found Line 2: [05 Command not found Line 2: [06 Command not found
Ještě je tam nějaká chyba, ale tomu nerozumím. Jaký příkaz?
Pokud opravím hranaté závorky, pak je výstup takto:
for f in ${IN}/*.7z; do
if [ "$(date -d @$(stat -c %Y $f) +%d)"] = 01 ; then
echo $f
fi
done
Píše Line 2: [01] Command not found Line 2: [02] Command not found Line 2: [03] Command not found Line 2: [04] Command not found Line 2: [05] Command not found Line 2: [06] Command not found
Kde je tam chyba? Já jí nevidím...
test a je potřeba ji chápat jako příkaz, od kterého je první argument oddělen mezerou.)
Tak toto jsem netušil, že to není jen ohraničení příkazu a mezera je nutná. Zase jsem chytřejší, moc díky.
Vyřešeno, teď to chodí skvěle 
Akorát nesmíte mít mezery v názvech souborů
Může. Při návrhu takových skriptů je vhodné na tyhle věci myslet. Chyby ve zpracování mezer je lepší pohlídat a odstranit hned v úvodu, protože jinak člověka jednou spolehlivě střelí do nohy. (Otázka není zdali, ale kdy.)
Tak mi přijde, že většina navrhovaných řešení nesplňuje některé důležité předpoklady, jako například:
Tady je řešení, které bych použil já, kdybych potřeboval najít soubory změněné prvního.
find -type f -printf '%Td %p\n' \
| while read line; do
((10#"${line%% *}" == 1)) && echo "${line#* }"
done
Tiskni
Sdílej: