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 12:33 | Zajímavý projekt

    MALUS je kontroverzní proprietarní nástroj, který svým zákazníkům umožňuje nechat AI, která dle tvrzení provozovatelů nikdy neviděla původní zdrojový kód, analyzovat dokumentaci, API a veřejná rozhraní jakéhokoliv open-source projektu a následně úplně od píky vygenerovat funkčně ekvivalentní software, ovšem pod libovolnou licencí.

    NUKE GAZA! 🎆 | Komentářů: 11
    dnes 03:55 | Bezpečnostní upozornění

    Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.

    Ladislav Hagara | Komentářů: 2
    včera 17:22 | Nová verze

    Byla vydána nová verze 19 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 0
    včera 03:44 | Nová verze

    Bitwig Studio (Wikipedie) bylo vydáno ve verzi 6. Jedná se o proprietární multiplatformní (macOS, Windows, Linux) digitální pracovní stanici pro práci s audiem (DAW).

    Ladislav Hagara | Komentářů: 4
    včera 02:11 | Komunita

    Společnost Igalia představila novou linuxovou distribuci (framework) s názvem Moonforge. Jedná se o distribuci určenou pro vestavěné systémy. Vychází z projektů Yocto a OpenEmbedded.

    Ladislav Hagara | Komentářů: 0
    včera 00:44 | Nová verze

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

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

    D7VK byl vydán ve verzi 1.5. Jedná se o fork DXVK implementující překlad volání Direct3D 3 (novinka), 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

    Ladislav Hagara | Komentářů: 0
    11.3. 23:22 | Nová verze

    Bylo vydáno Eclipse IDE 2026-03 aneb Eclipse 4.39. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 4
    11.3. 10:22 | Upozornění

    Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.

    Ladislav Hagara | Komentářů: 14
    11.3. 10:11 | IT novinky

    Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.

    Ladislav Hagara | Komentářů: 36
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (25%)
    Celkem 1067 hlasů
     Komentářů: 26, poslední včera 08:56
    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: 407×
    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.