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 11:11 | Zajímavý článek

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

    Ladislav Hagara | Komentářů: 0
    dnes 10:44 | Nová verze

    Po delší době vývoje vyšla nativní linuxová verze virtuálního bubeníka MT-PowerDrumKit 2 ve formátu VST3. Mezi testovanými hosty jsou Reaper, Ardour, Bitwig a Carla.

    balda | Komentářů: 1
    včera 21:33 | Nová verze

    Desktopové prostředí Budgie bylo vydáno ve verzi 10.10. Dokončena byla migrace z X11 na Wayland. Budgie 10 vstupuje do režimu údržby. Vývoj se přesouvá k Budgie 11. Dlouho se řešilo, v čem bude nové Budgie napsáno. Budgie 10 je postaveno nad GTK 3. Přemýšlelo se také nad přepsáním z GTK do EFL. Budgie 11 bude nakonec postaveno nad Qt 6.

    Ladislav Hagara | Komentářů: 0
    včera 13:00 | Humor

    OpenChaos.dev je 'samovolně se vyvíjející open source projekt' s nedefinovaným cílem. Každý týden mohou lidé hlasovat o návrzích (pull requestech), přičemž vítězný návrh se integruje do kódu projektu (repozitář na GitHubu). Hlasováním je možné změnit téměř vše, včetně tohoto pravidla. Hlasování končí vždy v neděli v 9:00 UTC.

    NUKE GAZA! 🎆 | Komentářů: 3
    včera 03:00 | Nová verze

    Byl vydán Debian 13.3, tj. třetí opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.13, tj. třináctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    10.1. 03:00 | Komunita

    Na stránkách Evropské komise, na portálu Podělte se o svůj názor, se lze do 3. února podělit o názor k iniciativě Evropské otevřené digitální ekosystémy řešící přístup EU k otevřenému softwaru.

    Ladislav Hagara | Komentářů: 6
    9.1. 19:44 | Zajímavý software

    Společnost Kagi stojící za stejnojmenným placeným vyhledávačem vydala (𝕏) alfa verzi linuxové verze (flatpak) svého proprietárního webového prohlížeče Orion.

    Ladislav Hagara | Komentářů: 5
    9.1. 19:11 | IT novinky

    Firma Bose se po tlaku uživatelů rozhodla, že otevře API svých chytrých reproduktorů SoundTouch, což umožní pokračovat v jejich používání i po plánovaném ukončení podpory v letošním roce. Pro ovládání také bude stále možné využívat oficiální aplikaci, ale už pouze lokálně bez cloudových služeb. Dokumentace API dostupná zde (soubor PDF).

    NUKE GAZA! 🎆 | Komentářů: 2
    9.1. 14:22 | Zajímavý článek

    Jiří Eischmann se v příspěvku na svém blogu rozepsal o open source AdGuard Home jako domácí ochraně nejen před reklamou. Adguard Home není plnohodnotným DNS resolverem, funguje jako DNS forwarder s možností filtrování. To znamená, že když přijme DNS dotaz, sám na něj neodpoví, ale přepošle ho na vybraný DNS server a odpovědi zpracovává a filtruje dle nastavených pravidel a následně posílá zpět klientům. Dá se tedy používat k blokování reklamy a škodlivých stránek a k rodičovské kontrole na úrovni DNS.

    Ladislav Hagara | Komentářů: 7
    9.1. 03:33 | Zajímavý software

    AI Claude Code od Anthropicu lépe rozumí frameworku Nette, tj. open source frameworku pro tvorbu webových aplikací v PHP. David Grudl napsal plugin Nette pro Claude Code.

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (8%)
     (4%)
     (0%)
     (9%)
     (20%)
     (3%)
     (5%)
     (3%)
     (11%)
     (49%)
    Celkem 381 hlasů
     Komentářů: 9, poslední dnes 18:09
    Rozcestník

    Dotaz: Proč mi tohle nefunguje: escaping v BASHi

    28.5.2007 14:35 Lukáš Zapletal | skóre: 42 | blog: lzapův svět | Olomouc
    Proč mi tohle nefunguje: escaping v BASHi
    Přečteno: 233×
    Nemohu přijít na to, proč se mi proměnná špatně expanduje... Program find pak nepracuje, jak bych čekal (měl by přeskočit všechny řádky začínající na /tmp).
    # find /tmp -not -iregex '^/tmp.*'
    # PARAM="-not -iregex '^/tmp.*'"
    # find /tmp $PARAM
    /tmp
    /tmp/.ICE-unix
    /tmp/backup.cpio
    /tmp/mc-root
    /tmp/.font-unix
    /tmp/.font-unix/fs7100
    # echo $PARAM
    -not -iregex '^/tmp.*'

    Odpovědi

    28.5.2007 14:53 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    <14:53:25> find /tmp -not -iregex '^/tmp.*'
    <14:53:52> PARAM='-not -iregex ^/tmp.*'
    <14:54:14> find /tmp $PARAM
    <14:54:23>
    
    28.5.2007 14:55 Lukáš Zapletal | skóre: 42 | blog: lzapův svět | Olomouc
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    Bez apostrofu to funguje, ale v praxi tam potrebuji dat daleko slozitejsi vyraz a escapovat pro bash se mi teda moc nechce...
    28.5.2007 15:02 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    ... a escapovat pro bash se mi teda moc nechce...
    Je uplne jedno ci sa Ti to chce alebo nie. ;-) Kolega ma teoriu, ze kazdy problem z regexpami treba zacat riesit zdvojnasobovanim poctu spatnych lomitok. No ale mam tu aj skript, kde na prepasovanie jedneho spatneho lomitka cielovemu programu je potrebnych 10 spatnych lomitok v skripte.
    28.5.2007 15:18 Lukáš Zapletal | skóre: 42 | blog: lzapův svět | Olomouc
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    Já mám zase teorii, že když je někde 10 zpětných lomýtek kvůli escapingu, tak je určitě něco špatně :-)

    Díky
    28.5.2007 14:59 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    Vzdy je dobre napisat to do skriptu a shell-u podhodit -x, t.j. napisat skript z hlavickou
    #! /bin/sh -x
    
    28.5.2007 15:10 Marble | skóre: 27 | blog: marble
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    Bez záruky přesného vysvětlení ... $PARAM se pravděpodobně předá jako jeden parametr, shell už jej nerozdělí na tři. Pokud je akceptovatelné omezení na konkrétní shell, třeba bash, tak řešení je pole:

    PARAM=(-not -iregex '^/tmp.*'); find /tmp ${PARAM[@]}

    ${PARAM[@]} expanduje právě na řadu oddělených položek z pole.

    28.5.2007 15:16 Lukáš Zapletal | skóre: 42 | blog: lzapův svět | Olomouc
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    Ano, to je ono! Zmátlo mě, že když napíšu

    find /tmp "-not -iregex '^/tmp.*'"

    tak find vrátí

    find: invalid predicate `-not -iregex '^/tmp.*''

    A tedy že pokud by to předalo v jednom parametru, tak by to psal také. Nevím, proč find tuto chybu nehlásil, nicméně s kulatými závorkami to funguje. Díky!
    28.5.2007 15:24 Marble | skóre: 27 | blog: marble
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    Chybu nenahlásil protože viz příspěvek o kousek níž. Právě mi to před chvíli došlo, že kdyby bylo předchozí vysvětlení správně, tak by tam musela být ona chybová hláška. Takže se omlouvám za zmatek a to dole už je snad správně. :-)
    28.5.2007 15:22 Marble | skóre: 27 | blog: marble
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    Aha, tak se omlouvám, vysvětlení je blbě. Postup s polem sice funguje, ale není to zdůvodnění proč to nešlo předtím ... Takže pokus o správné vysvětlení, když už jsem s tím začal. String se expanduje jen při přiřazení, ne při použití. Takže shell při přiřazení odstraní vnější uvozovky, ale nechá ty jednoduché, které prolezou až do regexpu. Takže platí to, co bylo napsáno jako první příspěvek. Jen jedna úroveň vnoření uvozovek a nic navíc se při použití už expandovat nebude, takže netřeba nic dál escapovat.
    28.5.2007 15:32 Lukáš Zapletal | skóre: 42 | blog: lzapův svět | Olomouc
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    Ještě jednou díky. To vysvětlení jsem ale bohužel nepochopil :-(

    Co bych tedy měl napsat, abych nemusel používat pole? Celé to uvodit ještě do jedněch uvozovek?

    String se expanduje jen při přiřazení, ne při použití. -- jak mám rozumnět tomuhle? Když dám přeci

    echo $PARAMS

    tak to vypíše ty parametry správně, tudíž se tedy expanduje, nebo ne?

    Díky za zpřesnení
    28.5.2007 16:38 Marble | skóre: 27 | blog: marble
    Rozbalit Rozbalit vše Re: Proč mi tohle nefunguje: escaping v BASHi
    OK, já v tom totiž také dělam pořád poněkud zmatek ... :-/ To co vypíše echo v úvodní otázce je špatně protože tam nemají být ty jednoduché uvozovky. Teď jde o to, jak se jich slušně zbavit. To, co jsme myslel já je něco ve stylu
    # a=a; b=b:$a; a=c; echo $b:$a
    b:a:c
    
    Ale ono to pro expanzi cest neplatí, jak jsme si myslel, protože ta se koná až úplně na konci po expanzi proměnných ... takže když tam z nějaké proměnné vypadne hvězdička, tak ta se ještě potom expanduje, což jsem předtím myslel, že ne.

    No stručně řečeno, mám v tom sám pěkný borčus, jak zjišťuju. Odvolávám, co jsme odvolal a řešení s polem je asi nejlepší. Jen jsem tam myslím nakonec zapomněl uvozovky, správně je to takhle:

    # PARAMS=(-not -iregexp '*'); echo "${PARAMS[@]}"
    -not -iregexp *
    
    Bez uvozovek na konci by se hvězdička ještě expandovala. Uvozovky v PARAMS= zas zajistí, že se nebude expandovat při přiřazení. Jak jedny tak druhé uvozovky nakonec zmizí.

    Řešení bez pole a bez nutnosti vše escapovat mě teď nenapadá. Protože pokud má být v proměnné víc oddělených parametrů, je nutné ji přesvěčit, aby se jako celek rozsekala (takže ji nejde dát při použití celou do uvozovek), ale zároveň aby se neexpandovaly kusy uvnitř a zároveň aby v ní nezustaly žádné přebytečné uvozovky. A to mě fakt nenapadá jak.

    Totiž, ono ten tvůj původní kód má ještě jednu zradu:

    # touch \'pokus\'
    # ls
    a.txt  b.txt  c.txt  'pokus'
    # PARAMS="-not -iregexp '*'"; echo $PARAMS
    -not -iregexp 'pokus'
    
    tedy dokonce ani korektně neescapuje. Teď už fakt nevím přesně proč, ale zdá se, že uvozovka vypadlá z expanze proměnné se chová jako literal uvozovka a ne jako escape. Takže IMO to bez pole nijak normálně nejde. Dokonce i důsledné escapování se chová divně:
    # touch \\pokus
    # ls
    \pokus
    # PARAMS="-not -iregexp \*"; echo $PARAMS
    -not -iregexp \*
    
    Tady už fakt nechápu, proč tam zároveň zůstal backslash a zároveň nechytl ten soubor, co skutečně začíná backslashem ...

    No, měl jsem pocit, že bash celkem chápu, ale zdá se, že moc ne ... :-))

    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.