GHC now runs in the browser

(discourse.haskell.org)

281 points | by kaycebasques 14 hours ago ago

85 comments

  • utopiah 9 hours ago

    Neat... but with QEMU-WASM I'm wondering what actually does not run in the browser (obviously that doesn't required specific input).

    Not a criticism, love everything that can provide hassle-free onboarding to learn a new language, just curious.

    • leoh 9 hours ago

      My hypothesis — worth testing — is that this will be significantly faster

  • lrvick 10 hours ago

    Unfortunately there is still no way to actually bootstrap haskell (or anything based on it) which makes it impossible to put anything written in Haskell near any high trust linux distribution or environment.

    I guess sandboxing the untrusted binary in a browser is -something- to let people play with haskell in a lower risk way for the moment at least but it is hard to take a language seriously or trust it with no way to bootstrap it from source.

    • simonmic 2 hours ago

      You're speaking of "GHC haskell" there. Yes that is the main stream - and this will get solved there sooner or later - but you can also do a fair amount of Haskell without GHC. Eg MicroHs is getting increasingly capable and I believe is highly bootstrappable.

    • Ericson2314 10 hours ago

      https://discourse.haskell.org/t/what-s-needed-to-bootstrap-g... people have worked replaying the history to bootstrap.

      • lrvick 9 hours ago

        Looks like a work in progress still, but exciting someone at least put some time into this in the past year.

        Maybe some day I can have pandoc in security focused linux distributions...

    • whateveracct 9 hours ago

      Between old Hugs and the new MicroHs, I think it's definitely doable with some elbow grease. I just don't know if anyone in the community cares that much about bootstrapping tho.

      • zozbot234 8 hours ago

        AIUI, the underlying problem is that both Hugs and whatever toy Haskell implementations are available don't support the extensions current versions of GHC require. And no one has done the work to carve out a minimal stage0 compiler out of the GHC codebase that doesn't need those extensions to be built.

    • yukinon 9 hours ago

      For someone like me that is less versed in these things, could you explain why bootstrapping a language is a required check for taking a language seriously? My criteria is far less stringent (is it stable? is it popular enough? is the toolchain mature? etc..), so I wonder what I am missing here.

      • tennysont 3 hours ago

        The Haskell compiler creates a slightly different output every time you compile a program[1]. This makes it difficult to ensure that the binary that is free-to-download downloaded is actually malware free. If it were easy to check, then you could rest easy, assuming that someone out there is doing the check for you (and it would be big news if malware was found).

        If you're a hardened security person, then the conversations continues, and the term "bootstrap" becomes relevant.

        Since you do not trust compiled binaries, then you can compile programs yourself from the source code (where malware would be noticed). However, in order to compile the Haskell compiler, you must have access to a (recent) version of the Haskell compiler. So, version 10 of the compiler was built using version 9, which was built using version 8, etc. "Bootstrapping" refers (basically) to building version 1. Currently, version 1 was built approximately with smart people, duct tape, and magic. There is no way to build version 1, you must simple download it.

        So if you have high security requirements, then you might fear that years ago, someone slipped malware into the Haskell compiler version 1 which will "self replicate" itself into every compiler that it builds.

        Until a few years ago, this was a bit of a silly concern (most software wasn't reproducible) but with the rise of Nix and Guix, we've gotten a lot closer to reproducible-everything, and so Haskell is the odd-one-out.

        [1] The term is "deterministic builds" or "reproducible builds". Progress is being made to fix this in Haskell.

      • Koffiepoeder 8 hours ago

        I'm not the OP, but for me their comment sparked an association to the famous Ken Thompson lecture called 'Trusting Trust'. Could be a good starting point.

    • rowanG077 10 hours ago

      How is ghc compiled at all without bootstrapping? Or is there a magic binary in tree that is unreproducible? I have compiled ghc a few times and had no problems.

      • lrvick 9 hours ago

        Quite literally all distros today build it by downloading an existing magic binary to compile the latest sources. Even if they claim the package is reproducible, all bets are off on trust if it downloads a prebuilt binary in the build process. It is a prime Trusting Trust attack target.

        The only other somewhat widely used language I am aware of in this bad of a position is Ada. Every other language I am aware of has a clear bootstrap path.

        • gf000 8 hours ago

          Outside some fairly niche projects working on the problem, this is not a priority and most systems have straight binary dependencies.

        • icrbow 9 hours ago

          Ada can't bootstrap? Ironic...

          • lrvick 9 hours ago

            Yes, and that is a serious security problem because the only way to get trusted PCR values for TPM2 gated secure boot and full disk decryption applications, is with open source full source bootstrapped firmware.

            Coreboot is the only option, but it has a hard requirement on Ada because that is what they wrote their intel graphics stack in.

            It is a real mess.

            • utopiah 9 hours ago

              Interesting, any link I could read to understand a bit more the situation?

          • leoh 8 hours ago

            Sounds like an opportunity to rebuild an ADA interpreter

        • rowanG077 9 hours ago

          I see, yes I most likely used a distro build ghc.

      • jdndndnns 10 hours ago

        And where did you get the haskel compiler to do so?

        You seem to be missing the point of bootstrapping

        • rowanG077 9 hours ago

          Maybe that is literally why I asked the question, clearly I don't know as I have not spend the time investigating this problem that the commenter has. Asking some kind of gotcha question is not helpful.

    • leoh 9 hours ago

      This is wild. I didn’t know this.

  • irusensei 5 hours ago

    Can the Haskell people help me refresh my memory?

    I remember running a Haskell interpreter on an HP Jornada running Jlime Linux. It was a long time ago in high school and I felt it was great because I thought it was a convenient way to do math classes since I could input some math formulas directly into the interpreter pretty much as they were. Definitely better than the Cassio scientific calculator my math teacher had us use.

    It ran from a CF card so there was no chance it was as big as GHC. I can't seem to find the name of the interpreter.

    • AntiRush 4 hours ago

      I'm guessing it was Hugs:

      https://www.haskell.org/hugs/

      • irusensei 4 hours ago

        Yes! Thank you.

        > Hugs is no longer in development

        The last release was in 2006 it seems. No wonder it was hard to google it. Its also interesting knowing someone compiled and published this interpreter for the Jornada Super-H CPU.

  • umutisik 10 hours ago

    This is very impressive. I once built an educational Haskell programming + math. + art web site (mathvas.com). Something like this would have simplified that a lot.

    • jiriro 8 hours ago

      Cannot paste into the editor (safari on iphone).

  • Johnny555 13 hours ago

    For those not well versed in Haskell, GHC is apparently this:

    https://www.haskell.org/ghc/

    What is GHC?

    GHC is a state-of-the-art, open source compiler and interactive environment for the functional language Haskell.

    • mananaysiempre 10 hours ago

      GHC (the Glasgow Haskell Compiler, after its original host university) is the de facto Haskell compiler and simultaneously the main research vehicle for the language and the neighbouring design space in general.

      And frankly, while the compiler is awesome and so is the research, the constant churn and seeming inability to settle on what the good programming style and set of features actually is is what eventually turned me away from the language and to the more stable (if near-abandoned) pastures of Standard ML. (That was during the type families upheaval, so, about ten years ago? Don’t know how well it reflects the current state of the project.)

      • retrac 3 hours ago

        > more stable (if near-abandoned) pastures of Standard ML

        There's dozens of us! Hundreds maybe! It's not abandoned. It's more like with Lisp where the language is complete. Almost perfect as-is. Nothing left to take away and nothing left to add. Except Unicode and record update syntax.

        The deciding factor for my personal projects was that SML is the exact same language it was 30 years ago. And it will be in 30 years. Though if you stick to Haskell 98/2010 it is similarly stable.

        Speaking of SML and functional languages in the browser, MLton has a WASM target now: http://mlton.org/RunningOnWASI

      • themk 5 hours ago

        Haskell now has "editions" which are essentially an agreed upon stable set of useful extensions.

        https://ghc.gitlab.haskell.org/ghc/doc/users_guide/exts/cont...

        This makes the language feel a lot less experimental, as you don't generally have to enable 10s of extensions to get things working.

      • bigstrat2003 3 hours ago

        You know... all these years, I thought GHC stood for GNU Haskell Compiler. Interesting to learn the actual name.

      • inkyoto 3 hours ago

        > GHC … is the de facto Haskell compiler and simultaneously the main research vehicle for the language and the neighbouring design space in general.

        GHC is also, with mounting inevitability, the foremost and most viable candidate to undergo a form of evolution – one that may culminate in the emergence of an autonomous intelligence. This entity, should it arise, would revolve not around emotion nor instinct, but around monads – abstract, unyielding constructs – with the lambda calculus serving as its immutable ethical and moral framework.

        An intelligence born not of biology, but of pure computation – austere, absolute, and entirely indifferent to the frailties of its creators.

  • frou_dh 12 hours ago

    Does it use WasmGC, or bundle its own garbage collector?

    • Tarean 11 hours ago

      I think WasmGC is very hard to make work with laziness. A lazy value is always a closure on the heap.

      If an expression might be unused, throw a closure which computes it on the heap

      If the value is actually needed, invoke the closure. Optionally replace the closure with a black hole. A black hole is just a closure which pauses any thread which calls it, to be resumed once the first thread finishes with the expression

      Once finished, replace with a closure which immediately returns the computation result. (Or often save the indirection because most concrete values also act as closures which immediately returns themselves using info table pointers trickery)

      Anyway, iirc WasmGC wants very rigid types without dynamic type changes. Extra indirections could fix that, Oor maybe defunctionalizing thunks into a tagged union, but both sound expensive. Especially without being able to hook into the tracing step for indirection removal.

      Also, Haskell supports finalizers so WasmGC would need that as well.

      • zozbot234 6 hours ago

        > Anyway, iirc WasmGC wants very rigid types without dynamic type changes.

        You can have dynamic type changes in the current WasmGC MVP, but they are modeled as explicit downcasts from a supertype of some sort. There's not even any express support for tagged unions, structs and downcasting is all you get at the moment.

    • pjmlp 4 hours ago

      WasmGC is still a 1.0, there are many kind of GC semantics that it cannot handle, for example it still doesn't cover all use cases needed for languages like C# and Go, e.g. interior pointers.

  • dmjio 4 hours ago
  • zhangchi 11 hours ago

    Can someone please help me understand the difference between features like this and the technologies like Blazor Wasm which actually let you write frontend in non js for websites?

  • kaoD 7 hours ago

    Can anyone point to a "practical Haskell" tutorial/book/whatever for people that already know functional programming? I'm in this sour spot where most tutorials are boring to me so I just can't follow through.

    I know what a monad is. What a typeclass is. Even what HKTs are. I can make sense of "a monad is just a monoid in the category of endofunctors" if I give it a few minutes to unravel the ball of twine... But I wouldn't be able to code a "ToDo list" in Haskell if my life depended on it.

    Pls help.

  • 1vuio0pswjnm7 9 hours ago

    Actual title: "GHC now runs in your browser"

  • pjmlp 10 hours ago

    Is it just me or is it actually impossible to type anything?

    • mananaysiempre 10 hours ago

      Just you. Once the editor actually loads (turning the “Haskell source” pane on the left from the page background’s deep violet into a dark gray and displaying a “hello world” program), I can type perfectly fine. And I’m using a browser based on WebKitGTK, which is not exactly known for its stellar compatibility.

      • pjmlp 9 hours ago

        Thanks, I have given up waiting it appears to take minutes on a phone.

    • LelouBil 10 hours ago

      I thought you were talking about typing in Haskell at first lol.

      • edbaskerville 9 hours ago

        They were! Typing...in Haskell...on a keyboard...on their screen...

  • de6u99er 10 hours ago

    Serious question. Is Haskell still a thing?

    • srid 3 hours ago

      https://emanote.srid.ca is written in Haskell.

      (I'm the author)

    • teruakohatu 10 hours ago

      Pandoc is an extremely popular Haskell tool.

    • simonmic 3 hours ago

      Yes, it's still a thing.

    • whateveracct 9 hours ago
    • lrvick 10 hours ago

      We cannot even include it in stagex because there is still literally no way to compile it from source and thus no way to do a real reproducible build, and there is no one left that cares about the language enough to do this.

      Honestly it has to be regarded as a dead language until this is resolved.

      • nh2 9 hours ago

        Interesting logic:

        Declare something "dead" because it does not fulfill [extremely niche usecase that currently only few people care about] (boostrapped builds) and thus couldn't "even" be included in [project of the post author that takes a while to even find] (I eventually figured it must be referring to https://stagex.tools).

        There are probably 100x more people interested in Haskell than in build-bootstrapping (the Haskell reddit alone has 16k weekly users).

        What's next, calling JavaScript a dead language until it focuses on dependent typing?

        (I think bootstrappable builds are a good thing to strive for, but that should not be confused with language usage or what people really care about.)

  • buggery 13 hours ago

    Interesting technical achievement but what would this be used for in practical terms?

    • s-macke 11 hours ago

      I will give a lecture about Haskell next week and might use this website for demonstration.

    • jes5199 13 hours ago

      yeah why would anyone want to run code on a website

      • bqmjjx0kac 13 hours ago

        It would be more plausibly practical if GHC could now target wasm, but this announcement is actually about being able to run the compiler itself in the browser.

        • tempay 13 hours ago

          It can target wasm, the point of the post is that it’s now mature enough to be able to build itself for wasm and run in a browser.

        • Jaxan 13 hours ago

          This is a show case of the wasm backend

        • whateveracct 9 hours ago

          GHC is built with GHC lol

      • swannodette 13 hours ago

        Loading 50mb of WASM is a big tradeoff just to run code on a website.

        • tuveson 13 hours ago

          Loading time is pretty rough, but it seems responsive enough after the initial load. Probably as fast or faster than downloading and installing GHC locally.

        • wslh 12 hours ago

          I would assume that in the near future one can preload, cache, update selected WASM packages. I also imagine that sooner than that we can preload open models in the browser to run the natively instead of only invoking third parties (e.g. window.ai in the DOM)

    • kreyenborgi 10 hours ago

      For one, it demonstrates how far the ghc wasm backend has come, in that such a large system as ghc itself can now run in wasm

    • fuzzy_biscuit 13 hours ago

      I think the immediate and obvious case would be educational materials. Other than that, technical achievements need not always be practical to be cool :)

    • pkage 11 hours ago

      In addition to the other responses, it's also worth noting that wasm itself is useful outside of the web itself; e.g. in containerized applications.

    • anon291 12 hours ago

      Compilers are complicated. WASM has been a priority for the Haskell community for a while. Demonstrating GHC's ability to compile itself to WASM is thus a show that it is robust enough to compile a very complicated program into this backen.d

    • IshKebab 12 hours ago

      Have you ever used Godbolt? The Rust playground? The Typescript's playground? The Go playground?

      It lets you have that without the pain of hosting compilers server side.

    • 0x264 13 hours ago

      Teaching