Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Guide to compile dhall to JS backend, wasm backend and GHCJS #2600

Open
flip111 opened this issue Jul 13, 2024 · 5 comments
Open

Guide to compile dhall to JS backend, wasm backend and GHCJS #2600

flip111 opened this issue Jul 13, 2024 · 5 comments

Comments

@flip111
Copy link

flip111 commented Jul 13, 2024

Could anyone provide some hints on how to get dhall compiled into a javascript library? And how would one get an API specification for this library? AFAIK there are three possibly targets, the older GHCJS, the new javascript backend 1 and a WASM backend. I would like to try all three

@flip111 flip111 changed the title Guide to compile dhall to JS backend and GHCJS Guide to compile dhall to JS backend, wasm backend and GHCJS Jul 13, 2024
@Gabriella439
Copy link
Collaborator

The Dhall JavaScript code that powers https://dhall-lang.org is built using the older GHCJS and that's using Nixpkgs's support for GHCJS. However, I haven't tried either the WASM backend or the new JavaScript backend.

Also, even the older GHCJS build is deprecated (it's currently disabled in master), although I've been working on re-enabling it. The dhall-lang repository is pinned to an older version of this repository for building the JavaScript code.

@georgefst
Copy link

With the WASM backend, the only problematic dependency now is unix-compat, which is used directly as well as via atomic-write. Comment those two out in the Cabal file, use the following cabal.project, and nix shell gitlab:haskell-wasm/ghc-wasm-meta?rev=56dfe2478cae35ded335261c854bb8b2a5e7f4d2#all_9_10 -c wasm32-wasi-cabal build dhall --only-dependencies works:

packages:
  ./dhall

if arch(wasm32)
  allow-newer:
    cborg:*,
    text-short:*,
    th-abstraction:*,
    th-compat:*,
    th-lift:*,

  constraints:
    -- The `network` library doesn't build, although I believe there's a work-in-progress patch out there somewhere.
    -- Even then, `-use-http-client-tls` would probably be useful for avoiding the whole `crypton`/`basement` ecosystem,
    -- which is unmaintained and includes a lot of C stuff.
    dhall -with-http,
    haskeline -terminfo,

  constraints: time installed
  allow-newer: time

  -- https://github.com/well-typed/cborg/pull/322
  source-repository-package
    type: git
    location: https://github.com/amesgen/cborg
    tag: c3b5c696f62d04c0d87f55250bfc0016ab94d800
    subdir: cborg

@georgefst
Copy link

Note that I haven't looked in to unix-compat, what exactly it does, and whether dhall could easily avoid depending on it.

@flip111
Copy link
Author

flip111 commented Dec 28, 2024

@georgefst did you get the wasm version running or just compiling?

@georgefst
Copy link

@georgefst did you get the wasm version running or just compiling?

I didn't even get it compiling! Note that I used the --only-dependencies flag.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants