nintengo
data:image/s3,"s3://crabby-images/877fe/877fed24aff3e49501d83a029c062fb4bb2b57c1" alt="Build Status"
An NES emulator written in Go
data:image/s3,"s3://crabby-images/87eaf/87eaf99dae4233a8844990dcccf0d4192cddb0e4" alt="Super Mario Bros. Super Mario Bros."
data:image/s3,"s3://crabby-images/d18a0/d18a075f0d0aaf50f5d77fd9985bf0c047470164" alt="Donkey Kong Donkey Kong"
data:image/s3,"s3://crabby-images/3f223/3f2234d685c3e76286a8d92b874e505d6d76928d" alt="Excitebike Excitebike"
data:image/s3,"s3://crabby-images/c5739/c57399cf045def6d41617d01a7b432ef99625600" alt="Legend of Zelda Legend of Zelda"
data:image/s3,"s3://crabby-images/03abf/03abfa7d72cc64157e1f853124c6996d651cfe52" alt="Punch-Out! Punch-Out!"
data:image/s3,"s3://crabby-images/3cb25/3cb253195c61c8bd3a489f818569f61c4547915f" alt="Super Mario Bros. 3 Super Mario Bros. 3"
data:image/s3,"s3://crabby-images/a962e/a962e04f6d54fd6c838d31f74c3df0ac2a92b0e0" alt="Mega Man 2 Mega Man 2"
Build
-
Install Azul3D by following the official
installation instructions for your
platform.
-
go get github.com/nwidger/nintengo
Usage
nintengo OPTIONS FILE
FILE can be a .nes file or a .nes file inside a .zip archive
-audio-recorder="": recorder to use: none | wav
-connect="": Connect to address as slave, <rom-file> will be ignored (e.g., 'localhost:8080')
-cpu-decode=false: decode CPU instructions
-cpu-profile="": write CPU profile to file
-http="": HTTP service address (e.g., ':6060')
-listen="": Listen at address as master (e.g., ':8080')
-mem-profile="": write memory profile to file
-recorder="": recorder to use: none | jpeg | gif
Controls
z - A
x - B
Enter - Start
Right Shift - Select
Arrow keys - Up/Down/Left/Right
p - Pause/Unpause
n - Toggle stepping by cycle/scanline/frame with p
r - Reset
q - Quit
F1 - save state
F5 - load state
F8 - 200% FPS (2x fast forward)
F9 - 100% FPS
F10 - 75% FPS
F11 - 50% FPS
F12 - 25% FPS
` - toggle overscan
1 - 256x240 screen size
2 - 512x480 screen size
3 - 768x720 screen size
4 - 1024x960 screen size
5 - 2560x1440 screen size
9 - Show/hide background
0 - Show/hide sprites
keypad 0 - toggle mute all channels
keypad 1 - toggle mute pulse 1 channel
keypad 2 - toggle mute pulse 2 channel
keypad 3 - toggle mute triangle channel
keypad 4 - toggle mute noise channel
l - Save pattern tables to left/right.jpg
o - Toggle CPU decoding
i - Toggle PPU decoding
with -recorder=gif:
s - Start recording to frame.gif
d - Stop recording
with -recorder=jpeg:
s - Save screenshot to frame.jpg
with -audio-recorder=wav:
keypad - (minus) - Start audio recording to audio.wav
keypad + (plus) - Stop audio recording
Support
Audio support is currently a work in progress. All audio channels
except the DMC channel are working in some capacity.
Battery backed saves is implemented and are saved to disk with a
.sav
file extension.
Save states are supported and are saved to disk with a .nst
file
extension.
Netplay
Nintengo includes two-player netplay support using the -listen
and
-connect
command-line arguments. To use, player one launches
nintengo and tells it to listen for incoming connections using the
-listen
flag:
nintengo -listen=:8080 FILE
Player two then connects to player one using the -connect
flag,
providing the server's host/port:
nintengo -connect=192.168.1.110:8080
Note that player two does not need to provide a FILE
argument.
Mappers
- NROM
- MMC1
- UNROM
- CNROM
- MMC3
- ANROM
- MMC2
Acknowledgments
This project would not have been possible without the amazing treasure
trove of information that is the
NESdev Wiki
and the fine folks at #nesdev
on EFnet.
Being able to read the source code of other NES emulators was also
extremely helpful. The following is a short list of the ones I
consulted most often, although it is probably not the complete list: