V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 14.0 (Mastodon). Forgejo je fork Gitei.
Just the Browser je projekt, 'který vám pomůže v internetovém prohlížeči deaktivovat funkce umělé inteligence, telemetrii, sponzorovaný obsah, integraci produktů a další nepříjemnosti' (repozitář na GitHubu). Využívá k tomu skrytá nastavení ve webových prohlížečích, určená původně pro firmy a organizace ('enterprise policies'). Pod linuxem je skriptem pro automatickou úpravu nastavení prozatím podporován pouze prohlížeč Firefox.
Svobodný multiplatformní herní engine Bevy napsaný v Rustu byl vydán ve verzi 0.18. Díky 174 přispěvatelům.
Miliardy korun na digitalizaci služeb státu nestačily. Stát do ní v letech 2020 až 2024 vložil víc než 50 miliard korun, ale původní cíl se nepodařilo splnit. Od loňského února měly být služby státu plně digitalizované a občané měli mít právo komunikovat se státem digitálně. Do tohoto data se povedlo plně digitalizovat 18 procent agendových služeb státu. Dnes to uvedl Nejvyšší kontrolní úřad (NKÚ) v souhrnné zprávě o stavu digitalizace v Česku. Zpráva vychází z výsledků víc než 50 kontrol, které NKÚ v posledních pěti letech v tomto oboru uskutečnil.
Nadace Wikimedia, která je provozovatelem internetové encyklopedie Wikipedia, oznámila u příležitosti 25. výročí vzniku encyklopedie nové licenční dohody s firmami vyvíjejícími umělou inteligenci (AI). Mezi partnery encyklopedie tak nově patří Microsoft, Amazon a Meta Platforms, ale také start-up Perplexity a francouzská společnost Mistral AI. Wikimedia má podobnou dohodu od roku 2022 také se společností Google ze skupiny
… více »D7VK byl vydán ve verzi 1.2. Jedná se o fork DXVK implementující překlad volání Direct3D 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.
Byla vydána verze 12.0.0 knihovny libvirt (Wikipedie) zastřešující různé virtualizační technologie a vytvářející jednotné rozhraní pro správu virtuálních strojů. Současně byl ve verzi 12.0.0 vydán související modul pro Python libvirt-python. Přehled novinek v poznámkách k vydání.
CreepyLink.com je nový zkracovač URL adres, 'díky kterému budou vaše odkazy vypadat tak podezřele, jak je to jen možné'. Například odkaz na abclinuxu.cz tento zkracovač převádí do podoby 'https://netflix.web-safe.link/logger_8oIlgs_free_money.php'. Dle prohlášení autora je CreepyLink alternativou ke zkracovači ShadyURL (repozitář na githubu), který dnes již bohužel není v provozu.
Na blogu Raspberry Pi byla představena rozšiřující deska Raspberry Pi AI HAT+ 2 s akcelerátorem Hailo-10 a 8 GB RAM. Na rozdíl od předchozí Raspberry Pi AI HAT+ podporuje generativní AI. Cena desky je 130 dolarů.
Wikipedie slaví 25. výročí svého založení. Vznikla 15. ledna 2001 jako doplňkový projekt k dnes již neexistující encyklopedii Nupedia. Doména wikipedia.org byla zaregistrována 12. ledna 2001. Zítra proběhne v Praze Večer svobodné kultury, který pořádá spolek Wikimedia ČR.
mv slouží k přesouvání (a přejmenování) souborů a adresářů. Název vychází z angl. slova move, což znamená přesunout.
V různých situacích má různé chování, tak si to předvedeme a vysvětlíme na praktických ukázkách.
Následuje příklad, ve kterém přejmenujeme soubor.txt na jiny_nazev.txt. Pokud soubor s názvem jiny_nazev.txt před spuštěním již existuje, bude přepsán (v případě, že na to máme právo, samozřejmě). Pokud před spuštěním existuje adresář s názvem jiny_nazev.txt, tak soubor.txt bude přesunut do něj.
mv soubor.txt jiny_nazev.txt
Co když chceme soubor skutečně přesunout jinam?
# přesuneme soubor.txt do adresáře /mnt/data mv soubor.txt /mnt/data/ # přesuneme soubor.txt do adresáře /mnt/data pod názvem file.txt mv soubor.txt /mnt/data/file.txt
Soubor či adresář lze přesunout a přejmenovat najednou, jen dokud pracujeme pouze s jedním, ovšem přesouvat lze i více souborů a adresářů najednou. Jako první vyjmenujeme všechno, co chceme přesunout, a poslední argument musí být cesta k existujícímu adresáři, do kterého se vše přesune.
mv adresar soubor.txt skript.py jiny_adresar ../cilovy_adresar/
Dalším zvláštním případem je přesouvání adresářů. Následující příklad se chová různě za různých podmínek:
mv adresar ../jiny_adresar
Chceme-li soubor skutečně přesunout do jiného adresáře a zajistit, aby nedošlo k přejmenování souboru či k přepisu jiného souboru, pomůže za název cílového adresáře přidat lomítko.
mv soubor.txt ~/.trash/ # problém je, že následující příkaz by mohl soubor.txt přesunout do ~ # pod názvem .trash, pokud by adresář .trash neexistoval mv soubor.txt ~/.trash
Tolik k základnímu použití. Nyní si vysvětlíme, co znamenají argumenty příkazu mv, které jsou dostupné ve většině implementací, včetně GNU. U nestandardních přepínačů přidám hvězdičku (*).
| Přepínač | Popis |
| -f | povolí přepisování souborů (obejde předchozí -n a -i) |
| -i | interaktivní režim; na přepsání souboru se zeptá (obejde předchozí -f a -n) |
| -n * | zakáže přepisování souborů (obejde předchozí -f a -i) |
| -v * | vypíše informace o tom, jaké operace byly provedeny |
Přepínač -f obvykle není nutné používat, protože jde o výchozí režim přepisování souborů, ale hodí se například nastavuje-li vaše distribuce mv jako alias mv -i (tzn. nastavuje -i jako výchozí) a vy to chcete jednorázově obejít.
Ukážeme si, jak v praxi vypadá použití přepínače -v. Uvažujme, že v aktuálním pracovním adresáři máme adresáře a a b.
# přejmenujeme a na c mv -v a c `a' -> `c' # přesuneme b do c mv -v b c `b' -> `c/b'
Mezi další nestandardní přepínače, které jsou dostupné v implementaci GNU, patří -b a -u. Tam, kde by normálně došlo k přepsání souboru, mv s přepínačem -b nejdřív zálohuje původní soubor (přejmenuje ho tak, že na konec názvu souboru přidá ~) a teprve poté jej nahradí. Přepínač -u zajistí, že se existující soubor přepíše jen tehdy, je-li zdrojový soubor novější než cílový (porovnává se mtime, tedy čas poslední úpravy souboru).
Na závěr je dobré si uvědomit, že přesunutí souboru nikdy není úplně totéž jako prosté zkopírování a smazání. Pokud jde o přesunutí v rámci jednoho souborového systému, kopírování a mazání většího souboru by trvalo dlouho, zatímco mv nejprve vytvoří soubory se stejnou inode (hardlinky) v cílovém adresáři a potom smaže ty původní, takže jde o velmi rychlou operaci. V každém případě (tzn. i když kopírujete na jiný souborový systém) má mv výhodu v tom, že máte jistotu, že nepřijdete o data, pokud kopírování dat selže (například při zaplnění souborového systému), protože mv v takovém případě původní soubory nesmaže.
Program cp slouží ke kopírování souborů a adresářů. Název cp vychází z anglického copy, což znamená kopírovat. Chování v různých specifických situacích je velmi podobné tomu u mv. To ale není jediná podobnost s mv; cp má totiž i několik stejných přepínačů – standardní -f a -i, a GNU verze také -b, -n, -u a -v.
Mezi další standardní a GNU (*) přepínače patří:
| Přepínač | Popis |
| -H | Následuje symlinky v explicitně zadaných zdrojových souborech. |
| -L | Následuje všechny symlinky. |
| -P | Režim kopírování symbolických odkazů. Ve výchozím režimu (GNU) se totiž kopírují soubory, na které symlinky odkazují. |
| -p | Zachová časy (posl. změny a přístupu) a oprávnění. |
| -R | Rekurzivní kopírování. Umožní kopírování adresářů. |
| -a * | Jako -PRp a navíc zachová všechny atributy. Často se používá při běžném rekurzivním kopírování adresářů. |
| -l * | Místo kopírování souborů vytváří pevné odkazy (hardlinky). |
| -s * | Místo kopírování souborů vytváří symbolické odkazy (symlinky). |
| -x * | Při rekurzivním kopírování zůstane pouze na souborovém systému zadaného adresáře. |
Ukázky:
# zkopíruje soubor.txt do adresáře /mnt/storage pod názvem jiny_nazev.txt cp soubor.txt /mnt/storage/jiny_nazev.txt # zkopíruje soubor.txt do adresáře /mnt/storage cp soubor.txt /mnt/storage/ # rekurzivně zkopíruje adresář a zachová atributy cp -a ../adresar /cilovy/adresar/ # vytvoření symlinku (b -> a) pomocí GNU cp cp -s a b
Adresáře /mnt či /media obvykle obsahují pouze adresáře sloužící jako přípojné body pro souborové systémy. Využijeme toho pro vysvětlení přepínače -x (význam viz výše v tabulce). Následující příkaz sice bude /media kopírovat rekurzivně, ale nezajde při tom mimo souborový systém, na kterém se tento adresář nachází. Pokud tento adresář obsahuje jen prázdné adresáře a případně adresáře, do kterých jsou připojené souborové systémy, následující příkaz zkopíruje pouze adresáře, které jsou přímo v /media (ne v podadresářích).
cp -Rx /media mnt
Máme adresář dir obsahující soubor file a symlink sym ukazující na file. Zkopírujeme-li tento adresář s přepínačem -L, symlink sym bude v kopii adresáře normální soubor, identický jako file, protože -L způsobilo následování symlinku při kopírování.
$ ls -l dir total 0 -rw-r--r-- 1 dave home 5 2009-11-05 14:07 file lrwxrwxrwx 1 dave home 4 2009-11-05 14:11 sym -> file $ cp -aL dir kopie_dir $ ls -l kopie_dir/ total 8 -rw-r--r-- 2 dave home 5 2009-11-05 14:07 file -rw-r--r-- 2 dave home 5 2009-11-05 14:07 sym
rm slouží k mazání souborů a adresářů. Název vychází z anglického slova remove, což znamená odstranit. Jedná se o nástroj, se kterým je z principu radno pracovat opatrně. O tom si povíme za chvíli. Nejdříve si ukážeme použití:
# smaže soubor.txt rm soubor.txt # smaže soubory a, b, c rm a b c
Nyní si popíšeme standardní přepínače.
| Přepínač | Popis |
| -f | Neptá se na potvrzení a nevypisuje chybová hlášení (např. při pokusu o mazání neexistujícího souboru). Obejde předchozí -i. |
| -i | Interaktivní režim. Před smazáním každého souboru či prázdného adresáře se zeptá. Obejde předchozí -f. |
| -r, -R | Rekurzivní mazání. Umožní mazat adresáře včetně veškerého obsahu. |
Předvedeme si rekurzivní mazání adresáře. Všimněte si, že s -i se rm nejprve zeptá, jestli má mazat v zadaném adresáři a poté se ptá na mazání jednotlivých položek (souboru, odkazu a nakonec samotného adresáře). Zkratkou y (angl. yes, tedy ano) mu jednotlivé operace povolíme.
# smaže adresář "dir" rm -r dir # smaže soubor.txt (a pokud už před spuštěním neexistuje, nehlásí chybu) rm -f soubor.txt # rm se nejprve zeptá, jestli má mazat v zadaném adresáři, a poté # se ptá na mazání jednotlivých položek (souboru, odkazu a nakonec # samotného adresáře). # Máte-li nainstalovanou lokalizaci, bude na vás mluvit česky. $ rm -ri dir rm: descend into directory `dir/'? y rm: remove regular file `dir/file'? y rm: remove symbolic link `dir/sym'? y rm: remove directory `dir'? y
Výjimka, kdy je rm (bez -f) interaktivní, i když nezadáme -i, nastane tehdy, když se pokusíme smazat soubor, ke kterému nemáme právo k zápisu (w). Potom se rm zeptá, zda chceme soubor skutečně smazat. Jsme-li vlastníkem souboru či root, smazání souboru nám při kladné odpovědi zpravidla projde. V případě, že nejsme vlastníkem souboru, rm se zeptá taky, ale kladná odpověď pouze způsobí chybové hlášení o nedostatečných právech.
rm soubor_s_pravy_0444 rm: remove write-protected regular empty file `soubor_s_pravy_0444'? y
Upozorňoval jsem na nebezpečnost příkazu rm. Proč? Velmi snadno si pomocí něj můžete zlikvidovat systém. Dříve stačilo (a na některých systémech stále stačí) spustit rm -rf / a smazali jste si celý kořenový adresář – celý systém. V dnešní době to na GNU systémech neprojde (za příkaz je třeba přidat ještě hvězdičku nebo zvláštní přepínač). Věřím tomu, že jsem jeden z mála adminů, kteří si troufnou spustit následující (a rozhodně to tímto nedoporučuji):
# rm -fr / rm: cannot remove root directory `/'
Kvůli relativně vysoké možnosti nechtěného spuštění tohoto příkazu to nefunguje na většině moderních Un*x systémech. Sun v roce 2005 vydal Solaris 10 s upraveným rm, které při spuštění tohoto příkazu pouze vypsalo chybové hlášení. Krátce na to se toho chytlo i FreeBSD a přidalo tuto úpravu i do své verze programu. GNU verze odmítá spustit příkaz, pokud byl zadán přepínač --preserve-root, který je výchozí od coreutils verze 6.4 z roku 2006. Na GNU systémech to lze obejít přepínačem --no-preserve-root.
Obzvláště dříve, když unixové systémy nebyly tak rozšířené jako dnes, se občas stalo, že se našel nějaký vtipálek, který spuštění tohoto příkazu doporučil nějakému začátečníkovi.
GNU rm disponuje navíc několika nestandardními přepínači. Má --one-file-system, který funguje jako -x u cp, což znamená, že rekurze mazání nezajde mimo souborový systém zadaných adresářů. Přepínač -v je stejný jako u mv a cp; vypíše informace o provedených operacích.
Nástroje: Tisk bez diskuse
Tiskni
Sdílej:
#cd / #ls -bash: ls: commnad not found #reboot -bash: reboot: commnad not found
# cd / # rm -rf / rm: kořenový adresář "/" nelze smazat # ls bin/ etc/ initrd/ lib64/ media/ proc/ sbin/ tmp/ var/ boot/ dev/ home/ lib/ lost+found/ mnt/ opt/ root/ sys/ usr/
Jsme-li vlastníkem souboru či root, smazání souboru nám při kladné odpovědi zpravidla projde.
Pro oprávnění smazat soubor není vůbec podstatné, zda jsem jeho vlastníkem, ale zda mám právo zápisu na adresář, ve kterém ten soubor je. Vlastnictví na to má vliv pouze v případě, že má ten adresář nastavený 't' bit.
GVFS/GIO, KIO slavesTo sice vypadá jako něco proti posvátné unixové filosofii, ale nutí tě někdo je používat? Brání ti to, připojit si SFTP, CIFS, FTP… pomocí FUSE a mít je v normální hierarchii /mnt/adresářů/ jako normální soubory? Je to jen další možnost. A dost užitečná, když chce člověk třeba jen zkopírovat jeden soubor, protože napsat ftp://example.com/ jako cestu je jednodušší, než si připojovat souborový systém. *) nemluvě o tom, že i v UNIXu bys se hodil atribut skrytosti, jako ve Windows a nespoléhat se na tečku (protože pak chceš změnit vlastnost skrytý/viditelný a musíš kvůli tomu měnit název, což je často nemožné).
Slozka .... Folder .... a nasi bratri pouzivaju Priecnik a to sa mi paci najvjac ....
. Bezne sa vsak pouziva vyraz adresar.
rm -rf -- "$soubory"
kdežto se už docela dost lidí spálilo bez nich.
standartníchstandardních
getopt() z glibc.
find ! -name ... [-or ! -name ...] -deletePřípadně místo
-delete tam dát -print0 a použít přes rouru xargs -0 rm
-and :-)