GHCJS is a Haskell to JavaScript compiler that uses the GHC API.
GHCJS contains a library, ghcjs
, which contains the JavaScript code generator and a slightly customized variant of the ghc
library, and several executable programs.
The repository has several submodules and some files must be generated before the package can be installed.
You need the same major version of GHC as the version of the GHCJS branch you're building.
cabal-install 3.0 is supported
GHCJS uses a C toolchain, mostly for build system related tasks like the C preprocessor, Autoconf scripts and tools like hsc2hs
. Direct support for using compiled foreign libraries from Haskell code may follow at a later date.
Please follow the installation instructions at https://emscripten.org/docs/getting_started/index.html
GHCJS requires the "upstream" emscripten backend, which is the default now. The earlier "fastcomp" backend will not work.
$ git clone https://github.com/ghcjs/ghcjs.git
$ cd ghcjs
$ git submodule update --init --recursive
GHCJS depends on a few "local" packages in the source tree. You can use
cabal-install
and stack
to set up a build environment that contains
these packages.
After the source tree has been prepared, the package can be installed. You may want ensure that binaries of earlier versions are overwritten:
cabal v2-install --overwrite-policy=always --install-method=copy --installdir=inplace
At the time of writing, cabal-install
does not support creating symbolic links on Windows, even though this is the default installation method. A workaround is telling it to copy the executables instead:
cabal v1-install --prefix=inplace
v1 style cabal sandboxes are also supported
if you want to build with a Cabal sandbox, use the makeSandbox.sh
script
to add the local packages.
$ cabal v1-sandbox init
$ cabal v1-install
or you can use stack:
$ stack --system-ghc --skip-ghc-check install --local-bin-dir=inplace/bin
The ghcjs-boot
program builds the "boot" libraries, like ghc-prim
, base
and template-haskell
with GHCJS. After booting, GHCJS can compile regular Haskell programs and packages.
ghcjs-boot
needs to be able to find the emscripten toolchain, a nodejs executable. The easiest way to do this is by running the emsdk_env.sh
script. After that, you can run ghcjs-boot
by pointing it to the boot libraries (the directory containing the boot.yaml
file)
$ source ~/emsdk/emsdk_env.sh
$ ./inplace/bin/ghcjs-boot -s ./lib/boot
After booting, you can add the directory containing the GHCJS binaries to
your executable PATH. The ghcjs-boot
program prints the location after
finishing building the libraries.
You can also create a symbolic link for the ghcjs
and ghcjs-pkg
programs, or use the --with-compiler
and --with-hc-pkg
flags
when using cabal-install
if you work on boot packages that need some for an upstream library,
make sure to update the patches in /lib/patches
first
$ ./utils/updatePatches.sh
then regenerate the packages
$ ./utils/makePackages.sh