Build instructions are set out by operating system below:
These instructions assume that you have the GNU C/C++ compilers and basic build utilities (make, pkg-config, ar) on your system. This means the "build-essential" and "pkg-config" packages on Debian or Ubuntu-based distributions. Other distributions should have similar packages available.
Install the following libraries and related headers on your system:
Extract the Attract-Mode source to your system.
From the directory you extracted the source into, run:
make -j 3
or, if you are building on a Raspberry Pi, O-Droid or another embedded system, you can build the OpenGL ES version with the following:
make -j 3 USE_GLES=1
This step will create the "attract" executable file.
The final step is to actually copy the Attract-Mode executable and data to a location where they can be used. To install on a system-wide basis you should run:
sudo make install
This will copy the "attract" executable to /usr/local/bin/
and default
data to /usr/local/share/attract/
For a single user install on Linux or FreeBSD, you can complete this step
by copying the contents of the "config" directory from the Attract-Mode
source directory to the location that you will use as your Attract-Mode
config directory. By default, this config directory is located in
$HOME/.attract
on Linux/FreeBSD systems.
NOTE: The Attract-Mode makefile tries to follow the GNU standards for
specifying installation directories: https://www.gnu.org/prep/standards/html_node/Directory-Variables.html.
If you want to change the location where Attract-Mode looks for its default
data from /usr/local/share/attract
you should change these values
appropriately before running the make
and make install
commands.
These instructions assume that you have X Code installed.
Install Homebrew (http://brew.sh). This can be done by running the following command at a terminal command prompt:
ruby -e "$(curl -fsSL https://raw.github.com/Homebrew/homebrew/go/install)"
Install the "pkg-config", "ffmpeg", "sfml" and "libarchive" homebrew recipes:
brew update
brew install pkg-config ffmpeg sfml libarchive
Extract the Attract-Mode source to your system.
From the directory you extracted the Attract-Mode source into, run:
make -j 3
This step will create the "attract" executable file.
The final step is to actually copy the Attract-Mode executable and data to the location where they will be used. You can run:
sudo make install
to install on a system-wide basis. This will copy the 'attract' executable
to /usr/local/bin/
and data to /usr/local/share/attract/
If you prefer to do a single user install, you can complete this step by
copying the contents of the "config" directory from the Attract-Mode
source directory to the location that you will use as your Attract-Mode
config directory. By default, this config directory is $HOME/.attract
on
OS X.
The recommended way to build Windows binaries for Attract-Mode is to cross compile on an OS that supports MXE (http://mxe.cc) such as Linux, FreeBSD or OS X.
Follow the steps in the mxe tutorial to set up mxe on your system: http://mxe.cc/#tutorial
Make mxe's sfml, ffmpeg and libarchive packages:
make ffmpeg sfml libarchive
the above command will make 32-bit versions of ffmpeg and sfml (and anything else that they depend on). To make the 64-bit version use the following:
make MXE_TARGETS='x86_64-w64-mingw32.static' ffmpeg sfml
Extract the Attract-Mode source to your system.
From the directory you extracted the source into, run the following:
make -j 3 CROSS=1 TOOLCHAIN=i686-w64-mingw32.static WINDOWS_STATIC=1
to build the 32-bit version of Attract-Mode. To build 64-bit, run:
make -j 3 CROSS=1 TOOLCHAIN=x86_64-w64-mingw32.static WINDOWS_STATIC=1
This step will create the "attract.exe" executable file.
Copy the contents of the config directory from the Attract-Mode source directory and the executable you just built into the same directory on your Windows-based system, and you should be ready to go!
Install MSYS2 https://msys2.github.io/
Launch the MSYS2 shell and update the system:
pacman --needed -Sy bash pacman pacman-mirrors msys2-runtime`
Close MSYS2 Shell, run it again and run the following command:
pacman -Syu
Install required packaged. (optionally use the mingw-w64-i686-toolchain instead for 32-bit windows architectures):
pacman -S git mingw-w64-x86_64-toolchain msys/make mingw64/mingw-w64-x86_64-sfml mingw64/mingw-w64-x86_64-ffmpeg mingw64/mingw-w64-x86_64-libarchive
Clone and make Attract-Mode
git clone https://github.com/mickelson/attract attract
cd attract
make -j 3
This builds a version of Attract-Mode with various .dll dependencies. To
run the program, you will need to add c:\msys64\mingw6in
to your path
(for 64-bit systems) or copy the dependent .dlls from that directory into
the same directory you will run Attract-Mode from.