Difference between revisions of "Doom source code"

From DoomWiki.org

[unchecked revision][unchecked revision]
(link and link)
(External links)
Line 35: Line 35:
 
== External links ==
 
== External links ==
 
[http://www.doomworld.com/10years/ports/ports01_1.php Doomworld - 10 years of Doom] - some history of the Doom source release.
 
[http://www.doomworld.com/10years/ports/ports01_1.php Doomworld - 10 years of Doom] - some history of the Doom source release.
 +
[http://www.3ddownloads.com/showfile.php3?file_id=7430 Original Doom Source Code] - The source code as [[id Software]] released it.
 
[[Category:Doom_engine]]
 
[[Category:Doom_engine]]

Revision as of 19:27, 22 February 2005

The Doom source code was released December 23 1997, initially under a not-for-profit license. Later, permission was granted to re-release the source code under the GNU GPL.

Before release, the source code was apparently tidied up by Bernd Kreimeier; the source release includes a ChangeLog of his contributions. Several documentation files are also included. The original plan for the source code release involved a book Kreimeier was to write on the Doom engine; however, due to Doom's decreasing relevance in the gaming community it was eventually judged not to be a marketable idea and the project was abandoned. The source code was released to the public.

Because of legal issues regarding the sound library used for Doom, the release was of the source code to the Linux port of Doom. Despite this, within several months several ports had been made back to DOS. As a result several source ports exist.

Source code structure

The source code can be divided into sections. Files and functions within the source code have one or two-letter prefixes to denote their subsystem.

AM_*
Automap code
D_*
Initialisation/general code
F_*
"Finale" (end of game) and "screen melt" code.
G_*
Main game loop/control
HU_*
Heads-up display
I_*
System-independent code
M_*
Miscellaneous (includes the menu)
P_*
Game logic/behaviour
R_*
Rendering engine
S_*
Sound code
ST_*
Status bar
V_*
General graphic rendering
WI_*
End-of level "intermission" screen
W_*
WAD file loading
Z_*
Zone memory allocation system

The following are common prefixes for functions although they do not denote a particular subsystem and there are no files with these prefixes:

A_*
Action functions invoked in sprite movement frames (these are the functions used in Dehacked "code pointers")
PIT_*
Callback functions passed to P_BlockThingsIterator (see p_maputl.c)
T_*
"Thinker" functions set to be called each clock tic for some purpose (eg, moving platforms or flickering lights)

A detailed list of files and their purposes can be found in Doom source code: files.

External links

Doomworld - 10 years of Doom - some history of the Doom source release. Original Doom Source Code - The source code as id Software released it.