/awesome-wasm-langs

😎 A curated list of languages that compile directly to or have their VMs in WebAssembly

Awesome WebAssembly Languages Awesome

WebAssembly, or wasm for short, is a low-level bytecode format that runs in the browser just like JavaScript. It is designed to be faster to parse than JavaScript, as well as faster to execute which makes it a suitable compilation target for new and existing languages.

This repo contains a list of languages that currently compile to or have their VMs in WebAssembly(wasm) :octocat:

Legend

🥚 - Work in progress.
🐣 - Unstable but usable.
🐥 - Stable for production usage.

Contents

🐥 .Net
🐥 AssemblyScript
🥚 Astro Unmaintained
🐥 Brainfuck
🐥 C
🐥 C#
🐥 C++
🐥 Clean
🥚 Co
🐥 COBOL
🐣 D
🐣 Eel
🐣 Elixir
🐣 F#
🥚 Faust
🥚 Forest
🐥 Forth
🐥 Go
🥚 Grain
🥚 Haskell
🐣 Java
🐣 JavaScript
🥚 Julia
🐣 Idris Unmaintained
🐣 Kotlin/Native
🥚 Kou
🐣 Lisp
🐥 Lobster
🐥 Lua
🐣 Lys
🐥 Never
🥚 Nim
🥚 Ocaml
🐣 Pascal
🐣 Perl
🐣 PHP
🥚 Plorth
🐣 Poetry
🐣 Python
🐣 Prolog
🐣 Ruby
🐥 Rust
🐣 Scheme
🐣 Scopes
🐣 Speedy.js Unmaintained
🐣 Swift
🐣 Turboscript Unmaintained
🐥 TypeScript
🐥 Wah Unmaintained
🐣 Walt Unmaintained
🐣 Wam Unmaintained
🥚 Wase
🐥 WebAssembly
🥚 Wracket Unmaintained
🐥 Zig


.Net top⇈

.NET Framework is a software framework developed by Microsoft that runs primarily on Microsoft Windows. It includes a large class library named Framework Class Library (FCL) and provides language interoperability (each language can use code written in other languages) across several programming languages.

  • Mono - an open source implementation of Microsoft's .NET Framework based on the ECMA standards for C# and the Common Language Runtime. For a real-work example, see this repository which contains the Windows 10 calculator. The application is built using standard C++ 11 and C++/CX, with a calculation engine that dates back from 1995. Made by possible with mono via Uno Platform.
  • Blazor - a web UI framework using C#/Razor and HTML, running client-side via WebAssembly. Source is maintained on ASP.Net Core repo.
  • Bolero - Bolero brings Blazor to F# developers with an easy to use Model-View-Update architecture, HTML combinators, hot reloaded templates, type-safe endpoints, advanced routing and remoting capabilities, and more.

AssemblyScript top⇈

AssemblyScript is a new compiler targeting WebAssembly while utilizing TypeScript's syntax and node's vibrant ecosystem. Instead of requiring complex toolchains to set up, you can simply npm install it - or run it in a browser.


Astro top⇈

Astro is a fun safe language for rapid prototyping and high performance applications.

  • Astro - main repository. Unmaintained

Brainfuck top⇈

Brainfuck is an esoteric programming language created in 1993 by Urban Müller, and notable for its extreme minimalism. The language consists of only eight simple commands and an instruction pointer. While it is fully Turing-complete, it is not intended for practical use, but to challenge and amuse programmers.

  • BrainfuckWebassembly - a simple Brainfuck-to-wasm compiler in one function.
  • Brainfuck2Wasm - a Brainfuck-to-wasm compiler and playground.
  • BrainfuckRsWasm - a Brainfuck interpreter written in Rust and compiled to WebAssembly.
  • bfwasm - A non-optimizing Brainf_ck to WebAssembly compiler with WASI support.

C is a general-purpose, imperative computer programming language, supporting structured programming, lexical variable scope and recursion, while a static type system prevents many unintended operations. C was originally developed by Dennis Ritchie between 1969 and 1973 at Bell Labs,[6] and used to re-implement the Unix operating system.

  • Emscripten - an LLVM-to-JavaScript/Webassembly compiler. It takes LLVM bitcode - which can be generated from C/C++, using llvm-gcc (DragonEgg) or clang, or any other language that can be converted into LLVM - and compiles that into JavaScript or wasm.
  • Cheerp - an open-source, commercial C/C++ compiler for Web applications. It can compile virtually any C/C++ code (up to C++14) to WebAssembly, JavaScript, asm.js or a combination thereof.

C# is a multi-paradigm programming language encompassing strong typing, imperative, declarative, functional, generic, object-oriented (class-based), and component-oriented programming disciplines. Its development team is led by Anders Hejlsberg. WebAssembly support is achieved through Blazor.


C++ top⇈

C++ is a general-purpose programming language. It has imperative, object-oriented and generic programming features, while also providing facilities for low-level memory manipulation. It was designed with a bias toward system programming and embedded, resource-constrained and large systems, with performance, efficiency and flexibility of use as its design highlights. The development of the language was started in 1979 by Bjarne Stroustrup as a "C with Classes".

  • See C.

Clean top⇈

Clean is a general purpose, state-of-the-art, pure and lazy functional programming language designed for making real-world applications. Some of its most notable language features are uniqueness typing, dynamic typing, and generic functions.

  • ABC interpreter - interpreter for Clean's intermediate language ABC, with a WebAssembly version.
  • iTasks - integration of the above ABC interpreter with browser applications.

A programming language similar to Go and TypeScript.

  • Co - main repository

COBOL top⇈

COBOL is a compiled English-like programming language designed for business use. It is imperative, procedural, and object-oriented. COBOL is primarily used in business, finance, and administrative systems.


D is a general-purpose programming language with static typing, systems-level access, and C-like syntax.

  • LDC - LLVM-based D compiler, which can generate WASM since version 1.11.0.

Eel top⇈

Eel is a small language used for, among other things, writing visualizer "presets" for Milkdrop, the music visualization program which came with Winamp.

  • eel-wasm - Compiles Milkdrop flavored Eel to Wasm in the browser. Intended to become a component of Butterchurn, a WebGL implementation of the Milkdrop Visualizer.

Elixir top⇈

Elixir is a dynamic, functional language designed for building scalable and maintainable applications. Elixir builds on top of Erlang and shares the same abstractions for building distributed, fault-tolerant applications.

  • ElixirWasm - an elixir compiler for wasm. [Unmaintained]
  • Lumen - An alternative BEAM implementation (with AOT compiler) designed for WebAssembly.

F# is a mature, open source, cross-platform, functional-first programming language. It empowers users and organizations to tackle complex computing problems with simple, maintainable and robust code. WebAssembly support is achieved through Bolero, a set of free and open-source libraries and tools built on top of Blazor. F# was mainly conceived by Don Syme of Microsoft Research but it's now maintained by the F# Foundation and its community.


Faust top⇈

Faust (Functional Audio Stream) is a functional programming language specifically designed for real-time signal processing and synthesis. A distinctive characteristic of Faust is to be fully compiled.

  • Faust - main repository.

Forest top⇈

Forest is a functional programming language that compiles to WebAssembly. The main repo contains the compiler and core syntaxes, currently implemented in Haskell.


Forth top⇈

Forth is an interactive, extensible, imperative, untyped, stack-based programming language.


Go is a statically typed compiled language in the tradition of C, with memory safety, garbage collection, structural typing, and CSP-style concurrent programming features added.

  • Go - main repository.
  • TinyGo - a subset of Go targeted to embedded devices and WebAssembly.

Grain top⇈

Grain is a strongly-typed functional programming language built for the modern web.


Haskell top⇈

Haskell is a standardized, general-purpose purely functional programming language, with non-strict semantics and strong static typing. It is named after logician Haskell Curry.[1] The latest standard of Haskell is Haskell 2010. As of May 2016, a group is working on the next version, Haskell 2020.

  • Asterius - a Haskell to WebAssembly compiler
  • DHC - a Haskell compiler that accepts only a tiny subset of the language and produces WebAssembly binaries.
  • HaskellWasm - a Haskell compiler infrastructure for generating WebAssembly. [Unmaintained]
  • haskell-wasm - Haskell WebAssembly Toolkit. It includes Language helpers and a fully spec-compatible WASM interpreter.
  • wasm-cross - A toolchain for cross compiling C and Haskell to WebAssembly, using the WebGHC and LLVM.

Idris top⇈

Idris is a general purpose pure functional programming language with dependent types. Dependent types allow types to be predicated on values, meaning that some aspects of a program’s behaviour can be specified precisely in the type. It is compiled, with eager evaluation. Its features are influenced by Haskell and ML.


Java top⇈

Java is a general-purpose computer programming language that is concurrent, class-based, object-oriented, and specifically designed to have as few implementation dependencies as possible. It is intended to let application developers "write once, run anywhere" (WORA), meaning that compiled Java code can run on all platforms that support Java without the need for recompilation. Java was originally developed by James Gosling at Sun Microsystems and released in 1995 as a core component of Sun Microsystems' Java platform. The language derives much of its syntax from C and C++, but it has fewer low-level facilities than either of them.

  • TeaVM - an ahead-of-time translating compiler (transpiler) of Java bytecode, that's capable of emitting JavaScript and WebAssembly.
  • JWebAssembly - A Java bytecode to WebAssembly compiler. It can generate the WebAssembly binary or text format. It is written in Java itself and can be integrated with other Java build tools.
  • Bytecoder - A Rich Domain Model for Java Bytecode and Framework to interpret and transpile it to other languages such as JavaScript, OpenCL or WebAssembly.
  • CheerpJ - A Java compiler for the web that converts any Java client application into standard HTML5/WebAssembly/JavaScript.

JavaScript top⇈

JavaScript is a high-level, interpreted programming language that conforms to the ECMAScript specification. It is a language that is also characterized as dynamic, weakly typed, prototype-based and multi-paradigm.

  • Duktape - an embeddable Javascript engine, with a focus on portability and compact footprint that's capable of being run in the browser via WebAssembly.

Julia top⇈

Julia was designed from the beginning for high performance. Julia programs compile to efficient native code for multiple platforms via LLVM.


Kotlin top⇈

Kotlin is a statically-typed programming language that runs on the Java virtual machine and also can be compiled to JavaScript source code or use the LLVM compiler infrastructure. Its primary development is from a team of JetBrains programmers based in Saint Petersburg, Russia. While the syntax is not compatible with Java, Kotlin is designed to interoperate with Java code and is reliant on Java code from the existing Java Class Library, such as the collections framework.


Kou top⇈

A minimal language compiled into wasm bytecode.

  • Kou - main repository.

Lisp top⇈

Lisp (historically LISP) is a family of programming languages with a long history and a distinctive, fully parenthesized prefix notation.

  • Femto Emacs - translates Low Level Lisp into WebAssembly.

Lobster top⇈

Lobster is a statically typed language with flow-sensitive type inference and specialization, compile time reference counting (lifetime analysis) that looks a bit like Python. It was originally intended specifically for games. Lobster has its own Wasm backend that compiles directly to linkable (with LLD) .wasm files.


Lua top⇈

Lua is a lightweight, multi-paradigm programming language designed primarily for embedded systems and clients.[2] Lua is cross-platform, since the interpreter is written in ANSI C, and has a relatively simple C API. Lua was originally designed in 1993 as a language for extending software applications to meet the increasing demand for customization at the time.

  • WasmLua - a Lua VM running in the browser.
  • Luwa - a wasm-to-Lua JIT compiler.
  • Wasmoon - a high level Lua VM with JS bindings.
  • Wasm2Lua - can compile WebAssembly modules to pure Lua (or with FFI LuaJIT for extra speed).

Lys top⇈

Lys is a typed functional language that compiles directly to WebAssembly.

  • Lys - main repository.

Never top⇈

Never is a simple functional programming language. Technically it may be classified as syntactically scoped, strongly typed, call by value, functional programming language.


Nim top⇈

A fringe language with some beautiful design patterns.

  • nlvm - LLVM-based compiler for Nim with a WebAssembly target supported out of the box
  • nwasm - a webassembly backend for nim.
  • Nim wasm helpers - a helper to set up a VM configured to build WebAssembly code using Nim.

Ocaml top⇈

OCaml, originally named Objective Caml, is the main implementation of the programming language Caml, created by Xavier Leroy, Jérôme Vouillon, Damien Doligez, Didier Rémy, Ascánder Suárez and others in 1996. A member of the ML language family, OCaml extends the core Caml language with object-oriented programming constructs.

  • Ocaml - a fork of main repo contianing work on OCaml to wasm compilation.
  • OcamlRun - a build script for compiling OCaml bytecode interpreter to wasm using emscripten [Unmaintained]

Pascal top⇈

Pascal is a general purpose imperative, procedural and object-oriented static typing programming language. The Free Pascal compiler targets many processor architectures, including wasm32; operating systems, including WASI; and embedded platforms.

  • Free Pascal - Free Pascal compilation target and Pascal-to-Javascript runtime.

Perl top⇈

Perl is a general-purpose programming language originally developed for text manipulation and now used for a wide range of tasks including system administration, web development, network programming, GUI development, and more.


PHP top⇈

PHP is a general-purpose scripting language that is especially suited to server-side web development, in which case PHP generally runs on a web server. Any PHP code in a requested file is executed by the PHP runtime, usually to create dynamic web page content or dynamic images used on websites or elsewhere.

  • PIB - a PHP runtime in the browser.
  • PHP WASM - maintained fork of PIB with PHP 8 support based on the work of seanmorris.

Plorth top⇈

Plorth is stack based, concatenative, strongly typed functional scripting language which is easy to embed to applications written in C++. It's inspired by Forth and Factor programming languages.


Poetry top⇈

Poetry is a poetically dynamic and simple programming language that compiles to WebAssembly. It has a minimalisting syntax akin to CoffeeScript and gives you full control over wasm imports and exports.


Python top⇈

Python is an open source interpreted high-level programming language for general-purpose programming. Created by Guido van Rossum and first released in 1991, Python has a design philosophy that emphasizes code readability, notably using significant whitespace. It provides constructs that enable clear programming on both small and large scales.

  • Pyodide - a port of Python to WebAssembly that includes the core packages of the scientific Python stack (Numpy, Pandas, matplotlib). Objects transparently convert and share between Python and Javascript.
  • MicroPython - a lean and efficient Python implementation for microcontrollers and constrained systems.
  • RustPython - A Python 3 interpreter written in Rust. Check the demo here

Prolog top⇈

Prolog is a general-purpose logic programming language associated with artificial intelligence and computational linguistics. Prolog has its roots in first-order logic, a formal logic, and unlike many other programming languages, Prolog is intended primarily as a declarative programming language: the program logic is expressed in terms of relations, represented as facts and rules. A computation is initiated by running a query over these relations.

  • SWI-Prolog port to WebAssembly - a port of SWI-Prolog to WebAssembly. SWI-Prolog is a free implementation of the programming language Prolog commonly used for teaching and semantic web applications.
  • Ciao Prolog - includes a WebAssembly compilation target based on Emscripten. Ciao Prolog is a modern Prolog implementation designed to be portable, extensible and modular. Check the playground here.

Ruby top⇈

Ruby is an open source interpreted high-level programming language for general-purpose programming. Created by Matz. Ruby has a design philosophy that emphasizes code readability, notably using as few sigils (special chars:.{}%[]&=>;) as possible.

  • Wruby Web ruby - a port of minimal ruby (mruby).
  • run.rb run.rb - allows you to run Ruby code in the browser
  • Artichoke - a Ruby implementation written in Rust and Ruby. You can try it out here: https://artichoke.run

Rust top⇈

Rust is a systems programming language sponsored by Mozilla Research, which describes it as a "safe, concurrent, practical language,"supporting functional and imperative-procedural paradigms. Rust is syntactically similar to C++, but its designers intend it to provide better memory safety while maintaining performance.

  • Rust wasm32-unknown-unknown target - Rust compiler backend for WebAssembly (without the need for Emscripten).
  • Wargo - a simple npm package that makes compiling Rust to WebAssembly easy on macOS or Linux.
  • RustWasmLoader - A simple Webpack loader that shells out to cargo to build a Rust project targeting WebAssembly.
  • CargoWeb - This cargo subcommand aims to make it easy and convenient to build, develop and deploy client-side Web applications written in Rust.
  • Wasm-Bindgen - A library and a CLI for Rust that facilitate high-level interactions between wasm modules and JavaScript.
  • Woz - Woz is a WebAssembly progressive web app (PWA) toolchain for building and deploying performant mobile apps with Rust. Distributing your app is as simple as sharing a hyperlink.

Scheme top⇈

Scheme is a programming language that supports multiple paradigms, including functional programming and imperative programming, and is one of the two main dialects of Lisp. Unlike Common Lisp, the other main dialect, Scheme follows a minimalist design philosophy specifying a small standard core with powerful tools for language extension..

  • Schism - Schism is an experimental self-hosting compiler from a subset of R6RS Scheme to WebAssembly. Development so far has focused on features necessary for self-hosting. The compiler itself is written in, and compiles, a very small subset of Scheme.

Scopes top⇈

Scopes is a general purpose programming language and compiler infrastructure specifically suited for short turnaround prototyping and development of high performance applications in need of multi-stage compilation at runtime.


Speedy.js top⇈

Speedy.js is a compiler for a well considered, performance pitfalls free subset of JavaScript targeting WebAssembly. Because WebAssembly is statically-typed, the project uses TypeScript as type-checker and to resolve the types of the program symbols.


Swift top⇈

Swift is a general-purpose, multi-paradigm, compiled programming language developed by Apple Inc. for iOS, macOS, watchOS, tvOS, Linux, and z/OS.


TurboScript top⇈

TurboScript is an experimental programming language for parallel programming for web which compiles to JavaScript (asm.js) and WebAssembly (targeting post-MVP). The syntax is similar to TypeScript and the compiler is open source and written in TypeScript. TurboScript has zero dependencies.


TypeScript top⇈

TypeScript is an open-source programming language developed and maintained by Microsoft. It is a strict syntactical superset of JavaScript, and adds optional static typing to the language.


Wah top⇈

Wah is a slightly higher level language that is a superset of WebAssembly. It aims to make WebAssembly's text format slightly more friendly to humans, without introducing new syntax or datatypes.

  • Wah - main repository. Unmaintained

WAlt top⇈

WAlt is an alternative syntax for WebAssembly text format. It's an experiment for using JavaScript syntax to write to as 'close to the metal' as possible. It's JavaScript with rules. .walt files compile directly to WebAssembly binary format.

  • Walt - main repository. Unmaintained

Wam top⇈

WebAssembly Macro language: Wam syntax is a near superset of wast syntax that is more convenient for human developers to write directly.

  • Wam - main repository. Unmaintained

Wase top⇈

WASE: WebAssembly made easy. Wase is a language, which tries to make WASM easy to write. The language maps closely to WebAssembly, and compiles directly to Wasm bytecode. Has strong typing with type inference.

  • Wase - main repository.

WebAssembly top⇈

Yes, WebAssembly. Wasm3 is the fastest WebAssembly interpreter, that enables WebAssembly self-hosting.


Wracket top⇈

A lisp-like language that compiles to WebAssembly, written in racket

  • Wracket - main repository. Unmaintained

Zig top⇈

Zig is a general-purpose programming language designed for robustness, optimality, and maintainability.


Please read the contribution guidelines if you want to contribute.


License

CC0

To the extent possible under law, Steve Akinyemi has waived all copyright and related or neighboring rights to this work.