abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 19:44 | IT novinky

    Microsoft představil Azure Linux 4.0 a Azure Container Linux. Na konferenci Open Source Summit North America 2026 organizované konsorciem Linux Foundation a sponzorované také Microsoftem. Azure Linux 4.0 vychází z Fedora Linuxu. Azure Container Linux je založen na projektu Flatcar. Azure Linux (GitHub, Wikipedie) byl původně znám jako CBL-Mariner.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 165 (pdf).

    Ladislav Hagara | Komentářů: 0
    včera 10:55 | Nová verze

    Byla vydána verze 9.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a informačním videu.

    Ladislav Hagara | Komentářů: 4
    včera 09:33 | IT novinky

    Firefox 151 podporuje Web Serial API. Pro komunikaci s různými mikrokontroléry připojenými přes USB nebo sériové porty už není nutné spouštět Chrome nebo na Chromiu postavené webové prohlížeče.

    Ladislav Hagara | Komentářů: 3
    včera 04:44 | Nová verze

    Byla vydána nová stabilní verze 8.0 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 148. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    21.5. 21:33 | Bezpečnostní upozornění

    Ve FreeBSD byla nalezena a opravena zranitelnost FatGid aneb CVE-2026-45250. Jedná se o lokální eskalaci práv. Neprivilegovaný uživatel se může stát rootem.

    Ladislav Hagara | Komentářů: 0
    21.5. 14:33 | IT novinky

    Společnost Flipper Devices oznámila Flipper One. Zcela nový Flipper postavený od nuly. Jedná se o open-source linuxovou platformu založenou na čipu Rockchip RK3576. Hledají se dobrovolníci pro pomoc s dokončením vývoje (ovladače, testování, tvorba modulů).

    Ladislav Hagara | Komentářů: 2
    21.5. 14:00 | Nová verze

    Vývojáři Wine oznámili vydání verze 2.0 knihovny vkd3d pro překlad volání Direct3D na Vulkan. Přehled novinek na GitLabu.

    Ladislav Hagara | Komentářů: 0
    21.5. 11:33 | Nová verze

    Společnost Red Hat oznámila vydání Red Hat Enterprise Linuxu (RHEL) 10.2 a 9.8. Vedle nových vlastností a oprav chyb přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Vypíchnout lze CLI AI asistenta goose. Podrobnosti v poznámkách k vydání (10.2 a 9.8).

    Ladislav Hagara | Komentářů: 0
    21.5. 05:11 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1685 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Echo příkazu je v pořádku, jeho vykonání ale už ne

    Zdeněk Zámečník avatar 13.8.2008 18:29 Zdeněk Zámečník | skóre: 26
    Echo příkazu je v pořádku, jeho vykonání ale už ne
    Přečteno: 357×
    Už hezkých pár hodin bojuji s tímto skriptem:
    #!/bin/bash
    EXCLUDE_LIST=./usr/share/doc,./usr/share/man/*,./var/cache/apt/archives
    
    EXCLUDE_LIST_DU=\"$(echo $EXCLUDE_LIST | sed 's/,/" --exclude "/g')\"
    du . -hs --exclude $EXCLUDE_LIST_DU
    
    Jednoduše má vypsat velikost aktuálního adresáře s výjimkami v EXCLUDE_LIST. Ale on to neudělá. Vypisuje stále velikost bez ohledu na exclude.

    Pokud poslední řádek upravím takto:
    echo "du . -hs --exclude $EXCLUDE_LIST_DU"
    tak je vidět, že příkaz je poskládán správně:
    du . -hs --exclude "./usr/share/doc" --exclude "./usr/share/man/*" --exclude "./var/cache/apt/archives"
    
    Když ho takto vezmu a spustím, je výsledek správný. Hádal bych, že mi tam někde haprují uvozovky, ale už si s tím takto hraju dost dlouho a stále nic...

    Za každé nakopnutí předem díky

    Řešení dotazu:


    Odpovědi

    David Watzke avatar 13.8.2008 18:59 David Watzke | skóre: 74 | blog: Blog... | Praha
    Rozbalit Rozbalit vše Re: Echo příkazu je v pořádku, jeho vykonání ale už ne
    Chyba je v tom, že když echo vypíše i ty uvozovky, tak to znamená, že se tu pak spustí jako kdyby byly escapovaný. Nejjednodušší řešení když už to máš takhle rozdělaný by bylo:
    eval "du . -hs --exclude $EXCLUDE_LIST_DU"
    “Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
    Zdeněk Zámečník avatar 13.8.2008 19:10 Zdeněk Zámečník | skóre: 26
    Rozbalit Rozbalit vše Re: Echo příkazu je v pořádku, jeho vykonání ale už ne
    Bezva! Jede to, a jak by to šlo udělat bez escapování? Něco jako toto:
    EXCLUDE_LIST=./usr/share/doc,./usr/share/man/*,./var/cache/apt/archives
    EXCLUDE_LIST_DU=$(echo $EXCLUDE_LIST | sed 's/,/" --exclude "/g')
    du . -hs --exclude "$EXCLUDE_LIST_DU"
    
    mi taky nešlape. Je to jen teoretická otázka ;) Každopádně díky!
    David Watzke avatar 14.8.2008 11:39 David Watzke | skóre: 74 | blog: Blog... | Praha
    Rozbalit Rozbalit vše Re: Echo příkazu je v pořádku, jeho vykonání ale už ne
    Osobně bych použil --exclude-from=soubor a nacpal ty cesty do souboru, ale když už bych to dělal takhle, tak by mělo jít něco jako:
    EXCLUDE_LIST=./usr/share/doc,./usr/share/man/*,./var/cache/apt/archives
    EXCLUDE_LIST_DU=$(for d in $EXCLUDE_LIST; do echo -n "--exclude \"$d\" "; done)
    IFS=,
    eval du . -hs --exclude $EXCLUDE_LIST_DU
    Což považuju za lepší řešení, ale tomu problému s escapováním se nevyhneš, pokud v tý proměnný budeš očekávat i cesty s mezerama atp.
    “Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
    Tarmaq avatar 13.8.2008 19:05 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: Echo příkazu je v pořádku, jeho vykonání ale už ne
    nestacilo by toto?
    EXCLUDE_LIST=,./usr/share/doc,./usr/share/man/*,./var/cache/apt/archives
    du . -hs $(echo $EXCLUDE_LIST | sed 's/,/ --exclude /g')
    
    Don't panic!
    Zdeněk Zámečník avatar 13.8.2008 19:12 Zdeněk Zámečník | skóre: 26
    Rozbalit Rozbalit vše Re: Echo příkazu je v pořádku, jeho vykonání ale už ne
    Nestačilo. Nevím, v čem přesně tkví tvá pointa, nejspíš narážíš na uvozovky, ale věř tomu, že tohle fungovat nebude - kvůli regulérnímu výrazu (*)...
    13.8.2008 22:29 petr
    Rozbalit Rozbalit vše Re: Echo příkazu je v pořádku, jeho vykonání ale už ne
    Staci pred hvezdicku dat \\ (dve lomitka)

    PS: * v bashi neni regularni vyraz, tak se rika necemu jinemu (a opravdu za tim l je a) * a ? v shellu se rika zolikove znaky ;-)

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.