80's, 90's and early 2000s classic Macs that load instantly in a browser and have access to a large software library. The full collection is at infinitemac.org. Shortcuts are available for System 6, System 7, Mac OS 8, Mac OS 9 and KanjiTalk (Japanese). For a high-level overview and the backstory, see the launch blog post and subsequent ones.
This project uses Git LFS. Ensure that the LFS tooling is installed before cloning the repo.
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).
Dependencies need to be installed:
npm install
pip3 install -r requirements.txt
npm run build-tools
Supporting data files need to be generated. This will build a minimal set of files, sufficient for running System 1 through System 7.5.5.
npm run import-disks minimal
npm run import-cd-roms placeholder
npm run import-library placeholder
You can then run the local dev server:
npm run start
It will be running at http://localhost:3127.
Common development tasks, all done via npm run
:
start
: Run local dev server (at http://localhost:3127)import-emulator <emulator>
: Copy generated WebAssembly from an emulator submodule (only necessary if modifying the emulator cores, see below for how to rebuild them). The following emulators are supported:basiliskii
: Basilisk II from https://github.com/mihaip/macemusheepshaver
: SheepShaver from https://github.com/mihaip/macemuminivmac-Plus
(and others): Mini vMac variants from https://github.com/mihaip/minivmacdingusppc
: DingusPPC from https://github.com/mihaip/dingusppcprevious
: Previous from https://github.com/mihaip/previouspearpc
: PearPC from https://github.com/mihaip/pearpc
import-disks
: Build disk images for serving. Copies base OS images for the above emulators, and imports other software (found inLibrary/
) into an "Infinite HD" disk image. Chunks disk images and generates a manifest for serving.placeholder
may be passed in as an argument to only build System 1 through 7.5.5, to skip populating the "Infinite HD" disk image.- This will invoke the native macOS versions of Mini vMac and Basilisk II as a final step, to ensure that the generated disk has a valid desktop database. If they are not installed, a warning will be logged and the generated disk may take longer to mount.
- To speed up the Mini vMac building step, you can change its speed: press Control-S to bring up the speed menu, and then the A to choose "All Out"
- Note that both Mini vMac and Basilisk II will be launched as part of this process. Once they seem done and you can see Infinite HD, use the "Shut Down" command to cleanly turn off the emulated machine and then quit the respective emulator so that the task can continue.
import-cd-roms
: Build CD-ROM library (actual CD-ROMs are hosted on archive.org and other sites, the library contains metadata)placeholder
may be passed in as an argument to make an empty CD-ROM library
import-library
: Build downloads library (actual downloads are hosted on macintoshgarden.org and other sites, the library contains metadata)placeholder
may be passed in as an argument to make the script generate a minimal library that does not depend on a Macintosh Garden data dump.
Common deployment tasks (also done via npm run
)
build
: Rebuild for either local use (in thebuild/
directory) or for Cloudflare Worker usepreview
: Serve built assets locally using Vite's server (will be running at https://localhost:4127)worker-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)sync-disks
: Sync disk images to a Cloudflare R2 bucket.- Requires that rclone installed, it can be obtained via
sudo -v ; curl https://rclone.org/install.sh | sudo bash
- Should be done after disks are rebuilt with
import-disks
(and beforeworker-deploy
).
- Requires that rclone installed, it can be obtained via
Basilisk II, SheepShaver, Mini vMac and DingusPPC are the original 68K and PowerPC emulators that enable this project. They are hosted in separate repos and are included via Git submodules. Rebuilding them is only required when making changes to the emulator core, the generated files are in src/emulator
and included in the Git repository.
To begin, ensure that you have a Docker image built with the Emscripten toolchain and supporting libraries:
docker build -t macemu_emsdk .
Open a shell into the Docker container:
scripts/docker-shell.sh
Once in that container, you can use a couple of helper scripts to build them:
cd /macemu/BasiliskII/src/Unix
# Bootstrap Basilisk II, to generate the CPU emulator code
./_embootstrap.sh
# Switch into building for WASM
./_emconfigure.sh
# Actually compile Basilisk II targeting WASM
make -j8
Once it has built, use npm run import-emulator basiliskii
from the host to update the files in src/emulator
.
cd /macemu/SheepShaver/src/Unix
# Configure for building for WASM
./_emconfigure.sh
# Actually compile SheepShaver targeting WASM
make -j8
Once it has built, use npm run import-emulator sheepshaver
from the host to update the files in src/emulator
.
See this page for the full set set of build options (and this one for more estoeric ones).
cd /minivmac
# Configure for building for WASM
./emscripten_setup.sh
# This configures the Mac Plus model by default, alternative outputs can be
# configured with additional arguments:
# - `-m 128K -speed z`: Mac 128K (uses 1x speed by default to be more realistic)
# - `-m 512Ke`: Mac 512ke
# - `-m SE`: Mac SE
# - `-m II`: Mac II
# Actually compile Mini vMac targeting WASM
make -j8
Once it has built, use npm run import-emulator minivmac-<model>
from the host to update the files in src/emulator
.
cd /dingusppc
mkdir -p build
cd build
emcmake cmake -DCMAKE_BUILD_TYPE=Release ..
make dingusppc -j8
Once it has built, use npm run import-emulator dingusppc
from the host to update the files in src/emulator
.
cd /previous
mkdir -p build
cd build
emcmake cmake -DCMAKE_BUILD_TYPE=Release -DENABLE_RENDERING_THREAD=0 ..
make previous -j8
Once it has built, use npm run import-emulator previous
from the host to update the files in src/emulator
.
cd /pearpc
# Configure for building for WASM
./_emconfigure.sh
# Actually compile PearPC targeting WASM
make -j8
Once it has built, use npm run import-emulator pearpc
from the host to update the files in src/emulator
.