Hacker News new | ask | show | jobs
by err4nt 2904 days ago
I'm not an expert, but my understanding is that WASM has two formats: a text-based format called WAT, and a binary format called WASM.

In order to run the code in the browser, the code will have to be compiled to the binary format.

So where WAT comes in is your methods for producing WASM files now become one of the following:

Source in <otherlang> -> WAT -> WASM

Source in <otherlang> -> WASM

WAT -> WASM

So the human-readable WAT can either be used as a compile target for another language, which can easily be compiled into WASM, or you can write the WAT manually and compile it. Alternatively other languages might be able to compile directly to the binary format, skipping WAT representation entirely.

1 comments

Generally, WAT is produced from the binary format. Compilers don't go through WAT; they produce the binary output directly.

The translation between WAT and the binary format is lossless, so there's no advantage of producing WAT as an intermediate step.

Since WAT -> WASM is already easy to do, compiling <otherlanguage> to WAT makes it really easy for people to create their own abstractions for writing WebAssembly in nearly _any_ other programming language, not just those that can compile directly to the binary format.
I don't understand why that would be true.

It's also just as easy to get WASM from WAT as it is WAT from WASM. I don't know of any languages that compile to WAT and then compile to WASM; as far as I know 100% of languages compile directly to WASM.