WebAssembly WASI #19
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# | |
# File: %wasi-build.yml | |
# | |
#============================================================================# | |
# | |
# GitHub Workflow for building the Wasi version of Ren-C. This is for use in | |
# non-Browser, non-NodeJs hosts (e.g. Wasmtime, WasmEdge, Wasmer). So rather | |
# than being built with Emscripten, it is built using "Wasi-Sdk" (because the | |
# STANDALONE_WEBASSEMBLY support in Emscripten is somewhat minimal). | |
# | |
# See %configs/wasi.r for more information on this build. | |
# | |
#====# PLEASE READ THE README #==============================================# | |
# | |
# Whenever this file says "See README", that is referring to the notes in the | |
# %.github/workflows/README.md file. If something appears in multiple GitHub | |
# Workflow files, it's best to document it there instead of repeating it: | |
# | |
# https://github.com/metaeducation/ren-c/blob/master/.github/workflows/README.md | |
# | |
name: WebAssembly WASI | |
# See README: When To Trigger Builds | |
# | |
on: | |
push: | |
branches: [ | |
wasi | |
] | |
pull_request: | |
branches: [ | |
wasi | |
] | |
workflow_dispatch: # Allows running this workflow manually from Actions tab | |
# Standardize to use bash on all platforms. | |
# | |
# See README: Using The Strict Erroring Bash Shell | |
# | |
defaults: | |
run: | |
shell: bash | |
# Each "Job" runs in its own VM, and a workflow run is made up of one or more | |
# jobs that can run sequentially or in parallel. | |
# | |
# See README: Jobs | |
# | |
jobs: | |
wasi-build: # Name of this workflow's only job | |
# https://github.com/actions/virtual-environments#available-environments | |
# | |
runs-on: ubuntu-20.04 | |
# See README: Build Matrix | |
# | |
strategy: | |
matrix: | |
include: | |
- os-id: 0.16.4 # "wasi" build | |
config-file: wasi.r | |
# See README: Environment Variables | |
# | |
env: | |
AWS_S3_BUCKET_NAME: metaeducation | |
# See README: Minimize GitHub-Specific Syntax | |
# | |
OS_ID: ${{ matrix.os-id }} | |
CONFIG_FILE: ${{ matrix.config-file }} | |
# Steps are a sequence of tasks that will be executed within a single VM | |
# as part of the job. | |
# | |
# See README: Steps | |
# | |
steps: # (no indentatation needed below; so indent the minimum!) | |
#====# CHECKOUT STEPS #====================================================# | |
# https://github.com/actions/checkout | |
# | |
# See README: Checkout Action | |
# | |
- uses: actions/checkout@v3 # See README: Trusted Actions | |
# The full commit is passed to make to build into the binary, and the | |
# abbreviated commit is used to name the executable. | |
# | |
# See README: Portably Capturing Git Hashes | |
# | |
- name: Grab Git Hash and Short Hash Into Environment Variables | |
run: | | |
git_commit="$(git show --format="%H" --no-patch)" | |
git_commit_short="$(git show --format="%h" --no-patch)" | |
echo "GIT_COMMIT=$git_commit" >> $GITHUB_ENV | |
echo "GIT_COMMIT_SHORT=$git_commit_short" >> $GITHUB_ENV | |
#====# TOOLCHAIN INSTALLATION STEPS #======================================# | |
# !!! Ideally this would use the same step that clients can use to build | |
# the system with `make.sh`. Unfortunately, something about the GitHub | |
# Ubuntus do not like the old bootstrap executable. Make sure the | |
# ordinary path works, but for the moment patch over it just to get | |
# to a point where the action works. | |
# | |
- name: Fetch R3 To Use For "Prep" Build Steps as $R3MAKE | |
run: | | |
repo_dir=$(pwd)/ | |
source tools/bash/fetch-prebuilt.sh | |
r3make=$(fetch_prebuilt) | |
echo "R3MAKE is set to $r3make" | |
echo "But that executable won't run on GitHub for some reason" | |
# "$r3make" --do "print {TESTING 1 2 3}" # NOT WORKING, dunno why | |
cd prebuilt | |
wget http://hostilefork.com/media/shared/github/r3-linux-8994d23-patched | |
chmod +x r3-linux-8994d23-patched | |
r3make=$(pwd)/r3-linux-8994d23-patched | |
echo "So now R3MAKE is $r3make" | |
echo "R3MAKE=$r3make" >> $GITHUB_ENV # pass to next step | |
- name: Stop the build early if the R3MAKE is no good | |
run: | | |
"$R3MAKE" --do "print {R3MAKE is Working} quit" | |
# Wasi-Sdk is part of the WebAssembly GitHub Repository. It has a version | |
# of clang that has been configured to emit wasm32 instructions. But we | |
# also need a `sysroot` to provide the cross-compilation header files, so | |
# when we compile with #include <stdio.h> (or whatever) it pulls that from | |
# wasi version instead of the /usr/include of this Linux container. | |
# | |
- name: Get the Wasi-Sdk from GitHub Release | |
run: | | |
wget https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-20/wasi-sdk-20.0-linux.tar.gz | |
tar xf wasi-sdk-20.0-linux.tar.gz | |
wget https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-20/wasi-sysroot-20.0.tar.gz | |
tar xf wasi-sysroot-20.0.tar.gz | |
# Everything in makefiles tends to be rigged up a bit hackily, and it's no | |
# exception here...the hardcoded environment variables WASI_CLANG and | |
# WASI_SYSROOT are looked up by %wasi.r in order to know where you put the | |
# non-native toolchain. | |
# | |
- name: Set Compiler and Sysroot Environment Variables Used By %wasi.r | |
run: | | |
echo "WASI_CLANG=$(pwd)/wasi-sdk-20.0/bin/clang" >> $GITHUB_ENV | |
echo "WASI_SYSROOT=$(pwd)/wasi-sysroot" >> $GITHUB_ENV | |
# Show a little bit of sanity check information | |
# | |
- name: Output System Information | |
run: | | |
echo "Current directory is: $(pwd)" | |
echo "WASI-SDK/clang version check:" | |
wasi-sdk-20.0/bin/clang -v | |
#====# BUILD STEPS #=======================================================# | |
# Note: optimization for the WASI build must be 0 if debug information is | |
# requested. Otherwise it is done for size, and the real "optimization" is | |
# done with a post-processing step (with WasmEdge's `wasmedgec`) | |
# | |
# See README: {Braces} For %make.r String Parameters | |
- name: Generate Makefile for Emscripten-Based Build | |
run: | | |
mkdir build | |
cd build | |
"$R3MAKE" ../make.r \ | |
config="../configs/$CONFIG_FILE" \ | |
target=makefile \ | |
standard=gnu99 \ | |
os_id=$OS_ID \ | |
debug=none \ | |
git_commit="{$GIT_COMMIT}" \ | |
rigorous=no \ | |
static=no \ | |
extensions="" | |
- name: Create Folders For Build Products (Compiler Won't Create Them) | |
run: | | |
cd build | |
make folders | |
- name: Prep the Build By Making Various Auto-Generated .h and .c Files | |
run: | | |
cd build | |
make prep | |
# https://github.com/actions/upload-artifact | |
# | |
- name: Optional Download of Prep Files Before They Can Cause Build Failure | |
if: false # Change this to true to download a file | |
uses: actions/upload-artifact@v2 # See README: Trusted Actions | |
with: | |
name: tmp-internals.h | |
path: build/prep/include/tmp-internals.h | |
- name: Compile and Link the C Sources to To Make .wasm and .js Files | |
run: | | |
cd build | |
make -j 2 # Linux GitHub Runners have 2 cores, use 2 jobs | |
- name: List Build Products | |
run: | | |
cd build | |
ls -alF | |
#====# UPLOAD STEPS #======================================================# | |
# We only want to build pull requests, we do not want to upload them to | |
# the AWS server. Deployment should happen only once a commit has been | |
# accepted and pushed to master. And then, it should only be greenlit | |
# (to be the version the web console uses) if it passes the smoke test in | |
# a headless browser. | |
# | |
# Unfortunately...there's no particularly great way to exit the steps | |
# cleanly now if it's only a pull request. We can stop the steps, but | |
# it would look like an error: | |
# | |
# https://github.com/actions/runner/issues/662 | |
# | |
# So either we write one giant monolithic step, or every subsequent step | |
# has to be qualified with an `if: github.ref == 'refs/heads/master'`. | |
# Though the latter is not *ideal*, it's good enough for government work. | |
# | |
# Note: Steps will be stopped by default if any fail, but you can turn | |
# a step back on with an `if: failure()` condition. | |
# This action configures the AWS keys stored in GitHub's "Secrets" for | |
# the repository so that `aws s3` allows us to do uploads, without needing | |
# to publish any passwords publicly: | |
# | |
# https://github.com/aws-actions/configure-aws-credentials | |
# | |
# See README: Trusted Actions | |
# | |
- name: Configure AWS Credentials | |
if: github.ref == 'refs/heads/master' # see notes on DEPLOY STEPS | |
uses: aws-actions/configure-aws-credentials@v1 | |
with: | |
aws-access-key-id: ${{ secrets.METAEDUCATION_AWS_ACCESS_KEY }} | |
aws-secret-access-key: ${{ secrets.METAEDUCATION_AWS_SECRET_KEY }} | |
aws-region: us-east-1 | |
#====# INSTALL WASMEDGE RUNTIME #==========================================# | |
# We do this after the build, because it does no good to download it | |
# unless we have something to optimize and run. | |
- name: Install WasmEdge Runtime | |
run: | | |
curl -sSf https://raw.githubusercontent.com/WasmEdge/WasmEdge/master/utils/install.sh | bash | |
#====# INSTALL REN-C #=====================================================# | |
# Useful to have a Ren-C on hand to validate tests with. | |
# | |
- name: Download and Cache the Interpreter | |
uses: metaeducation/ren-c-action@release | |
with: | |
checked: true | |
#====# TESTING STEPS #=====================================================# | |
# The compiler optimisation through the -O setting is generic, and a much | |
# better optimization can be achieved if it's specifically tailored to the | |
# runtime it's going to run on. Try optimization provided by WasmEdge. | |
# | |
- name: Optimize Build Result for WasmEdge | |
run: | | |
source /home/runner/.wasmedge/env | |
cd build | |
wasmedgec r3.wasm r3.wasm | |
- name: WasmEdge Smoke Test | |
run: | | |
source /home/runner/.wasmedge/env | |
cd build | |
wasmedge r3.wasm --do \ | |
"print ['** parse {Hello, Cloud} [thru space across to <end>] '**]" | |
# The command `--dir x:.` tells WasmEdge to allow file access to the | |
# current directory `.`, and to map it `:` to the directory that wasmedge | |
# considers %x/ | |
# | |
# (It does not appear that `--dir .:.` is allowed to work.) | |
# | |
- name: WasmEdge Read and Write Test | |
run: | | |
source /home/runner/.wasmedge/env | |
cd build | |
wasmedge --dir x:. r3.wasm --do \ | |
"print {Begin}, basic-write %x/test.txt {Test}, print {End}" | |
wasmedge --dir x:. r3.wasm --do \ | |
"either {Test} = as text! basic-read %x/test.txt [print {Yay}] [fail]" | |
r3 --do \ | |
"if {Test} = as text! read %test.txt [print {Verified}] else [fail]" |