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 01:00 | Komunita

    Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.

    Ladislav Hagara | Komentářů: 0
    dnes 00:00 | IT novinky

    Byl publikován plán na odstranění XSLT z webových prohlížečů Chrome a Chromium. S odstraněním XSLT souhlasí také vývojáři Firefoxu a WebKit. Důvodem jsou bezpečnostní rizika a klesající využití v moderním webovém vývoji.

    Ladislav Hagara | Komentářů: 0
    včera 15:55 | Nová verze

    Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.3.0. Přehled novinek v poznámkách k vydání.

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

    Organizace Open Container Initiative (OCI) (Wikipedie), projekt nadace Linux Foundation, vydala Runtime Specification 1.3 (pdf), tj. novou verzi specifikace kontejnerového běhového prostředí. Hlavní novinkou je podpora FreeBSD.

    Ladislav Hagara | Komentářů: 0
    4.11. 11:33 | IT novinky

    Nový open source router Turris Omnia NG je v prodeji. Aktuálně na Allegro, Alternetivo, Discomp, i4wifi a WiFiShop.

    Ladislav Hagara | Komentářů: 22
    4.11. 05:44 | Komunita

    Na YouTube a nově také na VHSky byly zveřejněny sestříhané videozáznamy přednášek z letošního OpenAltu.

    Ladislav Hagara | Komentářů: 0
    4.11. 04:33 | Komunita

    Jednou za rok otevírá společnost SUSE dveře svých kanceláří široké veřejnosti. Letos je pro vás otevře 26. listopadu v 16 hodin v pražském Karlíně. Vítáni jsou všichni, kdo se chtějí dozvědět více o práci vývojářů, prostředí ve kterém pracují a o místní firemní kultuře. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem inženýři v Praze pracují, jak spolupracují se zákazníky, partnery i studenty, proč mají rádi open source a co

    … více »
    SUSEMAS | Komentářů: 2
    4.11. 04:22 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za říjen (YouTube).

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

    Jeff Quast otestoval současné emulátory terminálu. Zaměřil se na podporu Unicode a výkon. Vítězným emulátorem terminálu je Ghostty.

    Ladislav Hagara | Komentářů: 11
    3.11. 22:55 | IT novinky

    Amazon bude poskytovat cloudové služby OpenAI. Cloudová divize Amazon Web Services (AWS) uzavřela s OpenAI víceletou smlouvu za 38 miliard USD (803,1 miliardy Kč), která poskytne majiteli chatovacího robota s umělou inteligencí (AI) ChatGPT přístup ke stovkám tisíc grafických procesů Nvidia. Ty bude moci využívat k trénování a provozování svých modelů AI. Firmy to oznámily v dnešní tiskové zprávě. Společnost OpenAI také nedávno

    … více »
    Ladislav Hagara | Komentářů: 8
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (18%)
     (17%)
     (22%)
     (15%)
     (21%)
     (16%)
     (16%)
    Celkem 316 hlasů
     Komentářů: 15, poslední 2.11. 08:25
    Rozcestník

    Dotaz: Zjednodusenie lisp-like interpretra v JS

    30.11.2016 15:48 gsnak | skóre: 22 | blog: gsnak
    Zjednodusenie lisp-like interpretra v JS
    Přečteno: 294×
    Mam nasledovny lisp-like interpreter v JS:
    var fun = {
        "+": function (a) { return a.reduce(function (a, b) { return a + b; }); },
        "-": function (a) { return a.reduce(function (a, b) { return a - b; }); },
        "*": function (a) { return a.reduce(function (a, b) { return a * b; }); },
        "/": function (a) { return a.reduce(function (a, b) { return a / b; }); }
    };
    
    function lisp(aCode) {
        var i, fn, arg;
        if (Array.isArray(aCode)) {
            fn = aCode[0];
            arg = aCode.slice(1);
            for (i = 0; i < arg.length; i++) {
                if (Array.isArray(arg[i])) {
                    arg[i] = lisp(arg[i]);
                }
            }
            return fun[fn](arg);
        }
        return aCode;
    }
    
    console.log(lisp(["/", 22, ["-", 10, ["+", 1, 1, 1]]]));
    console.log(22 / (10 - (1 + 1 + 1)));
    Ale ta hlavna funkcia lisp() sa mi zda neelegantna, nevedeli by ste niekto napisat ju elegantnejsie? Myslim ze to ide zapisat este kratsie.
    Čo Rys, to vrah!

    Řešení dotazu:


    Odpovědi

    wamba avatar 30.11.2016 19:27 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: Zjednodusenie lisp-like interpretra v JS
    Podle mě je tam podruhý ten if zbytečně. A možná bych raději testoval, kdy to není Array, abych měl zanořený jen ten return aCode a ne celý ten blok.
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    1.12.2016 09:09 gsnak | skóre: 22 | blog: gsnak
    Rozbalit Rozbalit vše Re: Zjednodusenie lisp-like interpretra v JS
    Jo, mas pravdu, ten druhy if tam bol zbytocne.
    Čo Rys, to vrah!
    1.12.2016 09:12 gsnak | skóre: 22 | blog: gsnak
    Rozbalit Rozbalit vše Re: Zjednodusenie lisp-like interpretra v JS
    Aj to znizenie odsadenia pomohlo:
    function lisp(aCode) {
        var i, fn, arg;
        if (!Array.isArray(aCode)) {
           return aCode;
        }
        fn = aCode[0];
        arg = aCode.slice(1);
        for (i = 0; i < arg.length; i++) {
            arg[i] = lisp(arg[i]);
        }
        return fun[fn](arg);
    }
    Čo Rys, to vrah!

    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.