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 14:11 | IT novinky

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 0
    dnes 12:44 | Zajímavý software

    Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.

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

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    včera 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 5
    včera 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    včera 04:22 | Nová verze

    Byla vydána nová verze 1.25 programovacího jazyka Go (Wikipedie). Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    12.8. 13:44 | Nová verze

    Byla vydána beta verze Linux Mintu 22.2 s kódovým jménem Zara. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze novou XApp aplikaci Fingwit pro autentizaci pomocí otisků prstů nebo vlastní fork knihovny libAdwaita s názvem libAdapta podporující grafická témata. Linux Mint 22.2 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 0
    12.8. 13:00 | IT novinky

    Provozovatel internetové encyklopedie Wikipedie prohrál v Británii soudní spor týkající se některých částí nového zákona o on-line bezpečnosti. Soud ale varoval britského regulátora Ofcom i odpovědné ministerstvo před zaváděním přílišných omezení. Legislativa zpřísňuje požadavky na on-line platformy, ale zároveň čelí kritice za možné omezování svobody slova. Společnost Wikimedia Foundation, která je zodpovědná za fungování

    … více »
    Ladislav Hagara | Komentářů: 2
    12.8. 12:55 | Nová verze

    Byla vydána verze 2.0.0 nástroje pro synchronizaci dat mezi vícero počítači bez centrálního serveru Syncthing (Wikipedie). Přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 3
    12.8. 12:33 | IT novinky

    Americký prezident Donald Trump se v pondělí osobně setkal s generálním ředitelem firmy na výrobu čipů Intel Lip-Bu Tanem. Šéfa podniku označil za úspěšného, informují agentury. Ještě před týdnem ho přitom ostře kritizoval a požadoval jeho okamžitý odchod. Akcie Intelu v reakci na schůzku po oficiálním uzavření trhu zpevnily asi o tři procenta.

    Ladislav Hagara | Komentářů: 14
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (52%)
     (18%)
     (4%)
     (5%)
     (3%)
     (1%)
     (1%)
     (16%)
    Celkem 390 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    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: 398×
    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.