Grain is a new programming language that compiles to WebAssembly via Binaryen. For more information about the language, check out grain-lang.org.
If it's your first time here, we recommended that you follow the Grain guide to get up and running.
There are tons of ways to contribute to Grain. Check out our contributing guide for more info and come chat with us on Discord! All contributors are held to our contributor code of conduct.
Grain currently only works on Mac and Linux. We are hard at work trying to integrate Binaryen and OCaml on Windows, but this is uncharted territory! Please let us know if you have this low-level expertise. 🙇
To build Grain, you'll need Node.js v14 and Yarn. To get everything set up, run:
yarn
yarn compiler build
This will set up the Grain runtime, standard library, and CLI.
If running tests is your kind of thing, run
yarn compiler test
If you are using vscode
as your editor, we recommend you run:
yarn vscode
This will create local settings that point OCaml LSP to our compiler
directory. Then, you should be able to use the OCaml Platform extension!
To build the standard library:
yarn stdlib build
To build the runtime:
yarn runtime build
To link the CLI:
yarn cli link
To reset your compiler build:
yarn compiler clean
To navigate tasks available in the system:
yarn run
This will display an interactive session where you can select the project and command you want.
You can run programs using the Grain CLI:
echo "print('Hello world')" > hello.gr
grain hello.gr
Alternatively, you can invoke the compiler directly:
grain compile hello.gr
and then to run the compiled program:
grain run hello.gr.wasm
Copyright ©️ 2017-2020 Philip Blair, Oscar Spencer, & contributors.