Google Chrome 136 byl prohlášen za stabilní. Nejnovější stabilní verze 136.0.7103.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 8 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 4.5.0. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.
Byl vydán Mozilla Firefox 138.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 138 je již k dispozici také na Flathubu a Snapcraftu.
Šestnáctý ročník ne-konference jOpenSpace se koná 3. – 5. října 2025 v Hotelu Antoň v Telči. Pro účast je potřeba vyplnit registrační formulář. Ne-konference neznamená, že se organizátorům nechce připravovat program, ale naopak dává prostor všem pozvaným, aby si program sami složili z toho nejzajímavějšího, čím se v poslední době zabývají nebo co je oslovilo. Obsah, který vytvářejí všichni účastníci, se skládá z desetiminutových
… více »Richard Stallman přednáší ve středu 7. května od 16:30 na Technické univerzitě v Liberci o vlivu technologií na svobodu. Přednáška je určená jak odborné tak laické veřejnosti.
Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.04.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.
TmuxAI (GitHub) je AI asistent pro práci v terminálu. Vyžaduje účet na OpenRouter.
Byla vydána nová verze R14.1.4 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5, Wikipedie). Přehled novinek i s náhledy v poznámkách k vydání. Podrobný přehled v Changelogu.
Bylo vydáno OpenBSD 7.7. Opět bez písničky.
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 ....
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
:-)