Fork of the Basilisk II Macintosh emulator modified to be compiled to WebAssembly and run in the browser. Part of the Infinite Mac, see its README and introductory blog post for more details.
Based on James Friend's original browser port of Basilisk II.
The TECH document describes the basic Basilisk II architecture. The WebAssembly port ends up being a modified Unix version, with a subset of Unix implementations of Basilisk II parts are replaced with JavaScript-based ones. They generally use the ES_ASM() macros to call into JavaScript code, with EmulatorWorkerApi
in the infinite-mac repo serving as the receiving endpoint.
The Basilisk emulator runs in an infinite loop (simulating the classic Mac and its CPU) thus it cannot yield to the browser's event loop. Therefore it is executed in a web worker, which interacts with the main browser thread for input and output. SharedArrayBuffer
s and Atomics
operations are used to efficiently communicate with the worker in the absence of postMessage
/message
event handlers.
Not a standalone project, see the build instructions in the infinite-mac repo for details on how to build this.