Skip to content

ZS-247/wasm-experiments

Repository files navigation

This repo contains some of my experiments with compiling c code to webassembly. I have not used emcc or any special toolchains/runtimes for this. I have used clang and llvm to direct compile the c code to webassembly and called it from javascript.

The resulting site is available here

How to run locally

Wasm doesnt need a server to run, you can run it locally by opening the html file in a browser. As explained in the site, wasm can be directly embeded in the html file, however for convienience a simple python script will run a webserver that serves everything correctly. For convienience I have provided a litle shell script that will convert wasm binaries to base64 + some js to load everything so you can copy and paste directly into a html file if you wish. The script ran fine on windows with git bash and should also run fine on linux/wsl, etc.

Prerequisites

  • Python 3 (for the webserver)
  • clang (for compiling the c code if you want to make changes)
  • a browser that supports webassembly (most modern browsers do)
  • bash or compatible shell to run wasm-to-base64.sh

Running the site

  1. Clone the repo
    git clone <repo-url>
    cd <repo-name>
  2. Run the python server
    python webserver.py # by default it runs on port 8000 and serves the current directory.
  3. Open the browser and go to http://localhost:8000

The javascript code will load the wasm file and run the functions defined in the c code. The output will be displayed as an alert box. (note, your browser may warn you about supressing alerts)

The javascript code is currently embeded inside index.html, purely for convienience and simplicity.

About

My attempt to learn more about webassembly

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published