Skip to content

odamex/odamex

Repository files navigation

Odamex

Windows Build Status Mac Build Status Linux Build Status Join our Discord!
Windows macOS Linux Join our discord

Odamex is a modification of DOOM to allow players to compete with each other over the Internet using a client/server architecture. Thanks to the source code release of DOOM by id Software in December 1997, there have been many modifications that enhanced DOOM in various ways. These modifications are known as "source ports", as early modifications mainly ported DOOM to other platforms and operating systems such as Windows and Macintosh.

Odamex is based on the CSDoom 0.62 source code originally created by Sergey Makovkin, which is based on the ZDoom 1.22 source code created by Marisa Heit.

Features

Odamex supports the following features:

  • Full Client/Server multiplayer architecture with network compensation features (unlagged, client interpolation and prediction)
  • Support for up to 255 players
  • Various compatibility settings, to emulate vanilla Doom, Boom, or ZDoom physics and fixes
  • Playback and recording of vanilla demos
  • A fully-featured client netdemo record system with playback control
  • Removal of most vanilla Doom Static limits
  • Support for most Boom and MBF mapping features
  • The traditional old-school style of Deathmatch and a Cooperative mode, but also other game modes such as Team Deathmatch and Capture the Flag
  • Support for Horde, Survival, Last Man Standing, Last Team Standing, LMS CTF, 3-WAY CTF, and Attack & Defend game modes
  • Competitive-ready features, such as a warmup mode, round system, player queue, or playercolor overriding
  • Several modern ZDoom additions, such as slopes, LANGUAGEv2 or MAPINFOv2 lump support
  • An array of editing features, including the Hexen map format, DeHackEd, BEX, and DEHEXTRA patch support, MBF21 features, and ACS up to ZDoom 1.23
  • Native Joystick support
  • Several additional music formats, such as MOD and OGG
  • In-Engine WAD downloader
  • Allow on-the-fly WAD loading
  • A 32-bit Color depth/true color renderer
  • Full Widescreen support
  • Ultra high resolution support (up to 8K)
  • Uncapped and raised framerate
  • Takes advantage of widely used libraries to port it to new devices with ease

Compilation instructions

Clone the repositories, with all submodules:

git clone https://github.com/odamex/odamex.git --recurse-submodules

If you downloaded the zip, use these commands on the git directory:

git submodule init
git submodule update

Odamex requires the following tools and libraries:

cURL, libPNG and zlib are automatically included in-tree as submodules.

On Windows, all libraries are automatically downloaded if not found. On *nix/MacOSX, you will need to download through your package manager libsdl2-dev, libsdl2-mixer-dev and libwxgtk3.0-dev.

Please check this page for further instructions on how to compile Odamex for your platform.

Contributing to the project

Please report any oddity, physics inaccuracies, bugs or game-breaking glitches to our issues page. You can also submit patches as a Pull Request.

Before submitting a pull request, please make sure it follows our coding standards!

Note: This project contains a demo testing utility that ensures vanilla compatibility by running a specific set of demos after each commit. When forking this project to prepare a pull request, this functionality will be unavailable by default to protect sensitive files. You can restore this functionality by:

  1. Forking OdaTest-Resources to get the PWADs.
  2. Downloading OdaTests to get the encryption module.
  3. Replacing the encrypted IWADs with your own set of encrypted IWADs. Encrypt using python .\secret.py encrypt doom2 with the environment variable SECRET_KEY defined to encrypt the IWADs with. The following IWADs (latest version) are needed to run all tests: doom, doom1, doom2, tnt, plutonia, hacx
  4. Create a release for your forked OdaTest-Resources repo.
  5. Enter the following Secrets / Repository Variables in GitHub:
  • secrets.DEMOTESTER_IWAD_KEY - Encryption key for the IWADs
  • vars.DEMOTESTER_DOWNLOAD_URL - Full URL to download the latest OdaTests release.
  • vars.DEMORESOURCES_DOWNLOAD_URL - Full URL to download your personal demo resources

External Links

Please visit the following websites for more information about the development of the port and our community:

License

Odamex is released under the GNU General Public License v2. Please read LICENSE for further details regarding the license.