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

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
dnes 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 3
včera 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

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

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 4
20.1. 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 8
20.1. 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
20.1. 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
20.1. 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
20.1. 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 355 hlasů
 Komentářů: 25, poslední včera 13:34
    Rozcestník
    Reklama

    Dotaz: Cast skriptu..kontrola parametru a IF

    6.6.2005 17:32 xhonzax | skóre: 1
    Cast skriptu..kontrola parametru a IF
    Přečteno: 76×
    Potrebuju aby tato cast skriptu zkontrolovala jestli uzivatel, ktery je zadavan jako parametr skriptu existuje nebo jestli bylo zadano all...jinak konec s chybobou hlaskou>>

    if test $1 != "cat /etc/passwd | grep ^[^:]*:[^:]*:[^:]*|cut -f 1 -d ":"" || test $1 != all
    then
    echo "Zadali jste uzivatele, ktery neexistuje, tudiz nespustil zadne procesy"
    exit
    fi

    Toto mi nefunguje, jak to upravit? Diky moc za odpovedi Honza

    Odpovědi

    6.6.2005 17:48 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    "cat /etc/passwd | grep ^[^:]*:[^:]*:[^:]*|cut -f 1 -d ":""
    je nesmysl, to se expanduje na ten řetězec v uvozovkách, měls asi na mysli $(...) nebo `...`, i tak by to moc nefungovalo.

    No nic, nejlepší co jsem vymyslel je
    if cut -d: -f1 | grep -F -x -q "$1"; then
      echo "OK"
    else
      echo "neexistuje"
    fi
    
    najdi si v man grep co ty optiony znamenají (btw asi nebudou přenositelné)

    Aby to bylo skutečně korektní, tak by to chtělo C prográmek, co zavolá getpwnam(argv[1]).
    6.6.2005 17:49 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    cut -d: -f1 /etc/passwd samozřejmě.
    6.6.2005 17:58 xhonzax | skóre: 1
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Dekuju. Funguje to.
    6.6.2005 21:08 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Vím, že na Python se tu nikdo neptal, ale funguje mi tohle:
    #!/usr/bin/env python
    import pwd
    
    user = 'all'
    
    if (cmp(user,'all')):
      try:
        print pwd.getpwnam(user)
      except KeyError:
        print "Tento uzivatel neexistuje"
    else:
      print "Tohle se tyka vsech uzivatelu"
    
    Odteďka chci mít všude login "all" ;-)
    6.6.2005 21:46 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    IMHO to děláte zbytečně složitě, stačí využít návratový kód (e)grepu:
    if egrep -q "^${1}:" /etc/passwd || [ "x$1" = xall ]; then
      echo OK
    else
      echo chyba
    fi
    
    6.6.2005 22:06 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Tohle je zase až moc jednoduše, nehlídá to tečky a pod. v "$1" ("regexp injection"? :-)).
    6.6.2005 22:36 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    OK, OK, tak se z toho nejdřív vyházejí nepohodlné znaky:
      x=`echo "$1" | LC_CTYPE=C tr -cd '[a-zA-Z0-9_]'`
      if [ "x$1" != "x$x" ];
        echo "Nech toho, darebáku, sic ti hnáty zpřerážím!" # :-)
        exit 1
      fi
    

    Na druhou stranu, kdyby si s tím člověk trochu pohrál, mohl by v tom být i určitý záměr: mohl by se zadávat regulární výraz a hledaly by se procesy kteréhokoli uživatele, který mu vyhovuje (nebo co to měl ten skript dělat)… :-)

    7.6.2005 00:45 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    :-)

    BTW, nevíte kde má původ ten zápis
    test "x$param" = "xvalue"
          ^           ^
    
    ? Používá to i Autoconf, takže asi existoval systém, kde nefungoval test s prázdným parametrem, ale netuším jaký (PDP-11 ve škole nemáme :-)).
    7.6.2005 00:58 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Ten problém není AFAIK kvůli prázdným parametrům, ale kvůli parametrům, které vypadají jako standardní podmínky příkazu test. Nějak se mi ale nedaří vyrobit nějaký dostatečně úderný příklad ('test -e = -f' i 'test -e = -e' mi kupodivu fungují správně s interním i externím testem).
    7.6.2005 01:19 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    A jo. GNU test, bash, ash a pdksh (víc toho u sebe nemám) se chovají podle očekávání; našel jsem tohle
    $ uname -srv 
    IRIX64 6.5 04091957
    $ /usr/bin/test -n = blabla; echo $?
    0
    
    Takže smysl to asi má pořád.
    7.6.2005 10:53 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
      x=`echo "$1" | LC_CTYPE=C tr -cd '[a-zA-Z0-9_]'`
      if [ "x$1" != "x$x" ];
        echo "Nech toho, darebáku, sic ti hnáty zpřerážím!" # :-)
        exit 1
      fi
    
    To se nám to krásně zjednodušilo. Až na ten fork, fork, exec a přitom je to úplně zbytečné.
    case "$1" in
        *[^a-zA-Z0-9_]*)
             echo "Nech toho, darebáku, sic ti hnáty zpřerážím!" # :-)
             exit 1;;
    esac
    To je ekvivalent uvedeného, ale víc jak 20x rychlejší. Nechce hledat přesné omezení na username abych to napsal přesněji.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    7.6.2005 11:28 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Bez case je to ještě jednodušší
    [[ "$1" == *[^a-zA-Z0-9_]* ]] && {
      echo "Nech toho, darebáku, sic ti hnáty zpřerážím!" # :-)
      exit 1
    }
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    7.6.2005 13:06 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Všichni jste ostudy. Nikoho nenapadlo použít to nejjednodužší a nejbezpečnější řešení.
    if ! id "$1" >&/dev/null && [ "x$1" != xall ]
    then
        echo "Zadali jste uzivatele, ktery neexistuje, tudiz nespustil zadne procesy"
        exit 1
    fi
    P.S.: Ano, opravdu tam má být && a ne || protože chyba nastane, když uživatel není a zároveň není zadáno all.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    7.6.2005 13:26 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Sakra :-) já věděl, že něco takového musí existovat, ale odradil mě finger
    $ finger chroustal; echo $?
    finger: chroustal: no such user.
    0
    
    7.6.2005 13:40 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Já jsem jsem přesvědčený, že jsem někde viděl utilitu, která byla ekvivalentem getpwnam(3), ale nemůžu se teď spomenout ani ji nikde najít. To přece není možné aby taková utilita nebyla. To by bylo padlé nahlavu, přece nebudu při zjišťování uživatelova shellu parsovat passwd(5). Nehledě na to, že tam taky vůbec nemusí být.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    7.6.2005 18:45 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Přinejhorším by nebyl problém si ji za chvíli napsat…
    7.6.2005 18:50 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    No jo, něco v tom duchu mne napadlo, jenže jsem zkoušel laborovat s něčím ve stylu ~$1, ale když jsem zjistil, že pořadí expanzí je opačné, než bych potřeboval, opustil jsem tuto cestu a vrhnul se na parsování /etc/passwd. Na druhou stranu, v praxi bych to asi stejně radši napsal v céčku…

    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.