mirror of
https://github.com/ddnet/ddnet.git
synced 2024-11-14 03:58:18 +00:00
317 lines
15 KiB
Markdown
317 lines
15 KiB
Markdown
[![DDraceNetwork](https://ddnet.tw/ddnet-small.png)](https://ddnet.tw) [![](https://github.com/ddnet/ddnet/workflows/Build/badge.svg)](https://github.com/ddnet/ddnet/actions?query=workflow%3ABuild+event%3Apush+branch%3Amaster)
|
|
|
|
Our own flavor of DDRace, a Teeworlds mod. See the [website](https://ddnet.tw) for more information.
|
|
|
|
Development discussions happen on #ddnet on Quakenet ([Webchat](http://webchat.quakenet.org/?channels=ddnet&uio=d4)) or on [Discord in the developer channel](https://discord.gg/xsEd9xu).
|
|
|
|
You can get binary releases on the [DDNet website](https://ddnet.tw/downloads/), find it on [Steam](https://store.steampowered.com/app/412220/DDraceNetwork/) or [install from repository](#installation-from-repository).
|
|
|
|
[Source Code Documentation](https://codedoc.ddnet.tw/) is available.
|
|
|
|
If you want to learn about the source code, you can check the [Development](https://wiki.ddnet.tw/wiki/Development) article on the wiki.
|
|
|
|
Cloning
|
|
-------
|
|
|
|
To clone this repository with full history and external libraries (~350 MB):
|
|
|
|
git clone --recursive https://github.com/ddnet/ddnet
|
|
|
|
To clone this repository with full history when you have the necessary libraries on your system already (~220 MB):
|
|
|
|
git clone https://github.com/ddnet/ddnet
|
|
|
|
To clone this repository with history since we moved the libraries to https://github.com/ddnet/ddnet-libs (~40 MB):
|
|
|
|
git clone --shallow-exclude=included-libs https://github.com/ddnet/ddnet
|
|
|
|
To clone the libraries if you have previously cloned DDNet without them:
|
|
|
|
git submodule update --init --recursive
|
|
|
|
Dependencies on Linux / macOS
|
|
-----------------------------
|
|
|
|
You can install the required libraries on your system, `touch CMakeLists.txt` and CMake will use the system-wide libraries by default. You can install all required dependencies and CMake on Debian or Ubuntu like this:
|
|
|
|
sudo apt install build-essential cmake git google-mock libcurl4-openssl-dev libssl-dev libfreetype6-dev libglew-dev libnotify-dev libogg-dev libopus-dev libopusfile-dev libpnglite-dev libsdl2-dev libsqlite3-dev libwavpack-dev python libx264-dev libavfilter-dev libavdevice-dev libavformat-dev libavcodec-extra libavutil-dev libvulkan-dev glslang-tools spirv-tools
|
|
|
|
On older distributions like Ubuntu 18.04 don't install `google-mock`, but instead set `-DDOWNLOAD_GTEST=ON` when building to get a more recent gtest/gmock version.
|
|
|
|
Or on CentOS, RedHat and AlmaLinux like this:
|
|
|
|
sudo yum install gcc gcc-c++ make cmake git python2 gtest-devel gmock-devel libcurl-devel openssl-devel freetype-devel glew-devel libnotify-devel libogg-devel opus-devel opusfile-devel pnglite-devel SDL2-devel sqlite-devel wavpack-devel libx264-devel ffmpeg-devel vulkan-devel glslang spirv-tools
|
|
|
|
Or on Arch Linux like this:
|
|
|
|
sudo pacman -S --needed base-devel cmake curl freetype2 git glew gmock libnotify opusfile python sdl2 sqlite wavpack x264 ffmpeg vulkan-icd-loader vulkan-headers glslang spirv-tools
|
|
|
|
There is an [AUR package for pnglite](https://aur.archlinux.org/packages/pnglite/). For instructions on installing it, see [AUR packages installation instructions on ArchWiki](https://wiki.archlinux.org/index.php/Arch_User_Repository#Installing_packages).
|
|
|
|
On macOS you can use [homebrew](https://brew.sh/) to install build dependencies like this:
|
|
|
|
brew install cmake freetype glew googletest opusfile SDL2 wavpack x264 ffmpeg molten-vk vulkan-headers glslang spirv-tools
|
|
|
|
If you don't want to use the system libraries, you can pass the `-DPREFER_BUNDLED_LIBS=ON` parameter to cmake.
|
|
|
|
Building on Linux and macOS
|
|
---------------------------
|
|
|
|
To compile DDNet yourself, execute the following commands in the source root:
|
|
|
|
mkdir build
|
|
cd build
|
|
cmake ..
|
|
make -j$(nproc)
|
|
|
|
Pass the number of threads for compilation to `make -j`. `$(nproc)` in this case returns the number of processing units. DDNet requires additional libraries, that are bundled for the most common platforms (Windows, Mac, Linux, all x86 and x86\_64). The bundled libraries are now in the ddnet-libs submodule.
|
|
|
|
The following is a non-exhaustive list of build arguments that can be passed to the `cmake` command-line tool in order to enable or disable options in build time:
|
|
|
|
* **-DCMAKE_BUILD_TYPE=[Release|Debug|RelWithDebInfo|MinSizeRel]** <br>
|
|
An optional CMake variable for setting the build type. If not set, defaults to "Release" if `-DDEV=ON` is **not** used, and "Debug" if `-DDEV=ON` is used. See `CMAKE_BUILD_TYPE` in CMake Documentation for more information.
|
|
|
|
* **-DPREFER_BUNDLED_LIBS=[ON|OFF]** <br>
|
|
Whether to prefer bundled libraries over system libraries. Setting to ON will make DDNet use third party libraries available in the `ddnet-libs` folder, which is the git-submodule target of the [ddnet-libs](https://github.com/ddnet/ddnet-libs) repository mentioned above -- Useful if you do not have those libraries installed and want to avoid building them. If set to OFF, will only use bundled libraries when system libraries are not found. Default value is OFF.
|
|
|
|
* **-DWEBSOCKETS=[ON|OFF]** <br>
|
|
Whether to enable WebSocket support for server. Setting to ON requires the `libwebsockets-dev` library installed. Default value is OFF.
|
|
|
|
* **-DMYSQL=[ON|OFF]** <br>
|
|
Whether to enable MySQL/MariaDB support for server. Requires at least MySQL 8.0 or MariaDB 10.2. Setting to ON requires the `libmariadbclient-dev` library installed, which are also provided as bundled libraries for the common platforms. Default value is OFF.
|
|
|
|
Note that the bundled MySQL libraries might not work properly on your system. If you run into connection problems with the MySQL server, for example that it connects as root while you chose another user, make sure to install your system libraries for the MySQL client. Make sure that the CMake configuration summary says that it found MySQL libs that were not bundled (no "using bundled libs").
|
|
|
|
* **-DTEST_MYSQL=[ON|OFF]** <br>
|
|
Whether to test MySQL/MariaDB support in GTest based tests. Note that this requires a running MySQL/MariaDB database on localhost with this setup:
|
|
|
|
```
|
|
CREATE DATABASE ddnet;
|
|
CREATE USER 'ddnet'@'localhost' IDENTIFIED BY 'thebestpassword';
|
|
GRANT ALL PRIVILEGES ON ddnet.* TO 'ddnet'@'localhost';
|
|
FLUSH PRIVILEGES;
|
|
```
|
|
|
|
* **-DAUTOUPDATE=[ON|OFF]** <br>
|
|
Whether to enable the autoupdater. Packagers may want to disable this for their packages. Default value is ON for Windows and Linux.
|
|
|
|
* **-DCLIENT=[ON|OFF]** <br>
|
|
Whether to enable client compilation. If set to OFF, DDNet will not depend on Curl, Freetype, Ogg, Opus, Opusfile, and SDL2. Default value is ON.
|
|
|
|
* **-DVIDEORECORDER=[ON|OFF]** <br>
|
|
Whether to add video recording support using FFmpeg to the client. Default value is ON.
|
|
|
|
* **-DDOWNLOAD_GTEST=[ON|OFF]** <br>
|
|
Whether to download and compile GTest. Useful if GTest is not installed and, for Linux users, there is no suitable package providing it. Default value is OFF.
|
|
|
|
* **-DDEV=[ON|OFF]** <br>
|
|
Whether to optimize for development, speeding up the compilation process a little. If enabled, don't generate stuff necessary for packaging. Setting to ON will set CMAKE\_BUILD\_TYPE to Debug by default. Default value is OFF.
|
|
|
|
* **-DUPNP=[ON|OFF]** <br>
|
|
Whether to enable UPnP support for the server.
|
|
You need to install `libminiupnpc-dev` on Debian, `miniupnpc` on Arch Linux.
|
|
|
|
* **-DVULKAN=[ON|OFF]** <br>
|
|
Whether to enable the vulkan backend.
|
|
On Windows you need to install the Vulkan SDK and set the `VULKAN_SDK` environment flag accordingly.
|
|
|
|
* **-GNinja** <br>
|
|
Use the Ninja build system instead of Make. This automatically parallizes the build and is generally faster. Compile with `ninja` instead of `make`. Install Ninja with `sudo apt install ninja-build` on Debian, `sudo pacman -S --needed ninja` on Arch Linux.
|
|
|
|
* **-DCMAKE_CXX_LINK_FLAGS=[FLAGS]** <br>
|
|
Custom flags to set for compiler when linking. With clang++ as the compiler this can be [used to link](https://github.com/rui314/mold#how-to-use) with [mold](https://github.com/rui314/mold), speeds up linking by a factor of ~10:
|
|
|
|
```bash
|
|
CC=clang CXX=clang++ cmake -DCMAKE_CXX_LINK_FLAGS="--ld-path=/usr/bin/mold" .
|
|
```
|
|
|
|
Running tests (Debian/Ubuntu)
|
|
-----------------------------
|
|
|
|
In order to run the tests, you need to install the following library `libgtest-dev`.
|
|
|
|
This library isn't compiled, so you have to do it:
|
|
```bash
|
|
sudo apt install libgtest-dev
|
|
cd /usr/src/gtest
|
|
sudo cmake CMakeLists.txt
|
|
sudo make -j8
|
|
|
|
# copy or symlink libgtest.a and libgtest_main.a to your /usr/lib folder
|
|
sudo cp lib/*.a /usr/lib
|
|
```
|
|
|
|
To run the tests you must target `run_tests` with make:
|
|
`make run_tests`
|
|
|
|
Code formatting
|
|
---------------
|
|
We use clang-format 10 to format the C++ code of this project. Execute `scripts/fix_style.py` after changing the code to ensure code is formatted properly, a GitHub central style checker will do the same and prevent your change from being submitted.
|
|
|
|
On Arch Linux you can install clang-format 10 using the [clang-format-static-bin AUR package](https://aur.archlinux.org/packages/clang-format-static-bin/). On macOS you can install clang-format 10 using a [homebrew tap](https://github.com/r-lib/homebrew-taps):
|
|
```bash
|
|
brew install r-lib/taps/clang-format@10
|
|
sudo ln -s /opt/homebrew/Cellar/clang-format@10/10.0.1/bin/clang-format /opt/homebrew/bin/clang-format-10
|
|
```
|
|
|
|
Using AddressSanitizer + UndefinedBehaviourSanitizer or Valgrind's Memcheck
|
|
---------------------------------------------------------------------------
|
|
ASan+UBSan and Memcheck are useful to find code problems more easily. Please use them to test your changes if you can.
|
|
|
|
For ASan+UBSan compile with:
|
|
```bash
|
|
CC=clang CXX=clang++ CXXFLAGS="-fsanitize=address,undefined -fsanitize-recover=address,undefined -fno-omit-frame-pointer" CFLAGS="-fsanitize=address,undefined -fsanitize-recover=address,undefined -fno-omit-frame-pointer" cmake -DCMAKE_BUILD_TYPE=Debug .
|
|
make
|
|
```
|
|
and run with:
|
|
```bash
|
|
UBSAN_OPTIONS=log_path=./SAN:print_stacktrace=1:halt_on_errors=0 ASAN_OPTIONS=log_path=./SAN:print_stacktrace=1:check_initialization_order=1:detect_leaks=1:halt_on_errors=0 ./DDNet
|
|
```
|
|
|
|
Check the SAN.\* files afterwards. This finds more problems than memcheck, runs faster, but requires a modern GCC/Clang compiler.
|
|
|
|
For valgrind's memcheck compile a normal Debug build and run with: `valgrind --tool=memcheck ./DDNet`
|
|
Expect a large slow down.
|
|
|
|
Building on Windows with Visual Studio
|
|
--------------------------------------
|
|
|
|
Download and install some version of [Microsoft Visual Studio](https://www.visualstudio.com/) (as of writing, MSVS Community 2017) with **C++ support**, install [Python 3](https://www.python.org/downloads/) **for all users** and install [CMake](https://cmake.org/download/#latest).
|
|
|
|
Start CMake and select the source code folder (where DDNet resides, the directory with `CMakeLists.txt`). Additionally select a build folder, e.g. create a build subdirectory in the source code directory. Click "Configure" and select the Visual Studio generator (it should be pre-selected, so pressing "Finish" will suffice). After configuration finishes and the "Generate" reactivates, click it. When that finishes, click "Open Project". Visual Studio should open. You can compile the DDNet client by right-clicking the DDNet project (not the solution) and select "Select as StartUp project". Now you should be able to compile DDNet by clicking the green, triangular "Run" button.
|
|
|
|
Cross-compiling on Linux to Windows x86/x86\_64
|
|
-----------------------------------------------
|
|
|
|
Install MinGW cross-compilers of the form `i686-w64-mingw32-gcc` (32 bit) or
|
|
`x86_64-w64-mingw32-gcc` (64 bit). This is probably the hard part. ;)
|
|
|
|
Then add `-DCMAKE_TOOLCHAIN_FILE=../cmake/toolchains/mingw64.toolchain` to the
|
|
**initial** CMake command line.
|
|
|
|
Cross-compiling on Linux to WebAssembly via Emscripten
|
|
--------------------------------------------------------
|
|
|
|
Install Emscripten cross-compilers (e.g. `sudo apt install emscripten`) on a modern linux distro.
|
|
|
|
If you need to compile the ddnet-libs for WebAssembly, simply call
|
|
|
|
```bash
|
|
# <directory to build in> should be a directory outside of the project's source directory
|
|
scripts/compile_libs/gen_libs.sh <directory to build in> webasm
|
|
```
|
|
|
|
from the project's source directory. It will automatically create a directory called `ddnet-libs`.
|
|
You can then manually merge this directory with the one in the ddnet source directory.
|
|
|
|
Then run `emcmake cmake .. -DVIDEORECORDER=OFF -DVULKAN=OFF -DSERVER=OFF -DTOOLS=OFF -DPREFER_BUNDLED_LIBS=ON` in your build directory.
|
|
|
|
To test the compiled code locally, just use `emrun --browser firefox DDNet.html`
|
|
|
|
To host the compiled .html file copy all `.data`, `.html`, `.js`, `.wasm` files to the web server. (see /other/emscripten/minimal.html for a minimal html example)
|
|
|
|
Then enable cross origin policies. Example for apache2 on debian based distros:
|
|
```bash
|
|
sudo a2enmod header
|
|
|
|
# edit the apache2 config to allow .htaccess files
|
|
sudo nano /etc/apache2/apache2.conf
|
|
|
|
# set AllowOverride to All for your directory
|
|
# then create a .htaccess file on the web server (where the .html is)
|
|
# and add these lines
|
|
Header add Cross-Origin-Embedder-Policy "require-corp"
|
|
Header add Cross-Origin-Opener-Policy "same-origin"
|
|
|
|
# now restart apache2
|
|
sudo service apache2 restart
|
|
```
|
|
|
|
Cross-compiling on Linux to macOS
|
|
---------------------------------
|
|
|
|
Install [osxcross](https://github.com/tpoechtrager/osxcross), then add
|
|
`-DCMAKE_TOOLCHAIN_FILE=../cmake/toolchains/darwin.toolchain` and
|
|
`-DCMAKE_OSX_SYSROOT=/path/to/osxcross/target/SDK/MacOSX10.11.sdk/` to the
|
|
**initial** CMake command line.
|
|
|
|
Install `dmg` and `hfsplus` from
|
|
[libdmg-hfsplus](https://github.com/mozilla/libdmg-hfsplus) and `newfs_hfs`
|
|
from
|
|
[diskdev\_cmds](http://pkgs.fedoraproject.org/repo/pkgs/hfsplus-tools/diskdev_cmds-540.1.linux3.tar.gz/0435afc389b919027b69616ad1b05709/diskdev_cmds-540.1.linux3.tar.gz)
|
|
to unlock the `package_dmg` target that outputs a macOS disk image.
|
|
|
|
Importing the official DDNet Database
|
|
-------------------------------------
|
|
|
|
```bash
|
|
$ wget https://ddnet.tw/stats/ddnet-sql.zip
|
|
$ unzip ddnet-sql.zip
|
|
$ yaourt -S mariadb mysql-connector-c++
|
|
$ mysql_install_db --user=mysql --basedir=/usr --datadir=/var/lib/mysql
|
|
$ systemctl start mariadb
|
|
$ mysqladmin -u root password 'PW'
|
|
$ mysql -u root -p'PW'
|
|
MariaDB [(none)]> create database teeworlds; create user 'teeworlds'@'localhost' identified by 'PW2'; grant all privileges on teeworlds.* to 'teeworlds'@'localhost'; flush privileges;
|
|
# this takes a while, you can remove the KEYs in record_race.sql to trade performance in queries
|
|
$ mysql -u teeworlds -p'PW2' teeworlds < ddnet-sql/record_*.sql
|
|
|
|
$ cat mine.cfg
|
|
sv_use_sql 1
|
|
add_sqlserver r teeworlds record teeworlds "PW2" "localhost" "3306"
|
|
add_sqlserver w teeworlds record teeworlds "PW2" "localhost" "3306"
|
|
|
|
$ mkdir build
|
|
$ cd build
|
|
$ cmake -DMYSQL=ON ..
|
|
$ make -j8
|
|
$ ./DDNet-Server -f mine.cfg
|
|
```
|
|
|
|
<a href="https://repology.org/metapackage/ddnet/versions">
|
|
<img src="https://repology.org/badge/vertical-allrepos/ddnet.svg?header=" alt="Packaging status" align="right">
|
|
</a>
|
|
|
|
Installation from Repository
|
|
----------------------------
|
|
|
|
Debian/Ubuntu
|
|
|
|
```bash
|
|
$ apt-get install ddnet
|
|
|
|
```
|
|
|
|
MacOS
|
|
|
|
```bash
|
|
$ brew install --cask ddnet
|
|
```
|
|
|
|
Fedora
|
|
|
|
```bash
|
|
$ dnf install ddnet
|
|
```
|
|
|
|
Arch Linux
|
|
|
|
```bash
|
|
$ yay -S ddnet
|
|
```
|
|
|
|
FreeBSD
|
|
|
|
```bash
|
|
$ pkg install DDNet
|
|
```
|
|
|
|
Benchmarking
|
|
------------
|
|
|
|
DDNet is available in the [Phoronix Test Suite](https://openbenchmarking.org/test/pts/ddnet). If you have PTS installed you can easily benchmark DDNet on your own system like this:
|
|
|
|
```bash
|
|
$ phoronix-test-suite benchmark ddnet
|
|
```
|