Compiling FS-UAE
These instructions are for you if you want to build your own version of FS-UAE for any reason.
Please note that the resulting build may not be built in a way that's suitable for distribution to other users. Often, you need to take additional steps to ensure that the packages work on systems with older operating system versions.
Setting up a build environment
First, you need to prepare your build environment. Instructions for several operating systems are listed below.
Debian / Ubuntu
Install dependencies for bootstrapping and building FS-UAE:
sudo apt install autoconf automake build-essential gettext \
libfreetype6-dev libglew-dev libglib2.0-dev libjpeg-dev libmpeg2-4-dev \
libopenal-dev libpng-dev libsdl2-dev libsdl2-ttf-dev libtool libxi-dev \
libxtst-dev zip zlib1g-dev
FIXME: Add portmidi
openSUSE
Install dependencies for bootstrapping and building FS-UAE:
sudo zypper install autoconf automake freetype2-devel gcc gcc-c++ gettext \
glib2-devel libpng-devel libtool libXi-devel openal-devel SDL2-devel zip
FIXME: Add portmidi
Fedora
Install dependencies for running bootstrap:
sudo dnf install autoconf automake libtool gettext
Install dependencies for building FS-UAE:
sudo dnf install SDL2-devel glib2-devel libpng-devel gcc gcc-c++ openal-devel libXi-devel zip libmpeg2-devel SDL2_ttf-devel glew-devel zlib-devel freetype-devel hicolor-icon-theme
FIXME: Add portmidi
Windows
Install latest msys2-x86_64 from www.msys2.org/ and follow the installation
instructions to get an updated MSYS2 installation. Then start
MSYS2 MinGW 64-bit
.
Install dependencies for bootstrapping and building FS-UAE:
pacman -S autoconf automake gettext libtool make \
mingw-w64-x86_64-freetype mingw-w64-x86_64-gcc mingw-w64-x86_64-glew \
mingw-w64-x86_64-glib2 mingw-w64-x86_64-libmpeg2 mingw-w64-x86_64-libpng \
mingw-w64-x86_64-openal mingw-w64-x86_64-SDL2 mingw-w64-x86_64-SDL2_ttf \
pkg-config zip
macOS
FIXME: Write new instructions for the fsdeps/ fsbuild scripts. Some build-time dependencies must be installed separately, for example via Homebrew:
brew install autoconf automake cmake dos2unix libtool m4 meson pkg-config \
wget
Install homebrew from https://brew.sh (follow their instructions) and then open a new terminal.
Install dependencies for bootstrapping and building FS-UAE:
brew install autoconf automake freetype gettext glew glib jpeg libmpeg2 \
libpng libtool openal-soft pkg-config sdl2 sdl2_ttf zlib
In order build FS-UAE itself, you need to have Apple's Xcode installed and command line tools for Xcode enabled.
Configuring and building FS-UAE
If you are using the git repository, you need to bootstrap with (skip if using source tarball):
./bootstrap
Run the configuration script (see the next section for options):
./configure
And finally, compile the fs-uae executable:
make
You can now run fs-uae from the source folder without installation:
./fs-uae
Configuration options
The configure script can be used to enable some additional features (but they might not work or even compile) and disable default features.
Please note, the only supported configuration is to build with the default option set or the ones listed below. Other options are provided for testing and debugging purposes - and also for your convenience, in the cases where it happens to work ;-).
Supported options:
--prefix=...
: Installation prefix (defaults to /usr/local).--disable-jit
: For platforms without UAE JIT support.--disable-x86
: Disable x86 bridgeboard emulation.
Source: https://github.com/FrodeSolheim/fs-uae/blob/master/docs/compiling.md