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í
×
    dnes 04:44 | Nová verze

    Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    dnes 02:22 | Nová verze

    Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).

    Ladislav Hagara | Komentářů: 1
    dnes 01:55 | Humor

    Microsoft zveřejnil zdrojový kód XAML Studia a uvolnil ho pod MIT licencí. XAML Studio je nástroj ze světa Windows, určený pro tvorbu uživatelského rozhraní aplikací pomocí XAML (Extensible Application Markup Language). Stalo se tak zhruba po osmi letech od prvního prohlášení Microsoftu, že se tento kód chystá zveřejnit.

    NUKE GAZA! 🎆 | Komentářů: 0
    dnes 01:44 | Zajímavý projekt

    TimeCapsule, 'časová kapsle', je jazykový model trénovaný výhradně na datech z určitých míst a časových období, aby se tak napodobila autentická slovní zásoba, způsob vyjadřování a názory dané doby. Na Hugging face jsou k dispozici modely natrénované na historických textech dostupných v oblasti Londýna mezi lety 1800 až 1875.

    NUKE GAZA! 🎆 | Komentářů: 1
    včera 17:55 | Nová verze

    Radicle byl vydán ve verzi 1.6.0 s kódovým jménem Amaryllis. Jedná se o distribuovanou alternativu k softwarům pro spolupráci jako např. GitLab.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Upozornění

    Zemřel Scott Adams, tvůrce komiksových stripů Dilbert parodujících pracovní prostředí velké firmy.

    Ladislav Hagara | Komentářů: 3
    včera 13:00 | Nová verze

    Sdružení CZ.NIC vydalo novou verzi Knot Resolveru (6.1.0). Jedná se o první vydanou stabilní verzi 6, která je nyní oficiálně preferovanou a doporučovanou verzí, namísto předešlé verze 5. Více o Knot Resolveru 6 je možné se dočíst přímo v dokumentaci.

    VSladek | Komentářů: 1
    včera 01:22 | Nová verze

    Byl vydán Linux Mint 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 1
    13.1. 21:33 | Nová verze

    Wine bylo po roce vývoje od vydání verze 10.0 vydáno v nové stabilní verzi 11.0. Přehled novinek na GitLabu. Vypíchnuta je podpora NTSYNC a dokončení architektury WoW64.

    Ladislav Hagara | Komentářů: 5
    13.1. 16:11 | Nová verze

    Byl vydán Mozilla Firefox 147.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Firefox nově podporuje Freedesktop.org XDG Base Directory Specification. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 147 bude brzy k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (5%)
     (0%)
     (8%)
     (19%)
     (3%)
     (6%)
     (3%)
     (11%)
     (44%)
    Celkem 441 hlasů
     Komentářů: 12, poslední včera 21:12
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: Kdy dávat proměnné do uozovek

    6.2.2014 12:07 Martas
    Kdy dávat proměnné do uozovek
    Přečteno: 406×
    Ahoj, nemůžu najít, kdy dávat a kdy nedávat ve scriptech bash/shell proměnné do uvozovek. poradí někdo? Děkuji

    Řešení dotazu:


    Odpovědi

    6.2.2014 12:26 podlesh | skóre: 38 | Freiburg im Breisgau
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek
    Rozhodně vždy, když se tam mohou vyskytnout whitespace (mezery apod). Ideálně vždy, pokud si nejsem opravdu 100% jistý že tam mezery fakt nejsou.
    6.2.2014 12:45 Martas
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek
    Díky a co třba tohle? Takto
    source "$(dirname $0)/foo/bar"
    nebo takto ?
    source  $(dirname $0)/foo/bar
    Díky
    6.2.2014 13:59 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek

    source "$(dirname "$0")/foo/bar" ;)

    OT: Takové source-ování nebude fungovat jak asi chceš při použití linek.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    6.2.2014 18:55 Martas
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek
    Tak že to má být bez uvozovek? Takto?
    source $(dirname $0)/foo/bar
    6.2.2014 21:11 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek
    Proč?, ne, má to být jak jsem napsal:
    source "$(dirname "$0")/foo/bar"
    Ale zjištění adresáře nebude vždy, to co si asi zamýšlíš.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    6.2.2014 21:43 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek

    Mám pocit, že tě napínám, takže příklad:

    Příprava:

    mkdir kuk
    echo -e "#\!/bin/bash\n\necho \"\$(dirname \"\$0\")/foo/bar\"\n" > kuk/do.bash
    ln -s kuk/do.bash dolink
    ln -s kuk kuklink
    chmod +x kuk/do.bash
    

    Test:

    ./kuk/do.bash
    ./dolink 
    ./kuklink/do.bash 
    

    Otázka:
     Chceš to tak?

    Úklid:

    rm ./dolink
    rm ./kuk/do.bash
    rm ./kuklink
    rmdir kuk
    

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    7.2.2014 01:00 Martas
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek
    Tak to jsem ted zcela v prdli :-( Můžeš ještě jednou co se snažíš říct - pro blba? Díky
    7.2.2014 08:28 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek

    Výstup z těch ukázek:

     $ ./kuk/do.bash     -> ./kuk/foo/bar       - OK
     $ ./dolink          -> ./foo/bar           - ???
     $ ./kuklink/do.bash -> ./kuklink/foo/bar   - OK!
    

    1. OK - standard
    2. Pokud budeš source-ovat script, který je ve stejném adresáři, jako ten script co spoustíš, tak ho takto nenajde, bo ho hledá jinde.
    3. Do vnořených adresářů OK, ale základní adresář scriptu není „kuk“ - jen ukázka chování.

    „¡Studenti! pokud nechápe výklad je chyba přednášejícího, ne vaše …rozumíte tomu?“…

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    6.2.2014 12:48 Semo | skóre: 45 | blog: Semo
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek
    Vzdy. Okrem miest, kde velmi dobre vies, preco by tam byt nemali.
    If you hold a Unix shell up to your ear, you can you hear the C.
    6.2.2014 17:06 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek

    Kromě případu, kdy chceš z proměnné s mezerami vytvořit pole, je vhodné mít uvozovky v podstatě všude. Možná se najde ještě pár dalších exotických situací, kde se uvozovky nehodí, ale moc jich nebude.

    text='a b c d e'
    tokens=(${text})              # Tohle je ten speciální případ.
    other_tokens=("${tokens[@]}") # Kopírování pole má uvozovky.
    

    Složené závorky jsou u proměnných, které nejsou pole, v podstatě dobrovolné, ale většinou je používám. Přijdou vhod třeba v případě, kdy člověk změní "${text} s mezerami" na "${text}bez_mezer", protože zatímco "$text s mezerami" funguje podle očekávání, "$textbez_mezer" se se značnou pravděpodobností rozexpanduje na velké kulové.

    Následuje ještě jeden příklad s poli a s uvozovkami. Expanze ${words[@]} a ${words[*]} dělají mimo uvozovky totéž, ale v uvozovkách se chovají odlišně.

    words=(' a  b ' ' c  d ')
    for word in ${words[*]}; do echo "${word}" \| ${word}; done        # 4 řádky
    for word in ${words[@]}; do echo "${word}" \| ${word}; done        # 4 řádky
    for word in "${words[@]}"; do echo "${word}" \| ${word}; done        # 2 řádky
    for word in "${words[*]}"; do echo "${word}" \| ${word}; done        # 1 řádek
    
    Zajímavé je též pořadí expanze v shellu — na první pohled nemusí být zřejmé, že přidání uvozovek do následujícího příkladu vůbec nic nezmění.
    quotes=('"' '"' '"');
    for i in ${quotes[@]}; do echo $i; done
    
    6.2.2014 18:08 potato
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek
    Možná se najde ještě pár dalších exotických situací, kde se uvozovky nehodí
    Exotických situací jako když máš v proměnné několik voleb programu?

    Ano, používat uvozovky všude, kde není zapotřebí word splitting, neškodí. Škodlivý je ovšem názor, že chtěný word splitting je cosi exotického. Je to příznak velkolepého formálního programování v shellu (ve srovnání se skriptováním), při kterém se nevyužívají silné stránky shellu, zato se složitě matlají věci, které ve vhodnějším jazyce fungují mnohem lépe.
    6.2.2014 20:28 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Kdy dávat proměnné do uozovek

    Na druhé straně není nic horšího než matlání skriptů, které selžou při první neočekávané mezeře. Viděl jsem takových dost na to, abych byl skalním příznivcem uvozovek. Když chci mít v jedné proměnné víc optionů, je spousta důvodů pro použití pole, ve kterém se například option obsahující mezeru nerozdělí na dva. Pokud parsuju strukturovaná data, u kterých vím naprosto jistě, co je oddělovač a co ne, je to samozřejmě zcela jiná situace. Nejhorší je expandovat obyčejnou proměnnou obsahující parametry příkazové řádky, které mohou obsahovat jména souborů, která mohou obsahovat téměř libovolné bílé místo.

    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.