|Standard||Doom, Boom, MBF|
|Developer(s)||Florian Schulze (Proff), Colin Phipps (cph), Rob Young (RjY), Andrey Budko (entryway)|
|Initial release||2.0.2 (1998-11-15, 25 years ago)|
|Latest release||2.5.0 (2008-11-09, 15 years ago)|
|License||GNU General Public License v2+|
PrBoom is currently maintained by Rob Young (RjY), with occasional contributions from Andrey Budko. Florian Schulze (Proff) and Colin Phipps (cph), who accompanied Proff for the first few years after the merge with LxDoom, have retired from the PrBoom development team. Most development now occurs in PrBoom+ instead.
Unlike other source ports that concentrate on offering many new game features or changes, such as ZDoom, EDGE and the Eternity Engine, PrBoom aims to act as a stable port of the more established or traditional engines.
PrBoom uses the SDL library to abstract away operating system or platform specifics. As a result it supports a very large variety of platforms In addition to the PC, it has been compiled for the GP2X and various Mac models, among others. The source port, packaged with Freedoom, is included in the Fedora RPM software repository.
Compatibility modes and settings
PrBoom supports various compatibility settings to adjust its behavior, much like those initially implemented for MBF. In addition to individual settings for each difference in behavior, it allows the user to set compatibility levels to behave like earlier versions and modifications of the Doom engine. With the compatibility levels PrBoom may provide almost flawless compatibility with regular demos, as well as those recorded with Boom engines.
To change compatibility levels, the cheat code tntcomp can be used ingame. The game can also be launched with the -complevel parameter, or with default_compatibility_level in the config file, followed by one of the following numbers:
|-1||Engine defaults ("current version")|
|0||Doom v1.2 (note: flawed in PrBoom; requires PrBoom+ 220.127.116.11 or later)|
|3||Ultimate Doom & Doom95|
|7||Boom's inaccurate vanilla compatibility mode|
|14||PrBoom v2.1.1 - 2.2.6|
|17||Engine defaults ("current version")|
|21||MBF21 (note: requires DSDA-Doom)|
In practice, complevels 2 and 9 are the ones used in the overwhelming majority of cases.
PrBoom's compatibility with demos from the plain Doom engine, Boom and MBF also allows it to behave like these while playing, whether recording new demos or not. PrBoom in Doom compatibility mode treats straferunning differently than usual, which makes it possible to identify demos recorded with it. This is due to the Compet-n rules which require demos to be recorded with the DOS executables included with the games. In addition, PrBoom includes features which make it possible to "cheat" by using saved games to record demos in several stages. The offshoot engine PrBoom+, on the other hand, has all the compatibility options of PrBoom yet treats straferunning in the same way as the unmodified games.
When using a compatibility mode during demo recording, PrBoom marks the resulting demo with the corresponding version header information. Since PrBoom can handle larger or more detailed levels than its predecessors, this may produce demos that are not compatible with the engine versions it is emulating.
PrBoom 2.5.0 was selected to be included in the libretro API, a universal platform used by the RetroArch frontend. Through RetroArch, PrBoom, called lr-prboom in the source code, is included as a core, a dynamic library providing a generalized platform for settings, controls and more to be called from and towards the frontend. This version of PrBoom has several modifications to be included in libretro:
- Support for framerates up to 244 fps
- The default framerate is 60 fps. (35 fps is the correct value, but leads to stuttering on 60 hz LCD displays.)
- Support for internal resolution up to 1920x1200, in 4:3 aspect ratio
- The default is 320x200, and can be increased to 640x400, 960x600, 1280x800, 1600x1000 and 1920x1200 respectively
- Can search in parent folders for IWADs
Through RetroArch, Libretro PrBoom runs on a vast range of platforms. The list of platforms known to run the PrBoom core are:
- Apple: macOS (Intel x86 processors and Apple ARM based silicon), iOS, tvOS (Apple TV)
- GCW Zero
- Google: Android (ARM and x86)
- Linux (ARM and x86)
- Microsoft: Xbox (RetroArch 1.7.0 unofficially), Xbox 360 (RetroArch 18.104.22.168 unofficially), Xbox One, Xbox Series X and Series S
- Nintendo: GameCube, Wii, Wii U, Nintendo Switch, Nintendo 3DS, NES Classic, SNES Classic
- Pandora (console)
- Raspberry Pi
- Sony: PlayStation 2, PlayStation 3 (RetroArch 1.9.0 unofficially), PlayStation Portable, PlayStation Vita, PlayStation TV, PlayStation Classic
- Valve: Steam Link
- Microsoft Windows (95, XP, 7, 8, 10, 11)
- PrBoom official site
- PrBoom 2.02 binary, hosted by Doomworld
- PrBoom 2.02 source code, hosted by Doomworld
- TeamTNT's Go Get It download page, includes mirrors for PrBoom 2.02
- PrBoom for OpenVMS, ported by Alexey Chupahin
- discussion prior to the merger at Doomworld, 1998-08-03
- announcement of the PrBoom/LxDoom/LsdlDoom merger, 2000-09-17
- LsdlDoom link #1, link #2
- SVN log retrieved by cia.vc
- Libretro PrBoom documentation, hosted by libretro.com
- RetroArch Official Platform list, hosted by retroarch.com
- Carmack, John. "iPhone Doom Classic Progress Report." id Software (archived 🗺). Retrieved 1 October 2022.
|Source code genealogy|
|Based on||Name||Base for|
|Boom v2.02||PrBoom v2.02||Merged|
|Based on||Name||Base for|
|LxDoom||PrBoom v2.1.0||Doom Classic (iOS)|