= WebAssembly ebook Over the past few decades, the web browser has endured as the most popular cross-platform application. Looking at the browser from a different angle, though, it is itself one of the most popular platforms for application delivery. Think of all the websites you use that take the place of activities you used to do with software running on your desktop. You're still using software, but you're accessing it through a browser, and it's running on somebody else's Linux server. In the eternal effort to optimize the software we all use, the world of software development introduced WebAssembly back in 2019 as a way to run compiled code through a web browser. Application performance is better than ever, and the options for coding goes far beyond the usual list of PHP, Python, and Javascript. == A target and a language One of the powerful but also most confusing things about WebAssembly is that the term "webassembly" refers to both a language and a target. WebAssembly is an assembly language, but not many people choose to write code directly in assembly. Even the assembly language is ultimately converted to a binary format, which is what a computer requires to run code. This binary format is also called WebAssembly. This is good, though, because it means that you can use your choice of languages to write something that's ultimately delivered in WebAssembly, including C, C++, Rust, Javascript, and many others. The gateway into WebAssembly is Emscripten, an LLVM compiler toolchain that produces WebAssembly from your code. == Install Emscripten To install Emscripten on your Linux or macOS computer, use Git: [source,bash] ---- $ git clone \ https://github.com/emscripten-core/emsdk.git ---- Change directory into the `emsdk` directory and run the install command: [source,bash] ---- $ ./emsdk install latest $ ./emsdk activate latest ---- Everything in the Emscripten toolchain is installed within the `emsdk` directory and has no effect on the rest of your system. For this reason, before you use `emsdk`, you must source its environment: [source,bash] ---- $ source ./emsdk_env.sh ---- If you plan on using `emsdk` often, you can also source its environment setup script in `.bashrc`. To install Emscripten on Windows, you can run Linux in the WSL environment. Visit the https://emscripten.org/[Emscripten website] for more information on installation. == Hello world Here's a simple "hello world" application in written in C++. [source,c] ---- #include <iostream> using namespace std; int main() { cout << "Hello world"; return 0; } ---- Test it as a standard binary for your system first: [source,bash] ---- $ g++ hello.cpp -o world $ ./world Hello world ---- Seeing that it works as expected, use `emcc` to build it as WebAssembly: [source,bash] ---- $ emcc hello.cpp -o world.html ---- Finally, run it with `emrun`: [source,bash] ---- $ emrun ./world.html ---- The `emrun` utility is a convenience command for local testing. When you host your application on a server, `emrun` isn't necessary. image:emscripten-hello-world.webp[The Emscripten template for running text applications in a web browser.] == Learning more about WebAssembly Developing for WebAssembly can go in many different directions, depending on what you already know and what you're trying to build. If you know C or C++ then you can write your project using those, if you're learning Rust then you can use Rust, and even Python code can use the Pyodide module to run as WebAssembly. You have lots of options, and there's no wrong way to start (there's even a COBOL-to-WebAssembly compiler). If you're keen to get started with WebAssembly, download our complimentary eBook.