A Mac with everything you'd want in 1995. Available in System 7, Mac OS 8 and KanjiTalk (Japanese) flavors. For a high-level overview and the backstory, see this blog post.
This project uses submodules, use git clone --recursive https://github.com/mihaip/infinite-mac.git
to clone it (or run git submodule update --init --recursive
if you have an existing checkout).
Common development tasks, all done via npm run
:
start
: Run local dev server (will be running at http://localhost:3127).import-basilisk-ii
: Copy generated WebAssembly from the https://github.com/mihaip/macemu submodule.import-disks
: Build disk images for serving. Copies base OS images from the above, and imports other software (found inLibrary/
) into an "Infinite HD" disk image. Chunks disk images and generates a manifest for serving.
Common deployment tasks (also done via npm run
)
build
: Rebuild for either local use (in thebuild/
directory) or for Cloudflare Worker useworker-dev
: Preview built assets in a local Cloudflare Worker (requires a separatebuild
invocation, result will be running at http://localhost:3128)worker-deploy
: Deploy built assets to the live version of the Cloudflare Worker (requires a separatebuild
invocation)
Dependencies can be installed with:
npm install -g wrangler
npm install
pip3 install -r requirements.txt
npm run build-xadmaster
This is only required when making changes to Basilisk II, the generated files are in src/BasiliskII
and included in the Git repository.
To begin, ensure that you have a Docker image built with the Emscripten toolchain and supporting library:
docker build -t macemu_emsdk .
Open a shell into the Docker container:
docker run --rm -it -v `realpath macemu`:/macemu --entrypoint bash macemu_emsdk
Once in that container, you can use this cheat sheet to build (based on the original instructions):
cd /macemu/BasiliskII/src/Unix
# Bootstrap Basilisk II, to generate the CPU emulator code
macemujs_conf_native=1 ./_embuild.sh && make clean && make -j6 cpuemu.cpp
# Switch into building for WASM
./_embuild.sh && make mostlyclean
# Actually compile Basilisk II targetting WASM
make -j6
Once you have it build, use npm run import-basilisk-ii
from the host to update the files in src/BasiliskII
.