Welcome to the (rather late) April 2022 monthly update from the GHC DevX team at IOG. Since the last update we've continued work on the upcoming JavaScript backend for GHC. Unfortunately, we have nothing to show quite yet but that doesn't mean nothing has happened! On the contrary, we've made great progress and are close to that crucial first milestone hello world
. Besides our work on the JavaScript backend, we were pleased to finally push through the Modularizing GHC paper that Sylvain has been working on for 2+ years! It causes quite the splash on the Haskell discourse and reddit, we recommend reading it if you haven't already (links below). Alright, enough introduction let's get into the update.
JavaScript Backendโ
We have made the following progresses in the implementation of a JavaScript backend for GHC (adapted from GHCJS):
linker: ported GHCJS's linker code into GHC. A lot of code was duplicated from GHC and slightly modified for GHCJS's needs, making the process far from trivial.
testsuite: fixed Hadrian to run GHC's testsuite with cross-compilers !7850. There are remaining issues though (see #21292).
build system: fixes for GHC's configure script were ported (e.g. support for the "ghcjs" target in
config.sub
). GHCJS's custom build script was integrated intoconfigure.ac
. We can now configure the build with:./configure --target=js-unknown-ghcjs
TH: we have conducted some experiments to find the best way to bridge GHCJS's TH runner and GHC's external interpreter. This will be described in details in a future blog post.
FFI: basic support for JavaScript FFI has been ported from GHCJS to GHC. We haven't ported the JavaScript parser, so we have dropped the fancy import syntax (e.g. "$1.xyz"). It should be enough to build boot libraries and we will add JS parsing support later.
At this stage, we are working on building boot libraries and on supporting linking with the JS RTS.
Development happens in the following branch: https://gitlab.haskell.org/ghc/ghc/-/tree/wip/js-staging
Modularity paperโ
Sylvain, Jeffrey, and John Ericson (from Obsidian Systems) wrote a paper about "modularizing GHC" using domain-driven design.
- Announce blog post: https://hsyl20.fr/home/posts/2022-05-03-modularizing-ghc-paper.html
- Paper: https://hsyl20.fr/home/files/papers/2022-ghc-modularity.pdf
- Reddit: https://www.reddit.com/r/haskell/comments/uhdu4l/modularizing_ghc_paper/
- Discourse: https://discourse.haskell.org/t/modularizing-ghc-paper/4471
We've got a lot of great feedback about it (expect a first revision soon). We also got a GHC contribution directly inspired by the paper (see !8160) which was very welcome!