- CMake 2.8+
- Make
- GCC 4.6+
- Boost libraries (tested on 1.54, 1.58, 1.59, 1.61)
- Python 2.7+ or Python 3+ with Numpy and Boost.Python for Python binding (optional)
- JDK for Java binding (JAVA_HOME must be set) (optional)
- LUA 5.1 for Lua binding (optional)
Additionally, ZDoom dependencies are needed.
To get all dependencies (except JDK) on Ubuntu execute the following commands in the shell (requires root access):
# ZDoom dependencies
sudo apt-get install build-essential zlib1g-dev libsdl2-dev libjpeg-dev \
nasm tar libbz2-dev libgtk2.0-dev cmake git libfluidsynth-dev libgme-dev \
libopenal-dev timidity libwildmidi-dev
# Python 2 and Python 3 bindings dependencies
sudo apt-get install python-pip python3-pip
pip install numpy #just for python2 binding
pip3 install numpy #just for python3 binding
# Boost libraries
sudo apt-get install libboost-all-dev
In ViZDoom's root directory:
cmake -DCMAKE_BUILD_TYPE=Release -DBUILD_PYTHON=ON -DBUILD_JAVA=ON -DBUILD_LUA=ON
make
-DBUILD_PYTHON=ON
and -DBUILD_JAVA=ON
and -DBUILD_LUA=ON
CMake options for Python, Java and Lua bindings are optional (default OFF). To force building bindings for Python3 instead of first version found use -DBUILD_PYTHON3=ON
(needs Boost.Python builded with Python 3, default OFF).
- CMake 2.8+
- Visual Studio 2012+
- Boost libraries
- Python 2.7+ or Python 3.4+ with Numpy and Boost.Python for Python binding (optional)
- JDK for Java binding (JAVA_HOME must be set) (optional)
Additionally, ZDoom dependencies are needed.
Run CMake GUI, select ViZDoom's root directory and set paths to:
- BOOST_ROOT
- BOOST_INCLUDEDIR
- BOOST_LIBRARYDIR
- PYTHON_INCLUDE_DIR (optional)
- PYTHON_LIBRARY (optional)
- NUMPY_INCLUDES (optional)
- ZDoom dependencies paths
In configuration select BUILD_PYTHON, BUILD_PYTHON3 and BUILD_JAVA options for Python and Java bindings (optional, default OFF).
Use generated Visual Studio solution to build all ViZDoom's parts.
Untested, code is compatible, CMake still may need minor adjustments. Let us know if You are using ViZDoom on OSX.
- CMake 2.8+
- XCode 5+
- Boost libraries
- Python 2.7+ or Python 3+ with Numpy and Boost.Python for Python binding (optional)
- JDK for Java binding (JAVA_HOME must be set) (optional)
Additionally, ZDoom dependencies are needed.
Run CMake and use generated project.
Users with brew-installed Python may need to manually set:
-DPYTHON_INCLUDE_DIR=/usr/local/Cellar/python/2.x.x/Frameworks/Python.framework/Versions/2.7/include/python2.7
and
-DPYTHON_LIBRARY=/usr/local/Cellar/python/2.x.x/Frameworks/Python.framework/Versions/2.7/lib/libpython2.7.dylib
####Configuration
Craeting symlink to the app executable may be needed:
ln -sf vizdoom.app/Contents/MacOS/vizdoom bin/vizdoom
Compilation output will be placed in vizdoom_root_dir/bin
and it should contain following files.
bin/vizdoom / vizdoom.exe
- ViZDoom executablebin/vizdoom.pk3
- resources file used by ViZDoom (needed by ViZDoom executable)bin/libvizdoom.a / vizdoom.lib
- C++ ViZDoom static librarybin/libvizdoom.so / vizdoom.dll
- C++ ViZDoom dynamically linked librarybin/python/vizdoom.so / vizdoom.pyd
- ViZDoom Python modulebin/python3/vizdoom.so / vizdoom.pyd
- ViZDoom Python3 modulebin/java/libvizdoom.so / vizdoom.dll
- ViZDoom library for Javabin/java/vizdoom.jar
- Contains ViZDoom Java classesbin/lua/vizdoom.so / vizdoom.dll
- ViZDoom Lua module