Geargrafx is a cross-platform TurboGrafx-16 / PC Engine emulator written in C++ that runs on Windows, macOS, Linux, BSD and RetroArch.
This is an open source project with its ongoing development made possible thanks to the support by these awesome backers. If you find it useful, please, consider sponsoring.
Don't hesitate to report bugs or ask for new features by openning an issue.
- Windows:
- Geargrafx-1.0.0-windows-x64.zip
- Geargrafx-1.0.0-windows-arm64.zip
- NOTE: If you have errors you may need to install:
- macOS:
- Linux:
- Geargrafx-1.0.0-ubuntu-24.04.zip
- Geargrafx-1.0.0-ubuntu-22.04.zip
- Geargrafx-1.0.0-ubuntu-20.04.zip
- NOTE: You may need to install
libsdl2
andlibglew
- Save states with preview.
- Compressed rom support (ZIP).
- Supported platforms (standalone): Windows, Linux, BSD and macOS.
- Supported platforms (libretro): Windows, Linux, macOS, Raspberry Pi, Android, iOS, tvOS, PlayStation Vita, PlayStation 3, Nintendo 3DS, Nintendo GameCube, Nintendo Wii, Nintendo WiiU, Nintendo Switch, Emscripten, Classic Mini systems (NES, SNES, C64, ...), OpenDingux, RetroFW and QNX.
- Full debugger with just-in-time disassembler, cpu breakpoints, memory access breakpoints, code navigation (goto address, JP JR and CALL double clicking), debug symbols, automatic labels, memory editor, PSG inspector and video viewer including registries, tiles, sprites and backgrounds.
- Windows and Linux Portable Mode.
- Rom loading from the command line by adding the rom path as an argument.
- Support for modern game controllers through gamecontrollerdb.txt file located in the same directory as the application binary.
- Mouse Cursor: Automatically hides when hovering main output window or when Main Menu is disabled.
- Portable Mode: Create an empty file named
portable.ini
in the same directory as the application binary to enable portable mode. - Docking windows: In debug mode you can dock windows together by pressing SHIFT and drag'n drop a window into another.
- Debug multi-viewport: In Windows or macOS you can enable "multi-viewport" in debug menu. You must restart the emulator for the change to take effect. Once enabled you can drag debugger windows outside the main window.
- Debug Symbols: The emulator always tries to load a symbol file at the same time a rom is being loaded. For example, for
path_to_rom_file.rom
it tries to loadpath_to_rom_file.sym
. It is also possible to load a symbol file using the GUI or using the CLI. - Command Line Usage:
geargrafx [rom_file] [symbol_file]
- Install Microsoft Visual Studio Community 2022 or later.
- Open the Geargrafx Visual Studio solution
platforms/windows/Geargrafx.sln
and build.
- Install Xcode and run
xcode-select --install
in the terminal for the compiler to be available on the command line. - Run these commands to generate a Mac app bundle:
brew install sdl2
cd platforms/macos
make dist
- Ubuntu / Debian / Raspberry Pi (Raspbian):
sudo apt install build-essential libsdl2-dev libglew-dev libgtk-3-dev
cd platforms/linux
make
- Fedora:
sudo dnf install @development-tools gcc-c++ SDL2-devel glew-devel gtk3-devel
cd platforms/linux
make
- FreeBSD:
su root -c "pkg install -y git gmake pkgconf SDL2 glew lang/gcc gtk3"
cd platforms/bsd
gmake
- NetBSD:
su root -c "pkgin install gmake pkgconf SDL2 glew lang/gcc gtk3"
cd platforms/bsd
gmake
- Ubuntu / Debian / Raspberry Pi (Raspbian):
sudo apt install build-essential
cd platforms/libretro
make
- Fedora:
sudo dnf install @development-tools gcc-c++
cd platforms/libretro
make
Thank you to all the people who have already contributed to Geargrafx!
Geargrafx is licensed under the GNU General Public License v3.0 License, see LICENSE for more information.