Java Apple Computer Emulator
Go to file
2024-08-27 23:46:42 -05:00
images Fix broken images 2024-07-01 14:10:15 -05:00
src Better handling of zero period values, still silencing if period <= 1 though 2024-08-27 23:46:42 -05:00
.gitignore Add Mac ARM support 2024-08-01 10:21:28 -05:00
.gitmodules Fixed a lot of weird CPU bugs and added the 65c02 singe step tests 2024-08-25 23:07:32 -05:00
.java-version Remove lawless music selection, add additional default cards 2024-07-07 16:23:41 -05:00
.travis.yml Giving up on the multi-line idea for now 2017-12-26 11:48:27 -06:00
LICENSE Update LICENSE to Apache 2.0 2024-07-01 14:17:13 -05:00
manifest.mf Initial version: Based on last source available in SourceForge, converted to a Maven project format 2014-09-07 16:10:04 -05:00
pom.xml Added single step tests and fixed a lot of CPU bugs 2024-08-25 23:07:51 -05:00
README.md Update README.md 2024-08-04 11:14:52 -05:00

Java Apple Computer Emulator

Jace is a mature cycle-accurate emulation of an Apple //e computer. The full library of software for that series is 100% compatible with this emulator, as well as many popular hardware add-ons such as:

  • Joysticks (emulated by mouse or using real gamepads)
  • Mouse
  • Extended 80 Column card or Ramworks (Apple memory expansion compatible)
  • Ramfactor
  • Floppy drives (up to 14 supported)
  • Hard drives (up to 12 supported) and 800kb disk images
  • Mockingboard/Applied engineering Phasor (up to 6 supported)
  • Passport MIDI Interface
  • Super Serial Card (over TCP/IP emulation)
  • Transwarp / Zip Chip
  • Thunderclock / NoSlot Clock
  • Apple RGB graphics modes

Other features of Jace include:

  • Small IDE for programming Applesoft basic and Assembly (via built-in ACME cross assembler)
  • Cheat features for some popular games like Prince of Persia, Montezuma's Revenge, Wolfenstein and more
  • Metacheat feature allows searching memory for discovering new game cheats/mods

Download:

To Run:

  • The easiest way to run Jace is by downloading a native build from gitub (see releases link above)

Running the standard java version of Jace requires you have installed Java 17 or later.

  • If you are building from source you can use any of the following:
    • mvn javafx:run
    • mvn gluonfx:run (Note: gluonfx plugin currently only supports up to Maven 3.8.8)

To Build natively:

In order to build Jace as a native application you need to install the following:

The Gluon instructions have more details about where to find and download these components. Once you have them installed you can test the Java version via mvn gluonfx:run and if that is working correctly, then you can use mvn gluonfx:build to create a native binary in the target/gluonfx folder for your local platform. Gluon is only able to build for the OS you are running it on, so building for multiple platforms requires separate windows, mac and linux machines.

The Gluon documentation provides a compatibility matrix for each OS platform and the prerequisites needed to create native applications on each. See here for more details: https://docs.gluonhq.com/#_platforms

All other native dependencies are automatically downloaded as needed by Maven for the various LWJGL libraries.

First time build note:

Because Jace provides an annotation processor for compilation, there is a chicken-and-egg problem when building the first time. Currently, this means the first time you compile, run mvn install twice. You don't have to do this step again as long as Maven is able to find a previously build version of Jace to provide this annotation processor. I tried to set up the profiles in the pom.xml so that it disables the annotation processor the first time you compile to avoid any issues. If running in a CICD environment, keep in mind you will likely always need to run the "mvn install" step twice, but only if your goal is to build the entire application including the annotations (should not be needed for just running unit tests.)

Support JACE:

JACE will always be free, and remain Apache-licensed, but it does take considerable time to refine and add new features. If you would like to show your support and encourage the author to keep maintaining this emulator, why not throw him some change to buy him a drink? (The emulator was named for the Jack and Cokes consumed during its inception.) Also, should you want to use Jace under the terms of the Apache-license for commercial works, you are under no obligation to contribute any source code modifications or royalties to me, but I would appreciate you credit and mention my project and let me know about it.

Donate here to support Jace developement:

More information here: https://sites.google.com/site/brendanrobert/projects/java-apple-computer-emulator