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í
×
    včera 15:11 | IT novinky

    Evropská komise naléhavě vyzvala členské státy EU, aby kvůli ochraně nezletilých na internetu urychlily zavádění unijní aplikace pro ověřování věku a zajistily její dostupnost do konce roku. Členské státy mohou zavést aplikaci EU pro ověřování věku jako samostatnou aplikaci nebo ji integrovat do takzvané evropské peněženky digitální identity.

    Ladislav Hagara | Komentářů: 10
    30.4. 23:33 | Nová verze

    Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    30.4. 23:11 | Nová verze

    Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    30.4. 12:11 | IT novinky

    Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.

    Ladislav Hagara | Komentářů: 23
    30.4. 11:44 | Komunita

    Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.

    Ladislav Hagara | Komentářů: 0
    30.4. 01:11 | IT novinky

    Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.

    Ladislav Hagara | Komentářů: 57
    29.4. 23:44 | Bezpečnostní upozornění

    Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.

    Ladislav Hagara | Komentářů: 4
    29.4. 17:44 | Nová verze

    Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    29.4. 04:44 | Komunita

    Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.

    Ladislav Hagara | Komentářů: 7
    29.4. 03:55 | Nová verze

    VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (2%)
     (13%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (25%)
    Celkem 1472 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník
    Štítky: není přiřazen žádný štítek


    Vložit další komentář
    15.6.2013 16:11 iwk
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    15.6.2013 17:43 JS
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Napada me, a prevest to na lookup table by neumel?
    15.6.2013 18:07 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    To me napadlo jako prvni, jestli to nedela v ramci te hruzi generovane s -O3... ale vypada to, ze ne. Na druhou stranu ma predpocitany vektor cisel (radek 2e), ktery pak pouziva k dalsimu nasobeni, takze mozna by to zvladl, ale nechce se mu.
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    15.6.2013 18:02 disorder | blog: weblog
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    o tomto som tiez pisal blog pred 3 rokmi, ked som sa k tomu dostal niekde cez reddit. implementovane to je v tree-tailcall.c

    ale podla standardu sa na to neda spoliehat (a to prekvapivo ani v common lispe)
    15.6.2013 18:30 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    o tomto som tiez pisal blog pred 3 rokmi, ked som sa k tomu dostal niekde cez reddit.

    Občas se vracím k tématům, o kterých jsme už v Receptáři hovořili. Není divu, každý se nemůže dívat na všechny pořady. Tak třeba paní Emilie Bezoušková...
    implementovane to je v tree-tailcall.c
    Diky za info, presne tohle jsem chtel vedet. Cekal jsem, ze to bude sofistikovanejsi a vychazet primo z vnitrni SSA reprezentace.
    ale podla standardu sa na to neda spoliehat (a to prekvapivo ani v common lispe)
    V CommonLispu se podle standardu neda spolehat ani na ty tail cally.
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    15.6.2013 19:50 Kvakor
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Je sice hezké, že překladač je dost chytrý na to, aby sám převáděl rekurze na cykly, ale když se objeví nějaké chybky, tak skutečnost, že neoptimalizovaný kód, který používá k ladění, se silně liší od optimalizovaného, může být za určitých okolností docela prolbematická ... Na druhou stranu, v C/C++ nejspíš nikdo takové věci stejně dělat nebude a v jiných jazycích to tolik nevadí, protože se o to postarají prostředky samotného jazyka i bez optimalizace.

    PS: Ty oprefixované NOPy (obvlášť ten v poslední verzi vygenerované přes -O3) mně dostaly :-) I když pro moderní procesory je nejspíš lepší nacpat několik prefixů před jeden NOP než tam dát více "jednoduchých" NOPů, například pokud dekodér dokáže zahazovat nesmyslné prefixy.
    15.6.2013 20:23 Radek Miček | skóre: 23 | blog: radekm_blog
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    a v jiných jazycích to tolik nevadí, protože se o to postarají prostředky samotného jazyka i bez optimalizace.
    V některých jazycích to jde vypnout – zejména kvůli ladění (např. v F#, k němuž se vztahovala původní diskuze).
    16.6.2013 16:28 kralyk z abclinuxu | skóre: 29 | blog:
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Je sice hezké, že překladač je dost chytrý na to, aby sám převáděl rekurze na cykly, ale když se objeví nějaké chybky, tak skutečnost, že neoptimalizovaný kód, který používá k ladění, se silně liší od optimalizovaného, může být za určitých okolností docela prolbematická...
    To ano, ovšem v GCC by mělo jít nějakým CFLAG zapnout jednu konkrétní optimalizaci, ne? Případně by mělo jít debugovat optimalizovaný kód apod...
    PS: Ty oprefixované NOPy (obvlášť ten v poslední verzi vygenerované přes -O3) mně dostaly :-)
    Kvůli čemu tam je? Zarovnání?

    Jinak jednoduché NOPy se afaik nevidí už vlastně nikdy (na x86), pokud najdeš v binárce jednoduché NOPy, nejspíš se v ní někdo hrabal ;-)
    16.6.2013 17:03 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Kvůli čemu tam je? Zarovnání?
    Jo, kvuli zarovnani. AMD64 ma instrukcni cache o velikosti 16B, takze ma rado, kdyz jsou skoky zarovnane na 16B. Teoreticky by mely jit pouzit slozitejsi NOP i pro prefetch, ale na to mi prijde rozumnejsi pouzit primo instrukce prefetchX z SSE.
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    16.6.2013 17:08 pc2005 | skóre: 38 | blog: GardenOfEdenConfiguration | liberec
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    AMD64 ma instrukcni cache o velikosti 16B
    Jako velikost jednoho cacheline?
    16.6.2013 19:06 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    jasne, samozrejme, ze cacheline...
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    16.6.2013 19:27 pc2005 | skóre: 38 | blog: GardenOfEdenConfiguration | liberec
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Myslel jsem si to i když napoprvé jsem si to chybně dekódoval jako velikost prefetch queue u 386 :-D.
    16.6.2013 19:24 pc2005 | skóre: 38 | blog: GardenOfEdenConfiguration | liberec
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Ty oprefixované NOPy (obvlášť ten v poslední verzi vygenerované přes -O3) mně dostaly
    On je zajímavej i ten "repz ret". Tipoval bych to na ten prefetch jak psal deda.jabko. Pro ostatní co neví (;-)): "rep" je prefix cyklu a "ret" je návrat, takže tipuju, že mikrokód si při "rep" myslí, že nastane cyklus a další instrukci po "ret" nenačte, což je výhoda, protože se stejně bude skákat pryč (pro ty co ví: jak moc jsem se seknul? :-D).

    Jinak ona je x86 tak šílená, že jí jednak nestačej volný hodnoty pro nový opkód a jednak se používaj různý kombinace i pro další věci. Například instrukce pause, což je vlastně jen sekvence dříve přeložitelná jako "rep nop". V Intelu to dělali už od začátku, schválně kdo bez internetu uhodne, co dělal původně na 80(1)86 opkód 0x0f (od zavedení chráněného módu jako prefix pro nové instrukce)? :-)

    Jinak podobné legrácky, co používá kompilátor, jsou popsané taky tady.
    16.6.2013 17:37 Jiří Veselský | skóre: 30 | blog: Jirkovo | Ostrava
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi

    Jakó... To mi zní dost jako černá magie. Evidentně udělaly optimalizační metody v překladačích kus cesty kupředu od dob, kdy nás o nich nesměle učili, jak jakože umí třeba občas za vhodnej okolností vytáhnout mimo cyklus invariant... :)

    Což o to, pokrok jde kupředu, ale todle mi přijde už fakt jako hodně moc. To je skoro jako kdyby ten překladač věděl, že počítáte faktoriál a prostě to celé udělal jinak, lépe a radostněji. Myslím tu poslední verzi. To mi jako někdo vysvětlete, jak todle pozná. Pochopit co dělá cizí zdroják je kolikrát problém pro člověka, ne tak pro stroj... :D

    16.6.2013 17:59 kralyk z abclinuxu | skóre: 29 | blog:
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    To je skoro jako kdyby ten překladač věděl, že počítáte faktoriál a prostě to celé udělal jinak, lépe a radostněji.
    A za chvíli ti řekne, aby sis s tou vázou nedělal starosti ;-)

    Ne, váženě, ten překladač neví, že počítáš faktoriál, ale ví, že něco cyklicky děláš pomocí tail callu, a tak to převede to na cyklus.

    Převádět rekurzi na cyklus a naopak jsme se učili někdy v druháku na střední v Packalu, takže jsem si jist, že pro moderní překladač to není problém....
    16.6.2013 18:59 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Ne, váženě, ten překladač neví, že počítáš faktoriál, ale ví, že něco cyklicky děláš pomocí tail callu,
    Vtip je v tom, ze v tom prikladu neni pouzity tail call, a presto to prekladac dokazal prelozit jako cyklus.
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    16.6.2013 20:39 kralyk z abclinuxu | skóre: 29 | blog:
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Kouknul jsem na to, je to popsaný hned na začátku v komentářích v tom tree-tailcall.c.

    V kostce: on pracuje s tail callem ve tvaru (obecně) return a + m * func(...);, kde a ani m nezávisí na výsledku toho tail volání. Předeve to na cyklus s akumulátory (zvlášť pro aditivní a multiplikativní proměnnou podle potřeby). Klasický tail call (tedy return func(...);) je pouze specielním případem, kdy a = 0, m = 1, tedy bez akumulátoru.

    Chytrej trik.
    16.6.2013 18:03 xxar3s
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Rekurzia sa prelozi na cyklus iba ked ako poslednu funkcia vola samu seba, tzn tail call.

    tento map sa prelozi ako rekurzia, pri velkych zoznamoch hrozi stackoverflow:
    let rec map mapper = function
    | [] -> []
    | x::xs -> mapper x :: (map mapper xs)
    tento map sa prelozi ako cyklus:
    let map mapper list =
        let rec map mapper acc = function
        | [] -> acc
        | x::xs -> xs |> map mapper (mapper x :: acc)
        list |> map mapper [] |> List.rev
    16.6.2013 19:01 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Pointou toho celeho blogu bylo, ze tohle tvrzeni uplne neplati a prekladace dokazou i ten prvni typ rekurze prevest na cyklus.
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    16.6.2013 22:00 xxar3s
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Niektore hej, bohuzial fsc toto zatial nepodporuje.
    16.6.2013 20:24 Radek Miček | skóre: 23 | blog: radekm_blog
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    tento map sa prelozi ako rekurzia, pri velkych zoznamoch hrozi stackoverflow:
    Záleží na sémantice a implementaci. Např. v GHC Haskellu by byla preferována první verze.
    tento map sa prelozi ako cyklus:
    Bohužel toto řešení není příliš efektivní a ani přehledné.
    16.6.2013 21:57 xxar3s
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Pridal som ešte tretí map (používa kontinuácie, takže nepotrebuje List.rev, ale pritom je tail-rekurzívny):
    let rec map1 mapper = function
    | [] -> []
    | x::xs -> mapper x :: (map1 mapper xs)
    
    let map2 mapper list =
        let rec map mapper acc = function
        | [] -> acc
        | x::xs -> map mapper (mapper x :: acc) xs
        List.rev (map mapper [] list)
    
    let map3 mapper list =
        let rec map3 cnt mapper = function
        | [] -> cnt []
        | x::xs -> map3 (fun l -> cnt (mapper x :: l)) mapper xs
        map3 id mapper list
    Podľa môjho testu:

    map1: 3610 ms
    map2: 2976 ms
    map3: 3521 ms

    je ten druhý map najrýchlejší (presne ako som očakával), ten prvý pri väčších zoznamoch vyhadzuje stackoverflow.
    16.6.2013 23:31 Radek Miček | skóre: 23 | blog: radekm_blog
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    To měříte F#, že?

    Osobně bych čekal, že na krátkých seznamech bude nejrychlejší (z těch 3) ta první implementace. Pokud se vám chce, tak můžete změřit ještě knihovní List.map. Pro OCaml jsou nějaká měření v článku Optimizing List.map.
    16.6.2013 19:57 pc2005 | skóre: 38 | blog: GardenOfEdenConfiguration | liberec
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Docela mě zaujalo, že tam jsou ty returny duplicitní a i v tom posledním (-O3) kódu je nepodmíněný skok (=další instrukce dosažitelná jen dalším jmp) a za ním return. Klidně by šlo imho volat nějakej již existující.

    P.S. Pojďme si porovnávat (kompilátory!) :-D

    gcc (GCC) 4.7.1 z aktuálního Slackware (vím, nemám 64bit OS :-( ). Kompilace přes "gcc -c zzzzzzzzzzzzz.c -O0" atd.

    -O0
    00000000 <fact_rec>:
       0:	55                   	push   %ebp
       1:	89 e5                	mov    %esp,%ebp
       3:	83 ec 18             	sub    $0x18,%esp
       6:	83 7d 08 00          	cmpl   $0x0,0x8(%ebp)
       a:	75 07                	jne    13 <fact_rec+0x13>
       c:	b8 01 00 00 00       	mov    $0x1,%eax
      11:	eb 10                	jmp    23 <fact_rec+0x23>
      13:	8b 45 08             	mov    0x8(%ebp),%eax
      16:	48                   	dec    %eax
      17:	89 04 24             	mov    %eax,(%esp)
      1a:	e8 fc ff ff ff       	call   1b <fact_rec+0x1b>
      1f:	0f af 45 08          	imul   0x8(%ebp),%eax
      23:	c9                   	leave  
      24:	c3                   	ret   
    -O1
    00000000 <fact_rec>:
       0:	53                   	push   %ebx
       1:	83 ec 18             	sub    $0x18,%esp
       4:	8b 5c 24 20          	mov    0x20(%esp),%ebx
       8:	85 db                	test   %ebx,%ebx
       a:	74 10                	je     1c <fact_rec+0x1c>
       c:	8d 43 ff             	lea    -0x1(%ebx),%eax
       f:	89 04 24             	mov    %eax,(%esp)
      12:	e8 fc ff ff ff       	call   13 <fact_rec+0x13>
      17:	0f af c3             	imul   %ebx,%eax
      1a:	eb 05                	jmp    21 <fact_rec+0x21>
      1c:	b8 01 00 00 00       	mov    $0x1,%eax
      21:	83 c4 18             	add    $0x18,%esp
      24:	5b                   	pop    %ebx
      25:	c3                   	ret    
    
    -O2
    00000000 <fact_rec>:
       0:	8b 54 24 04          	mov    0x4(%esp),%edx
       4:	b8 01 00 00 00       	mov    $0x1,%eax
       9:	85 d2                	test   %edx,%edx
       b:	74 0a                	je     17 <fact_rec+0x17>
       d:	8d 76 00             	lea    0x0(%esi),%esi
      10:	0f af c2             	imul   %edx,%eax
      13:	4a                   	dec    %edx
      14:	75 fa                	jne    10 <fact_rec+0x10>
      16:	c3                   	ret    
      17:	c3                   	ret    
    
    -O3 == -O2

    -Os
    00000000 <fact_rec>:
       0:	55                   	push   %ebp
       1:	89 e5                	mov    %esp,%ebp
       3:	8b 55 08             	mov    0x8(%ebp),%edx
       6:	b8 01 00 00 00       	mov    $0x1,%eax
       b:	85 d2                	test   %edx,%edx
       d:	74 06                	je     15 <fact_rec+0x15>
       f:	0f af c2             	imul   %edx,%eax
      12:	4a                   	dec    %edx
      13:	eb f6                	jmp    b <fact_rec+0xb>
      15:	5d                   	pop    %ebp
      16:	c3                   	ret    
    
    16.6.2013 20:23 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    vysledky zalezi jeste od nastaveni prekladace a pouziteho procesoru.

    pokud dam "-O3 -m32 -march=pentium3" tak -O3 == -O2, ale s pentium4 uz to generuje kod s vektorovymi instrukcemi, pripadne to lze vynutit pouzitim -msse2.
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    16.6.2013 20:45 pc2005 | skóre: 38 | blog: GardenOfEdenConfiguration | liberec
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Jasný, ale i tak je to rozdílný:

    gcc -c zzzzzzzzzzzzz.c -O2 -march=core2
    00000000 <fact_rec>:
       0:	8b 54 24 04          	mov    0x4(%esp),%edx
       4:	b8 01 00 00 00       	mov    $0x1,%eax
       9:	85 d2                	test   %edx,%edx
       b:	74 0d                	je     1a <fact_rec+0x1a>
       d:	8d 76 00             	lea    0x0(%esi),%esi
      10:	0f af c2             	imul   %edx,%eax
      13:	83 ea 01             	sub    $0x1,%edx
      16:	75 f8                	jne    10 <fact_rec+0x10>
      18:	f3 c3                	repz ret 
      1a:	f3 c3                	repz ret 
    
    Kromě přidání těch repz (slackware default je i486) se změnil "dec" na "sub" (zajímavý, sub má delší opkód). Ještě zajímavější je ten "lea", což je jestli se nepletu taky jen "nop".
    16.6.2013 21:38 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Rychlosti sub, dec a lea se docela lisi mezi jednotlivymi procesory, takze tomu se nedivim, ze to prehodil. Ta lea jako nop je zajimava, ... Nemuze to byt kvuli efektivnimu vytizeni jednotlivych pipeline?
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    16.6.2013 23:29 pc2005 | skóre: 38 | blog: GardenOfEdenConfiguration | liberec
    Rozbalit Rozbalit vše Re: Poznamka k diskuzi o rekurzi
    Na 486 by měl "sub reg,imm" trvat jeden takt, navíc je to taková základní instrukce a pochybuju, že "dec" bude implementovaná v mikrokódu jinak než "sub reg,1". Navíc v rychlosti nalezené tvrzení.

    Aha tak jsem to nakonec našel, "lea" je vycpávka jako "nop" s prefixama :-O.

    BTW docela by mě zajímaly všechny ty vyjímky v mikrokódu, protože třeba "xchg eax,eax" je vlastně klasickej "nop" (stejnej opkód), ale obecně "xchg reg1,reg2" způsobí závislost použití registru.

    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.