mirror of
https://github.com/ZDoom/qzdoom-gpl.git
synced 2024-11-26 05:41:39 +00:00
Remove outdated and redundant files from the docs folder, and added the GZDoom license file.
This commit is contained in:
parent
05aae38031
commit
0ab4a4a349
11 changed files with 32 additions and 29530 deletions
|
@ -1,71 +0,0 @@
|
|||
BUILD SOURCE CODE LICENSE TERMS: 06/20/2000
|
||||
|
||||
[1] I give you permission to make modifications to my Build source and
|
||||
distribute it, BUT:
|
||||
|
||||
[2] Any derivative works based on my Build source may be distributed ONLY
|
||||
through the INTERNET.
|
||||
|
||||
[3] Distribution of any derivative works MUST be done completely FREE of
|
||||
charge - no commercial exploitation whatsoever.
|
||||
|
||||
[4] Anything you distribute which uses a part of my Build Engine source
|
||||
code MUST include:
|
||||
|
||||
[A] The following message somewhere in the archive:
|
||||
|
||||
// "Build Engine & Tools" Copyright (c) 1993-1997 Ken Silverman
|
||||
// Ken Silverman's official web site: "http://www.advsys.net/ken"
|
||||
// See the included license file "BUILDLIC.TXT" for license info.
|
||||
|
||||
[B] This text file "BUILDLIC.TXT" along with it.
|
||||
|
||||
[C] Any source files that you modify must include this message as well:
|
||||
|
||||
// This file has been modified from Ken Silverman's original release
|
||||
|
||||
[5] The use of the Build Engine for commercial purposes will require an
|
||||
appropriate license arrangement with me. Contact information is
|
||||
on my web site.
|
||||
|
||||
[6] I take no responsibility for damage to your system.
|
||||
|
||||
[7] Technical support: Before contacting me with questions, please read
|
||||
and do ALL of the following!
|
||||
|
||||
[A] Look though ALL of my text files. There are 7 of them (including this
|
||||
one). I like to think that I wrote them for a reason. You will find
|
||||
many of your answers in the history section of BUILD.TXT and
|
||||
BUILD2.TXT (they're located inside SRC.ZIP).
|
||||
|
||||
[B] If that doesn't satisfy you, then try going to:
|
||||
|
||||
"http://www.advsys.net/ken/buildsrc"
|
||||
|
||||
where I will maintain a Build Source Code FAQ (or perhaps I might
|
||||
just provide a link to a good FAQ).
|
||||
|
||||
[C] I am willing to respond to questions, but ONLY if they come at a rate
|
||||
that I can handle.
|
||||
|
||||
PLEASE TRY TO AVOID ASKING DUPLICATE QUESTIONS!
|
||||
|
||||
As my line of defense, I will post my current policy about
|
||||
answering Build source questions (right below the E-mail address
|
||||
on my web site.) You can check there to see if I'm getting
|
||||
overloaded with questions or not.
|
||||
|
||||
If I'm too busy, it might say something like this:
|
||||
|
||||
I'm too busy to answer Build source questions right now.
|
||||
Sorry, but don't expect a reply from me any time soon.
|
||||
|
||||
If I'm open for Build source questions, please state your question
|
||||
clearly and don't include any unsolicited attachments unless
|
||||
they're really small (like less than 50k). Assume that I have
|
||||
a 28.8k modem. Also, don't leave out important details just
|
||||
to make your question appear shorter - making me guess what
|
||||
you're asking doesn't save me time!
|
||||
|
||||
----------------------------------------------------------------------------
|
||||
-Ken S. (official web site: http://www.advsys.net/ken)
|
32
docs/GZDoom License.md
Normal file
32
docs/GZDoom License.md
Normal file
|
@ -0,0 +1,32 @@
|
|||
GZDoom License
|
||||
==============
|
||||
|
||||
Copyright 2004-2009 Christoph Oelckers
|
||||
All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
modification, are permitted provided that the following conditions
|
||||
are met:
|
||||
|
||||
1. Redistributions of source code must retain the above copyright
|
||||
notice, this list of conditions and the following disclaimer.
|
||||
2. Redistributions in binary form must reproduce the above copyright
|
||||
notice, this list of conditions and the following disclaimer in the
|
||||
documentation and/or other materials provided with the distribution.
|
||||
3. The name of the author may not be used to endorse or promote products
|
||||
derived from this software without specific prior written permission.
|
||||
4. When not used as part of GZDoom or a GZDoom derivative, this code will be
|
||||
covered by the terms of the GNU Lesser General Public License as published
|
||||
by the Free Software Foundation; either version 2.1 of the License, or (at
|
||||
your option) any later version.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR
|
||||
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||
IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||||
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
283
docs/README.asm
283
docs/README.asm
|
@ -1,283 +0,0 @@
|
|||
|
||||
README - DOOM assembly code
|
||||
|
||||
Okay, I add the DOS assembly module for the historically
|
||||
inclined here (may rec.games.programmer suffer). If anyone
|
||||
feels the urge to port these to GNU GCC; either inline or
|
||||
as separate modules including Makefile support, be my guest.
|
||||
|
||||
Module tmap.S includes the inner loops for texture mapping,
|
||||
the interesting one being the floor/ceiling span rendering.
|
||||
|
||||
There was another module in the source dump, fpfunc.S, that
|
||||
had both texture mapping and fixed point functions. It
|
||||
contained implementations both for i386 and M68k. For
|
||||
brevity, I include only the i386 fixed point stuff below.
|
||||
|
||||
//====================================================
|
||||
// tmap.S as of January 10th, 1997
|
||||
|
||||
//================
|
||||
//
|
||||
// R_DrawColumn
|
||||
//
|
||||
//================
|
||||
|
||||
.data
|
||||
loopcount .long 0
|
||||
pixelcount .long 0
|
||||
|
||||
.text
|
||||
|
||||
.align 16
|
||||
.globl _R_DrawColumn
|
||||
_R_DrawColumn:
|
||||
|
||||
pushad
|
||||
|
||||
movl ebp,[_dc_yl]
|
||||
movl ebx,ebp
|
||||
movl edi,[_ylookup+ebx*4]
|
||||
movl ebx,[_dc_x]
|
||||
addl edi,[_columnofs + ebx*4]
|
||||
|
||||
movl eax,[_dc_yh]
|
||||
incl eax
|
||||
subl eax,ebp // pixel count
|
||||
movl [pixelcount],eax // save for final pixel
|
||||
js done // nothing to scale
|
||||
shrl eax,1 // double pixel count
|
||||
movl [loopcount],eax
|
||||
|
||||
movl ecx,[_dc_iscale]
|
||||
|
||||
movl eax,[_centery]
|
||||
subl eax,ebp
|
||||
imull ecx
|
||||
movl ebp,[_dc_texturemid]
|
||||
subl ebp,eax
|
||||
shll ebp,9 // 7 significant bits, 25 frac
|
||||
|
||||
movl esi,[_dc_source]
|
||||
|
||||
|
||||
movl ebx,[_dc_iscale]
|
||||
shll ebx,9
|
||||
movl eax,OFFSET patch1+2 // convice tasm to modify code...
|
||||
movl [eax],ebx
|
||||
movl eax,OFFSET patch2+2 // convice tasm to modify code...
|
||||
movl [eax],ebx
|
||||
|
||||
// eax aligned colormap
|
||||
// ebx aligned colormap
|
||||
// ecx,edx scratch
|
||||
// esi virtual source
|
||||
// edi moving destination pointer
|
||||
// ebp frac
|
||||
|
||||
movl ecx,ebp // begin calculating first pixel
|
||||
addl ebp,ebx // advance frac pointer
|
||||
shrl ecx,25 // finish calculation for first pixel
|
||||
movl edx,ebp // begin calculating second pixel
|
||||
addl ebp,ebx // advance frac pointer
|
||||
shrl edx,25 // finish calculation for second pixel
|
||||
movl eax,[_dc_colormap]
|
||||
movl ebx,eax
|
||||
movb al,[esi+ecx] // get first pixel
|
||||
movb bl,[esi+edx] // get second pixel
|
||||
movb al,[eax] // color translate first pixel
|
||||
movb bl,[ebx] // color translate second pixel
|
||||
|
||||
testl [pixelcount],0fffffffeh
|
||||
jnz doubleloop // at least two pixels to map
|
||||
jmp checklast
|
||||
|
||||
.align 16
|
||||
doubleloop:
|
||||
movl ecx,ebp // begin calculating third pixel
|
||||
patch1:
|
||||
addl ebp,12345678h // advance frac pointer
|
||||
movb [edi],al // write first pixel
|
||||
shrl ecx,25 // finish calculation for third pixel
|
||||
movl edx,ebp // begin calculating fourth pixel
|
||||
patch2:
|
||||
addl ebp,12345678h // advance frac pointer
|
||||
movl [edi+SCREENWIDTH],bl // write second pixel
|
||||
shrl edx,25 // finish calculation for fourth pixel
|
||||
movb al,[esi+ecx] // get third pixel
|
||||
addl edi,SCREENWIDTH*2 // advance to third pixel destination
|
||||
movb bl,[esi+edx] // get fourth pixel
|
||||
decl [loopcount] // done with loop?
|
||||
movb al,[eax] // color translate third pixel
|
||||
movb bl,[ebx] // color translate fourth pixel
|
||||
jnz doubleloop
|
||||
|
||||
// check for final pixel
|
||||
checklast:
|
||||
testl [pixelcount],1
|
||||
jz done
|
||||
movb [edi],al // write final pixel
|
||||
|
||||
done:
|
||||
popad
|
||||
ret
|
||||
|
||||
|
||||
|
||||
//================
|
||||
//
|
||||
// R_DrawSpan
|
||||
//
|
||||
// Horizontal texture mapping
|
||||
//
|
||||
//================
|
||||
|
||||
|
||||
.align 16
|
||||
.globl _R_DrawSpan
|
||||
_R_DrawSpan:
|
||||
pushad
|
||||
|
||||
//
|
||||
// find loop count
|
||||
//
|
||||
movl eax,[_ds_x2]
|
||||
incl eax
|
||||
subl eax,[_ds_x1] // pixel count
|
||||
movl [pixelcount],eax // save for final pixel
|
||||
js hdone // nothing to scale
|
||||
shrl eax,1 // double pixel count
|
||||
movl [loopcount],eax
|
||||
|
||||
//
|
||||
// build composite position
|
||||
//
|
||||
movl ebp,[_ds_xfrac]
|
||||
shll ebp,10
|
||||
andl ebp,0ffff0000h
|
||||
movl eax,[_ds_yfrac]
|
||||
shrl eax,6
|
||||
andl eax,0ffffh
|
||||
orl ebp,eax
|
||||
|
||||
movl esi,[_ds_source]
|
||||
|
||||
//
|
||||
// calculate screen dest
|
||||
//
|
||||
movl edi,[_ds_y]
|
||||
movl edi,[_ylookup+edi*4]
|
||||
movl eax,[_ds_x1]
|
||||
addl edi,[_columnofs+eax*4]
|
||||
|
||||
//
|
||||
// build composite step
|
||||
//
|
||||
movl ebx,[_ds_xstep]
|
||||
shll ebx,10
|
||||
andl ebx,0ffff0000h
|
||||
movl eax,[_ds_ystep]
|
||||
shrl eax,6
|
||||
andl eax,0ffffh
|
||||
orl ebx,eax
|
||||
|
||||
movl eax,OFFSET hpatch1+2 // convice tasm to modify code...
|
||||
movl [eax],ebx
|
||||
movl eax,OFFSET hpatch2+2 // convice tasm to modify code...
|
||||
movl [eax],ebx
|
||||
|
||||
// eax aligned colormap
|
||||
// ebx aligned colormap
|
||||
// ecx,edx scratch
|
||||
// esi virtual source
|
||||
// edi moving destination pointer
|
||||
// ebp frac
|
||||
|
||||
shldl ecx,ebp,22 // begin calculating third pixel (y units)
|
||||
shldl ecx,ebp,6 // begin calculating third pixel (x units)
|
||||
addl ebp,ebx // advance frac pointer
|
||||
andl ecx,4095 // finish calculation for third pixel
|
||||
shldl edx,ebp,22 // begin calculating fourth pixel (y units)
|
||||
shldl edx,ebp,6 // begin calculating fourth pixel (x units)
|
||||
addl ebp,ebx // advance frac pointer
|
||||
andl edx,4095 // finish calculation for fourth pixel
|
||||
movl eax,[_ds_colormap]
|
||||
movl ebx,eax
|
||||
movb al,[esi+ecx] // get first pixel
|
||||
movb bl,[esi+edx] // get second pixel
|
||||
movb al,[eax] // color translate first pixel
|
||||
movb bl,[ebx] // color translate second pixel
|
||||
|
||||
testl [pixelcount],0fffffffeh
|
||||
jnz hdoubleloop // at least two pixels to map
|
||||
jmp hchecklast
|
||||
|
||||
|
||||
.align 16
|
||||
hdoubleloop:
|
||||
shldl ecx,ebp,22 // begin calculating third pixel (y units)
|
||||
shldl ecx,ebp,6 // begin calculating third pixel (x units)
|
||||
hpatch1:
|
||||
addl ebp,12345678h // advance frac pointer
|
||||
movb [edi],al // write first pixel
|
||||
andl ecx,4095 // finish calculation for third pixel
|
||||
shldl edx,ebp,22 // begin calculating fourth pixel (y units)
|
||||
shldl edx,ebp,6 // begin calculating fourth pixel (x units)
|
||||
hpatch2:
|
||||
addl ebp,12345678h // advance frac pointer
|
||||
movb [edi+1],bl // write second pixel
|
||||
andl edx,4095 // finish calculation for fourth pixel
|
||||
movb al,[esi+ecx] // get third pixel
|
||||
addl edi,2 // advance to third pixel destination
|
||||
movb bl,[esi+edx] // get fourth pixel
|
||||
decl [loopcount] // done with loop?
|
||||
movb al,[eax] // color translate third pixel
|
||||
movb bl,[ebx] // color translate fourth pixel
|
||||
jnz hdoubleloop
|
||||
|
||||
// check for final pixel
|
||||
hchecklast:
|
||||
testl [pixelcount],1
|
||||
jz hdone
|
||||
movb [edi],al // write final pixel
|
||||
|
||||
hdone:
|
||||
popad
|
||||
ret
|
||||
|
||||
|
||||
|
||||
|
||||
//====================================================
|
||||
// fpfunc.S as of January 10th, 1997 (parts)
|
||||
|
||||
#ifdef i386
|
||||
|
||||
.text
|
||||
.align 4
|
||||
.globl _FixedMul
|
||||
_FixedMul:
|
||||
pushl %ebp
|
||||
movl %esp,%ebp
|
||||
movl 8(%ebp),%eax
|
||||
imull 12(%ebp)
|
||||
shrdl $16,%edx,%eax
|
||||
popl %ebp
|
||||
ret
|
||||
|
||||
|
||||
.align 4
|
||||
.globl _FixedDiv2
|
||||
_FixedDiv2:
|
||||
pushl %ebp
|
||||
movl %esp,%ebp
|
||||
movl 8(%ebp),%eax
|
||||
cdq
|
||||
shldl $16,%eax,%edx
|
||||
sall $16,%eax
|
||||
idivl 12(%ebp)
|
||||
popl %ebp
|
||||
ret
|
||||
|
||||
#endif
|
||||
|
149
docs/README.gl
149
docs/README.gl
|
@ -1,149 +0,0 @@
|
|||
|
||||
README: glDOOM
|
||||
|
||||
I never got around to do anything with respect to
|
||||
a Linux glDOOM port except for assembling a Linux3Dfx
|
||||
HOWTO (which, at that time, was a prerequisite
|
||||
to get permission to publicly distribute the
|
||||
already finished LinuxGlide port by Daryll Strauss).
|
||||
|
||||
Linux q2test (and soon LinuxQuake2) demonstrate that
|
||||
Mesa with the MesaVoodoo driver is quite up to the
|
||||
requirements for a glDOOM port. If anybody wants to
|
||||
get into Linux glDOOM, please drop me a line.
|
||||
|
||||
There is a Win32 GLDOOM port in the works, by Jim Dose.
|
||||
Quoting a recent posting by him:
|
||||
|
||||
"I haven't had as much time lately to really work on
|
||||
the conversion. I currently have the renderer drawing
|
||||
the walls and floors as texture spans as the are in
|
||||
the software renderer. There's lighting on the walls,
|
||||
but not the floors, and sprites are being drawn, but
|
||||
not with the right texture. I figure that this is one
|
||||
nights work to get the game looking "normal". I haven't
|
||||
tested the game on less than a p200, so I'm not sure
|
||||
how it will perform under the average machine, but I
|
||||
don't expect it to be blindingly fast because of the
|
||||
number of spans that have to be drawn each frame.
|
||||
Rendering as polys is definitely the way to go.
|
||||
|
||||
The reason I chose to do spans first was because it
|
||||
left the base renderer intact and I could concentrate
|
||||
on ironing out any Windows compatibility problems.
|
||||
Actually, the first version I had running was simply
|
||||
a blit of the 320x200 game screen through Open GL.
|
||||
Surprisingly, this actually was very playable, but
|
||||
certainly wasn't taking any advantage of 3D acceleration.
|
||||
Once the game was running, I started converting all
|
||||
the span routines over."
|
||||
|
||||
Comment: for merging Linuxdoom with Win32, this is
|
||||
probably the best source for getting the Win32
|
||||
environment done - before more significant changes
|
||||
occur.
|
||||
|
||||
"One problem with drawing spans is that the engine
|
||||
doesn't calculate the texture coordinates with
|
||||
fractional accuracy, so the bilinear filtering works
|
||||
vertically, but not horizontally on the walls. I may
|
||||
try to fix this, but since I plan to use polys for
|
||||
the final version, it's not really high priority.
|
||||
Also, spans don't really allow for looking up and
|
||||
down."
|
||||
|
||||
Comment: true looking up/down vs. Heretic-style
|
||||
y-shearing seems to require either a strange kind
|
||||
of transofrmation matrix (he probably does not use
|
||||
the OpenGL transformation at all), or rendering
|
||||
all the spans as textured rectangular slices
|
||||
instead of using glDrawBitmap. No, polys are the
|
||||
way to go.
|
||||
|
||||
"When I tackle the conversion to polys, one big problem
|
||||
I'll encounter is drawing floors. Since the world is
|
||||
stored in a 2D bsp tree, there is no information on
|
||||
the shape of the floors. In fact the floors can be
|
||||
concave and may include holes (typically, most renderers
|
||||
break concave polys down into a collection of convex
|
||||
polys or triangles). In software, the floors are actually
|
||||
drawn using an algorithm that's similar to a flood fill
|
||||
(except that a list of open spans is kept instead of a
|
||||
buffer of pixels). This makes drawing the floors as
|
||||
polys fairly difficult."
|
||||
|
||||
A polygon based approach will require significant changes
|
||||
to the data structures used in the refresh module. I
|
||||
recommend either separating a libref_soft.so first (a
|
||||
Quake2 like approach), and creating libref_gl afterwards,
|
||||
or abandoning the software rendering entirely.
|
||||
|
||||
John Carmack wrote once upon a time:
|
||||
"... the U64 DOOM engine is much more what I would consider
|
||||
The Right Thing now -- it turns the subsector boundaries
|
||||
into polygons for the floors and ceilings ahead of time,
|
||||
then for rendering it walks the BSP front to back, doing
|
||||
visibility determination of subsectors by the one dimensional
|
||||
occlusion buffer and clipping sprites into subsectors, then
|
||||
it goes backwards through the visible subsectors, drawing
|
||||
floors, ceilings, walls, then sorted internal sprite fragments.
|
||||
It's a ton simpler and a ton faster, although it does suffer
|
||||
some overdraw when a high subsector overlooks a low one (but
|
||||
that is more than made up for by the simplicity of everything
|
||||
else)."
|
||||
|
||||
Well, IMO compiling a separate list of floor/ceiling polygons
|
||||
after having read the WAD file, and thus introducing this as
|
||||
a completely separate data structure to the current code base
|
||||
might be the easiest thing to do. Jim Dose writes:
|
||||
|
||||
"One method I may use to draw the floors as polys was suggested
|
||||
by Billy Zelsnack of Rebel Boat Rocker when we were working
|
||||
at 3D Realms together a few years ago. Basically, Billy was
|
||||
designing an engine that dealt with the world in a 2D portal
|
||||
format similar to the one that Build used, except that it had
|
||||
true looking up and down (no shearing). Since floors were
|
||||
basically implicit and could be concave, Billy drew them as
|
||||
if the walls extended downwards to infinity, but fixed the
|
||||
texture coordinates to appear that they were on the plane of
|
||||
the floor. The effect was that you could look up and down and
|
||||
there were no gaps or overdraw. It's a fairly clever method
|
||||
and allows you to store the world in a simpler data format.
|
||||
Had perspective texture mapping been fast enough back then,
|
||||
both Build and Doom could have done this in software."
|
||||
|
||||
Perhaps the above is sufficient to get you started.
|
||||
Other Issues:
|
||||
|
||||
1. Occlusion
|
||||
DOOM uses a per-column lookup (top/bottom index) to do HLHSR.
|
||||
This works fine with span based rendering (well, getting
|
||||
horizontal spans of floors/ceilings into the picture is a
|
||||
separate story). It isn't really mindboggling with polygon
|
||||
based rendering. GLDOOM should abandon that.
|
||||
|
||||
2. Precalculated Visibility
|
||||
DOOM has the data used by Quake's PVS - in REJECT.
|
||||
During Quake development, lots of replacements for the
|
||||
occlusion buffer were tried, and PVS turned out to be best.
|
||||
I suggest usind the REJECT as PVS.
|
||||
|
||||
There have been special effects using a utility named RMB.
|
||||
REJECT is a lump meant for enemy AI LoS calculation - a
|
||||
nonstandard REJECT will not work as a PVS, and introduce
|
||||
rendering errors. I suggest looking for a PVS lump in the
|
||||
WAD, and using REJECT if none is found. That way, it might
|
||||
be feasible to eat the cake and keep it.
|
||||
|
||||
3. Mipmaps
|
||||
DOOM does not have mipmapping. As we have 8bit palettized
|
||||
textures, OpenGL mipmapping might not give the desired
|
||||
results. Plus, composing textures from patches at runtime
|
||||
would require runtime mipmapping. Precalculated mipmaps
|
||||
in the WAD?
|
||||
|
||||
4. Sprites
|
||||
Partly transparent textures and sprites impose another
|
||||
problem related to mipmapping. Without alpha channel,
|
||||
this could give strange results. Precalculated, valid
|
||||
sprite mipmaps (w/o alpha)?
|
1742
docs/commands.txt
1742
docs/commands.txt
File diff suppressed because it is too large
Load diff
162
docs/console.css
162
docs/console.css
|
@ -1,162 +0,0 @@
|
|||
DT
|
||||
{
|
||||
font-weight: bold;
|
||||
}
|
||||
DD
|
||||
{
|
||||
margin-bottom: 1em;
|
||||
margin-left: 1.5em;
|
||||
margin-right: 1.5em;
|
||||
}
|
||||
TH
|
||||
{
|
||||
text-align: left;
|
||||
font-weight: bold;
|
||||
padding-right: 2em;
|
||||
vertical-align: top;
|
||||
}
|
||||
TD
|
||||
{
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
/* Command Descriptions */
|
||||
DIV.c
|
||||
{
|
||||
border-right: 2px solid;
|
||||
padding-right: 0.4em;
|
||||
border-top: 1px solid;
|
||||
margin-top: 1em;
|
||||
padding-left: 0.4em;
|
||||
font-weight: bold;
|
||||
padding-bottom: 0.2em;
|
||||
border-left: 1px solid;
|
||||
padding-top: 0.2em;
|
||||
border-bottom: 1px solid;
|
||||
background-color: rgb(152,251,152);
|
||||
margin-bottom: 0px;
|
||||
}
|
||||
DIV.b
|
||||
{
|
||||
border-right: 2px solid;
|
||||
padding-right: 1.2em;
|
||||
border-top: 1px;
|
||||
padding-left: 1.2em;
|
||||
padding-bottom: 0.5em;
|
||||
border-left: 1px solid;
|
||||
padding-top: 0.5em;
|
||||
border-bottom: 2px solid;
|
||||
background-color: rgb(240,255,240);
|
||||
margin-top: 0px;
|
||||
}
|
||||
|
||||
/* Variable Descriptions */
|
||||
DIV.v, DIV.vf
|
||||
{
|
||||
border-right: 2px solid;
|
||||
padding-right: 0.4em;
|
||||
border-top: 1px solid;
|
||||
margin-top: 1em;
|
||||
padding-left: 0.4em;
|
||||
font-weight: bold;
|
||||
padding-bottom: 0.2em;
|
||||
border-left: 1px solid;
|
||||
padding-top: 0.2em;
|
||||
border-bottom: 1px solid;
|
||||
background-color: rgb(175,238,238);
|
||||
}
|
||||
DIV.vf
|
||||
{
|
||||
background-color: rgb(175,200,238);
|
||||
}
|
||||
DIV.t, DIV.tf
|
||||
{
|
||||
border-right: 2px solid;
|
||||
padding-right: 1.2em;
|
||||
border-top: 1px;
|
||||
padding-left: 0.9em;
|
||||
padding-bottom: 0.2em;
|
||||
border-left: 1px solid;
|
||||
padding-top: 0.2em;
|
||||
border-bottom: 1px solid;
|
||||
background-color: rgb(224,255,255);
|
||||
}
|
||||
DIV.tf
|
||||
{
|
||||
background-color: rgb(224,238,255);
|
||||
}
|
||||
DIV.d, DIV.df
|
||||
{
|
||||
border-right: 2px solid;
|
||||
padding-right: 1.2em;
|
||||
border-top: 2px;
|
||||
padding-left: 1.2em;
|
||||
padding-bottom: 0.5em;
|
||||
border-left: 1px solid;
|
||||
padding-top: 0.5em;
|
||||
border-bottom: 2px solid;
|
||||
background-color: rgb(240,255,255);
|
||||
}
|
||||
DIV.df
|
||||
{
|
||||
background-color: rgb(240,248,255);
|
||||
}
|
||||
P
|
||||
{
|
||||
margin-top: 1em;
|
||||
margin-bottom: 0em;
|
||||
}
|
||||
A
|
||||
{
|
||||
color: Blue;
|
||||
text-decoration: none;
|
||||
}
|
||||
A:hover
|
||||
{
|
||||
text-decoration: underline;
|
||||
}
|
||||
H1, H2
|
||||
{
|
||||
font-weight: bold;
|
||||
left: -0.8em;
|
||||
font-family: Verdana, Arial, Helvetica, Sans-Serif;
|
||||
position: relative;
|
||||
}
|
||||
H3, H4
|
||||
{
|
||||
font-weight: bold;
|
||||
font-family: Verdana, Arial, Helvetica, Sans-Serif;
|
||||
left: 0em;
|
||||
}
|
||||
BODY
|
||||
{
|
||||
margin: 2em 2em 2em 2em;
|
||||
background-color: white;
|
||||
}
|
||||
PRE
|
||||
{
|
||||
border: ridge 2px;
|
||||
background-color: rgb(210,210,210);
|
||||
padding: 1em 1em 1em 1em;
|
||||
}
|
||||
DIV.index
|
||||
{
|
||||
padding-right: 0.8em;
|
||||
padding-left: 0.8em;
|
||||
left: 0px;
|
||||
float: left;
|
||||
padding-bottom: 1em;
|
||||
overflow: auto;
|
||||
clip: rect(auto,auto,auto,auto);
|
||||
padding-top: 0.5em;
|
||||
position: absolute;
|
||||
top: 0px;
|
||||
background-color: #ffffcc;
|
||||
border-right: solid 1px #808080;
|
||||
border-bottom: solid 1px #808080;
|
||||
}
|
||||
DIV.main
|
||||
{
|
||||
margin-left: 11em;
|
||||
height: 50%;
|
||||
}
|
3587
docs/console.html
3587
docs/console.html
File diff suppressed because it is too large
Load diff
112
docs/doomlic.txt
112
docs/doomlic.txt
|
@ -1,112 +0,0 @@
|
|||
|
||||
|
||||
LIMITED USE SOFTWARE LICENSE AGREEMENT
|
||||
|
||||
This Limited Use Software License Agreement (the "Agreement")
|
||||
is a legal agreement between you, the end-user, and Id Software, Inc.
|
||||
("ID"). By downloading or purchasing the software material, which
|
||||
includes source code (the "Source Code"), artwork data, music and
|
||||
software tools (collectively, the "Software"), you are agreeing to
|
||||
be bound by the terms of this Agreement. If you do not agree to the
|
||||
terms of this Agreement, promptly destroy the Software you may have
|
||||
downloaded or copied.
|
||||
|
||||
ID SOFTWARE LICENSE
|
||||
|
||||
1. Grant of License. ID grants to you the right to use the
|
||||
Software. You have no ownership or proprietary rights in or to the
|
||||
Software, or the Trademark. For purposes of this section, "use" means
|
||||
loading the Software into RAM, as well as installation on a hard disk
|
||||
or other storage device. The Software, together with any archive copy
|
||||
thereof, shall be destroyed when no longer used in accordance with
|
||||
this Agreement, or when the right to use the Software is terminated.
|
||||
You agree that the Software will not be shipped, transferred or
|
||||
exported into any country in violation of the U.S. Export
|
||||
Administration Act (or any other law governing such matters) and that
|
||||
you will not utilize, in any other manner, the Software in violation
|
||||
of any applicable law.
|
||||
|
||||
2. Permitted Uses. For educational purposes only, you, the
|
||||
end-user, may use portions of the Source Code, such as particular
|
||||
routines, to develop your own software, but may not duplicate the
|
||||
Source Code, except as noted in paragraph 4. The limited right
|
||||
referenced in the preceding sentence is hereinafter referred to as
|
||||
"Educational Use." By so exercising the Educational Use right you
|
||||
shall not obtain any ownership, copyright, proprietary or other
|
||||
interest in or to the Source Code, or any portion of the Source
|
||||
Code. You may dispose of your own software in your sole discretion.
|
||||
With the exception of the Educational Use right, you may not
|
||||
otherwise use the Software, or an portion of the Software, which
|
||||
includes the Source Code, for commercial gain.
|
||||
|
||||
3. Prohibited Uses: Under no circumstances shall you, the
|
||||
end-user, be permitted, allowed or authorized to commercially exploit
|
||||
the Software. Neither you nor anyone at your direction shall do any
|
||||
of the following acts with regard to the Software, or any portion
|
||||
thereof:
|
||||
|
||||
Rent;
|
||||
|
||||
Sell;
|
||||
|
||||
Lease;
|
||||
|
||||
Offer on a pay-per-play basis;
|
||||
|
||||
Distribute for money or any other consideration; or
|
||||
|
||||
In any other manner and through any medium whatsoever
|
||||
commercially exploit or use for any commercial purpose.
|
||||
|
||||
Notwithstanding the foregoing prohibitions, you may commercially
|
||||
exploit the software you develop by exercising the Educational Use
|
||||
right, referenced in paragraph 2. hereinabove.
|
||||
|
||||
4. Copyright. The Software and all copyrights related thereto
|
||||
(including all characters and other images generated by the Software
|
||||
or depicted in the Software) are owned by ID and is protected by
|
||||
United States copyright laws and international treaty provisions.
|
||||
Id shall retain exclusive ownership and copyright in and to the
|
||||
Software and all portions of the Software and you shall have no
|
||||
ownership or other proprietary interest in such materials. You must
|
||||
treat the Software like any other copyrighted material. You may not
|
||||
otherwise reproduce, copy or disclose to others, in whole or in any
|
||||
part, the Software. You may not copy the written materials
|
||||
accompanying the Software. You agree to use your best efforts to
|
||||
see that any user of the Software licensed hereunder complies with
|
||||
this Agreement.
|
||||
|
||||
5. NO WARRANTIES. ID DISCLAIMS ALL WARRANTIES, BOTH EXPRESS
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
|
||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT
|
||||
TO THE SOFTWARE. THIS LIMITED WARRANTY GIVES YOU SPECIFIC LEGAL
|
||||
RIGHTS. YOU MAY HAVE OTHER RIGHTS WHICH VARY FROM JURISDICTION TO
|
||||
JURISDICTION. ID DOES NOT WARRANT THAT THE OPERATION OF THE SOFTWARE
|
||||
WILL BE UNINTERRUPTED, ERROR FREE OR MEET YOUR SPECIFIC REQUIREMENTS.
|
||||
THE WARRANTY SET FORTH ABOVE IS IN LIEU OF ALL OTHER EXPRESS
|
||||
WARRANTIES WHETHER ORAL OR WRITTEN. THE AGENTS, EMPLOYEES,
|
||||
DISTRIBUTORS, AND DEALERS OF ID ARE NOT AUTHORIZED TO MAKE
|
||||
MODIFICATIONS TO THIS WARRANTY, OR ADDITIONAL WARRANTIES ON BEHALF
|
||||
OF ID.
|
||||
|
||||
Exclusive Remedies. The Software is being offered to you
|
||||
free of any charge. You agree that you have no remedy against ID, its
|
||||
affiliates, contractors, suppliers, and agents for loss or damage
|
||||
caused by any defect or failure in the Software regardless of the form
|
||||
of action, whether in contract, tort, includinegligence, strict
|
||||
liability or otherwise, with regard to the Software. This Agreement
|
||||
shall be construed in accordance with and governed by the laws of the
|
||||
State of Texas. Copyright and other proprietary matters will be
|
||||
governed by United States laws and international treaties. IN ANY
|
||||
CASE, ID SHALL NOT BE LIABLE FOR LOSS OF DATA, LOSS OF PROFITS, LOST
|
||||
SAVINGS, SPECIAL, INCIDENTAL, CONSEQUENTIAL, INDIRECT OR OTHER
|
||||
SIMILAR DAMAGES ARISING FROM BREACH OF WARRANTY, BREACH OF CONTRACT,
|
||||
NEGLIGENCE, OR OTHER LEGAL THEORY EVEN IF ID OR ITS AGENT HAS BEEN
|
||||
ADVISED OF THE POSSIBILITY OF SUCH DAMAGES, OR FOR ANY CLAIM BY ANY
|
||||
OTHER PARTY. Some jurisdictions do not allow the exclusion or
|
||||
limitation of incidental or consequential damages, so the above
|
||||
limitation or exclusion may not apply to you.
|
||||
|
||||
|
||||
|
||||
|
534
docs/history.txt
534
docs/history.txt
|
@ -1,534 +0,0 @@
|
|||
ZDoom Release History
|
||||
|
||||
More detailed info can be found in the file docs/rh-log.txt included with
|
||||
the source code.
|
||||
|
||||
|
||||
1.22 (12 December 1999)
|
||||
=======================
|
||||
* Scroll_Texture_Both and TranslucentLine specials can now be used from ACS.
|
||||
* Fixed compiler-dependent cvar ordering during netgame arbitration.
|
||||
* Fixed certain polyobject movement combinations that would not stop even
|
||||
though they were supposed to.
|
||||
* Did some cleanup for Alpha processors.
|
||||
|
||||
|
||||
1.21 (26 November 1999)
|
||||
=======================
|
||||
* Fixed problems with thinkers removing themselves and causing other thinkers
|
||||
to not get a chance to think.
|
||||
* Added hud_scale cvar.
|
||||
|
||||
|
||||
1.20 (25 November 1999)
|
||||
=======================
|
||||
* Fixed saving, reloading, and then resaving games when travelling between
|
||||
levels in a hub.
|
||||
* Fixed saving of ACS scripts scheduled to occur on a future level.
|
||||
|
||||
|
||||
1.19 (24 November 1999)
|
||||
=======================
|
||||
* DeHackEd patches that set an actor's death sound to 0 without removing
|
||||
the A_Scream call no longer crash.
|
||||
* Fixed sync problems when playing with bullet puffs as particles vs as
|
||||
sprites.
|
||||
* Fixed friction when walking on the bottom of swimmable water.
|
||||
* Added Jeffrey Cuenco's fixes to get -host and -join to work properly.
|
||||
* Fixed BOOM generalized locked doors so that the open/close type will
|
||||
actually close.
|
||||
* Added pointer tracking and cleanup. This should fix the occasional
|
||||
crashes when saving games and various other anomalies.
|
||||
|
||||
|
||||
1.18b (15 September 1999)
|
||||
=========================
|
||||
* Fixed crash when saving games with more than 1024 objects.
|
||||
* Fixed crash when loading a game without starting a new one first.
|
||||
* Reduced the size and frequency of pregame network packets, under the
|
||||
assumption that problems people were having using 1.18 on the Internet
|
||||
are a result of limited modem bandwidth.
|
||||
|
||||
|
||||
1.18a (12 September 1999)
|
||||
=========================
|
||||
* Fixed liquid warping temporarily stopping when changing levels.
|
||||
* +/-mlook commands do not generate unknown command messages.
|
||||
* Fixed support for maps with >10 deathmatch starts. Thanks to Roman
|
||||
Hatsiev.
|
||||
* Fixed support for the special "maps" EndGame? in MAPINFO lumps.
|
||||
* Teleport destination (no gravity) now works as intended.
|
||||
* Hopefully fixed savegame problems.
|
||||
* Bots are restored from savegames.
|
||||
* Fixed keyboard turning speed when -dup is used.
|
||||
* Network commands get executed only once when -dup is used.
|
||||
* In sectors with damaging floors and swimmable deep water, the damage
|
||||
will also be applied while the player is swimming and not just when
|
||||
the player is on the ground.
|
||||
|
||||
|
||||
1.18 (5 September 1999)
|
||||
=======================
|
||||
* Replaced the older Cajun 0.71 with Cajun 0.97.
|
||||
* Fixed handling of status bar faces with skins that provide them.
|
||||
* Added swimmable water.
|
||||
* Messages printed to the middle of the screen also print to the console.
|
||||
* Skill and other server cvars get saved in savegames again.
|
||||
* Added liquid texture warping.
|
||||
* Bad MAPINFO lumps generate error messages instead of hanging.
|
||||
* Realized that it's impossible to guarantee that all object pointers will
|
||||
be valid without some effort, so FArchive saves DObject objects as NULL
|
||||
objects now instead of aborting with an error.
|
||||
* Added the ACS built-in functions localambientsound, activatorsound, and
|
||||
setlinemonsterblocking.
|
||||
* Added a thing that does nothing but count toward the number of secrets.
|
||||
* Added a fly mode.
|
||||
* Finally implemented the +moveup and +movedown commands.
|
||||
|
||||
|
||||
118test10-source only (14 August 1999)
|
||||
======================================
|
||||
* Reimplemented hub travel.
|
||||
* Optimized R_MapPlane slightly.
|
||||
* Added fov command.
|
||||
* Added vertical sub-pixel accuracy to the renderer.
|
||||
* Added searches for an IWAD in the current directory, $DOOMWADDIR, and
|
||||
$HOME.
|
||||
|
||||
|
||||
118test9 (9 August 1999)
|
||||
========================
|
||||
* Fixed the "wild" bot spinning problem.
|
||||
* Commands like changemap that could make network games go out of sync
|
||||
should work properly now. The reason they would do that is closely related
|
||||
to the reason that the bots would start spinning.
|
||||
* Finished the serializer. Now savegames work. Hubs don't, because I haven't
|
||||
written the player travelling code yet.
|
||||
* Various other code cleanup.
|
||||
|
||||
|
||||
118test8 (20 July 1999)
|
||||
=======================
|
||||
* Fixed a crash problem with the "burn" screen wipe.
|
||||
* Fixed a crash problem with playing non-assigned sound sequences.
|
||||
* Fixed a crash problem related to trying to shutdown the music subsystem
|
||||
twice.
|
||||
* If you try to add more coop bots than there are coop starts, the extra
|
||||
bot leaves quietly instead of ending the game.
|
||||
* Weapondrop is now a "server" cvar, which it should have been in the
|
||||
first place.
|
||||
* Changed the nodetable file format to be more compact.
|
||||
* Bots can now be recorded in demos.
|
||||
* Bots work in multiplayer games. Still buggy. Spawning bots can cause
|
||||
consistancy failures, and they can start spinning wildly.
|
||||
|
||||
|
||||
118test7 (12 July 1999)
|
||||
=======================
|
||||
* Fixed handling of maps with scrolling walls.
|
||||
* Single player works again. In test6, all games were considered either coop
|
||||
or deathmatch.
|
||||
* Disabled the bot thinking code in single player games, so you don't suffer
|
||||
a performance hitwhen not using bots.
|
||||
* Added some performance counters accessible through the stat command.
|
||||
|
||||
|
||||
118test6 (10 July 1999)
|
||||
=======================
|
||||
* Rewrote the wu line drawer to look better (especially in overlay mode).
|
||||
* Stretched skies now get stretched horizontally as well as vertically.
|
||||
* Did an initial integration of the Cajun Bot 0.71 code.
|
||||
|
||||
|
||||
118test5 (6 July 1999)
|
||||
======================
|
||||
* Fixed a potential infinite loop that was introduced in 118test1.
|
||||
* Delayed the initial execution of cvar callbacks.
|
||||
* Added Heretic's anti-aliased Wu line drawer to the automap.
|
||||
|
||||
|
||||
118test4 (3 July 1999)
|
||||
======================
|
||||
* Fixed the "Bad DCanvas::CopyRect" problem introduced in test3.
|
||||
* Fixed sound sequences that should not be cut off when stopped (such as
|
||||
the standard doors).
|
||||
|
||||
|
||||
118test3 (2 July 1999)
|
||||
======================
|
||||
* Removed unnecessary display mode switches.
|
||||
* Created a DCanvas class to encapsulate most 2D rendering.
|
||||
|
||||
|
||||
118test2 (1 July 1999)
|
||||
======================
|
||||
* Fixed vertical aim clipping (BFG works again).
|
||||
* Fixed monster wandering.
|
||||
* Maps with mapthings of type 0 no longer generate warning messages.
|
||||
* Crushers that do no damage no longer act as if they inflict pain to
|
||||
actors.
|
||||
* The alias command lists aliases again.
|
||||
* Aliases are saved to the config file again.
|
||||
|
||||
|
||||
118test1 (30 June 1999)
|
||||
=======================
|
||||
* Tweaked the optimized renderer for fifth-generation processors.
|
||||
* Added the following specials:
|
||||
- Line_AlignFloor
|
||||
- Line_AlignCeiling
|
||||
- Sector_SetRotation
|
||||
- Sector_SetCeilingPanning
|
||||
- Sector_SetFloorPanning
|
||||
- Secter_SetCeilingScale
|
||||
- Sector_SetFloorScale
|
||||
* Added an additional parameter to the Transfer_Heights special.
|
||||
* Switched to the OpenPTC library for display.
|
||||
* Converted lots of code to an object-oriented C++ architecture.
|
||||
|
||||
|
||||
1.17c (5 May 1999)
|
||||
==================
|
||||
* Fixed game saving crashes on maps with wind/current effects.
|
||||
* In deep water sectors, the underwater light and fog colors can now be
|
||||
set independently of the area above water.
|
||||
* Added nojump, allowjump, nofreelook, and allowfreelook keywords for
|
||||
use in MAPINFO lumps.
|
||||
* The random number seed now changes each time you run the program.
|
||||
|
||||
|
||||
1.17b (15 March 1999)
|
||||
=====================
|
||||
1.17b contains some minor bug fixes over 1.17 and 1.17a. It also loads
|
||||
faster because the sprite dimensions are not cached until they are
|
||||
actually needed. There are also some other internal changes in
|
||||
preparation for supporting Heretic and Hexen, but those don't affect
|
||||
the user yet.
|
||||
|
||||
|
||||
1.17a (21 February 1999)
|
||||
========================
|
||||
1.17a is mostly minor bug fixes and was released because Herian 2 needed
|
||||
some of those fixes. There are a few new features, however:
|
||||
|
||||
* If you have a skins directory in the same directory as zdoom.exe,
|
||||
every wad file in it will be automatically loaded when the game starts.
|
||||
This way, you don't have to load your skins by hand to use them.
|
||||
* New formatting options for text printed using ACS.
|
||||
* A code pointer to make monsters fire a railgun.
|
||||
|
||||
|
||||
1.17 (17 February 1999)
|
||||
=======================
|
||||
* I'm releasing both DOS and Win32 versions simultaneously. (The DOS version
|
||||
does not support MIDI/MUS music or a joystick.)
|
||||
|
||||
Bug fixes:
|
||||
* Multiplayer games with monsters do not crash.
|
||||
* Player corpses do not levitate and then fall down when a player respawns
|
||||
in multiplayer games.
|
||||
* Using togglemap outside of a game will not crash.
|
||||
* Monsters stop attacking their target once it's dead.
|
||||
* EV_StopPlat() does not get stuck in an infinite loop if there are moving
|
||||
platforms.
|
||||
* Partially invisible players are drawn the proper colors (instead of
|
||||
green) if r_drawfuzz is 0.
|
||||
* If you are invisible, so are your muzzle flashes.
|
||||
* Trying to execute a non-existant script will not crash.
|
||||
* Using a ChangeCamera special from an open script will not crash.
|
||||
* The FloorAndCeiling_RaiseByValue and FloorAndCeiling_LowerByValues now
|
||||
behave like Hexen's.
|
||||
* Using -loadgame from the command line works.
|
||||
* Fixed a memory leak during generation of the translucency tables.
|
||||
* In high resolutions, weapon sprites meet the bottom of the screen.
|
||||
* Sounds will not cut out mysteriously when there is no reason for them to
|
||||
do so.
|
||||
* Sounds will also not be stopped immediately when a thing is removed, so
|
||||
explosion sounds will play to their full length.
|
||||
* Things can make more than one sound at once.
|
||||
* The deathmatch scoreboard is aligned properly at high resolutions.
|
||||
* Spynext and spyprev work properly instead of leaving the status bar
|
||||
"lagging behind" the player being viewed.
|
||||
* The light-amp does not disable colored lighting.
|
||||
* The sky gets inverted when using the invulnerability powerup.
|
||||
* Implemented better z-checking code (from Heretic/Hexen).
|
||||
* Pain elementals will spawn one lost soul at a time instead of two inside
|
||||
of each other.
|
||||
* Bex patches that use thing mnemonics really do work now, and unknown bit
|
||||
messages aren't generated for regular DeHackEd patches.
|
||||
* Linedef type 134 for regular DOOM/BOOM maps requires a red key for
|
||||
activation (it was being improperly translated to require a blue one).
|
||||
* Monsters can activate secret lines when they cross them. (See DOOM2/MAP08).
|
||||
* The player extreme death sound is used.
|
||||
* When a player leaves a network game, their body is removed instead of
|
||||
being left empty.
|
||||
* 0-length sounds are treated as empty sounds instead of sounds 4 gigs long.
|
||||
* Skins that replaced player sounds with sounds in the IWAD work.
|
||||
* Muzzle flashes do not light up foggy areas, and fullbright sprites stay
|
||||
shrouded in fog.
|
||||
* Alphanumeric keys no longer automatically repeat on the console.
|
||||
* Wads such as gothicdm2 that used new flats in addition to the ones in the
|
||||
IWAD with the regular doom.exe work.
|
||||
|
||||
New features:
|
||||
* Significant speed improvements on modern processors.
|
||||
* Armor and keys are shown on the fullscreen HUD.
|
||||
* Colored text.
|
||||
* A playdemo console command.
|
||||
* A chasecam.
|
||||
* A particle sytsem.
|
||||
* An optional railgun to show off the particle system. (Start the game with
|
||||
-deh railgun.bex if you want to use it.)
|
||||
|
||||
New features interesting for wad authors:
|
||||
* Polyobjects.
|
||||
* Sound sequences.
|
||||
* WAVE files can be used as sound lumps without converting them to DMX's
|
||||
format first.
|
||||
* A sky can be specified to not be stretched even if it is shorter than 200
|
||||
pixels.
|
||||
* Sparks.
|
||||
* Particle fountains.
|
||||
* Parallax skies.
|
||||
* Some new DeHackEd thing flags from Hexen (bobbing, reflective, etc.).
|
||||
|
||||
|
||||
1.16 (22 December 1998)
|
||||
=======================
|
||||
Bug fixes:
|
||||
* No more limit on size of savegames or demos.
|
||||
* Screen resolutions above 320x200 are now the proper brightness (they were
|
||||
too bright before.)
|
||||
* Improved the brightness of the console font.
|
||||
* Bullet puffs can show up on the floor and ceiling and not just walls.
|
||||
* Missile weapons can trigger gun activation lines.
|
||||
* Barrels now bounce around as much as they did in original DOOM. (They were
|
||||
too "inert" in 1.14.)
|
||||
* If a demo is being recorded, quitting the game normally will save the demo
|
||||
to disk. (Previously, you had to use the stop command to do this.)
|
||||
|
||||
New features for players:
|
||||
* Proper support for BOOM maps.
|
||||
* Mouse wheel support and weapnext/weapprev commands.
|
||||
* Doublebindings.
|
||||
* Better analog joystick support.
|
||||
* 180 degree turn command for keyboarders.
|
||||
* Damage done by a rocket to its shooter is configurable and defaults to the
|
||||
original Doom behavior.
|
||||
* User-configurable gender. (Even though I don't have any new player sounds,
|
||||
at least the obituaries are gender-aware. :-)
|
||||
* Teamplay mode.
|
||||
* New cvar to disable manual aiming of the BFG to prevent someone from
|
||||
shooting it at the floor and quickly triggering tracer damage before.
|
||||
* Maps no longer need to have as many deathmatch starts as there are players
|
||||
in a deathmatch game.
|
||||
* Support for Doom Legacy skins.
|
||||
* Rewrote the MIDI/MUS code so that it has a working volume control.
|
||||
* Many more console commands and cvars.
|
||||
|
||||
New features for editors:
|
||||
* Proper support for BOOM maps.
|
||||
* Obituaries are configurable with a .bex patch.
|
||||
* Moster paths
|
||||
* Colored lighting
|
||||
* Fog can be applied to only part of a level instead of all of it.
|
||||
* Per-sector gravity settings.
|
||||
* Support for up to 256 ambient sounds (as opposed to the limit of 64 in
|
||||
earlier versions).
|
||||
* Sector damage adjustable from between 0-255 points of damage.
|
||||
* Changable camera views.
|
||||
* The following editing features that were introduced in Hexen are also
|
||||
available in ZDoom:
|
||||
- Most line specials take arguments that modify their behavior.
|
||||
- ACS scripting.
|
||||
- Hubs.
|
||||
- Earthquakes.
|
||||
- Dormant monsters.
|
||||
- Trigger events to happen on monster deaths.
|
||||
- "Waggling" floors.
|
||||
- Pillar builders.
|
||||
- Push activation lines (walking into a wall can trigger an event).
|
||||
- Thing spawning (e.g. for traps/gifts).
|
||||
|
||||
|
||||
1.14a (27 July 1998)
|
||||
====================
|
||||
Bugs fixed are:
|
||||
|
||||
* No more crashing about freeing a pointer without ZONEID when changing
|
||||
levels.
|
||||
* Skies wider than 256 pixels are drawn correctly.
|
||||
* Monsters' heights are once again the same as they were in id's original
|
||||
DOOM, so certain areas work properly again.
|
||||
* Monsters shouldn't teleport into each other anymore.
|
||||
* Improved support for international keyboards.
|
||||
* The skill level chosen for a new game is no longer ignored if the new
|
||||
game is started while a demo is playing.
|
||||
|
||||
Cosmetic changes:
|
||||
|
||||
* No more "sv_gravity changed to...", "skill changed to...", etc. messages
|
||||
in single player games.
|
||||
* Activating the player setup menu automatically stops any playing demos,
|
||||
since it doesn't work properly while they play.
|
||||
* Barrels don't go flying away when exploding anymore.
|
||||
* Added def_patch cvar to automatically load a DeHackEd patch each time the
|
||||
game is started.
|
||||
* ZDoom save games now use the name zdoomsv?.dsg instead of doomsav?.dsg.
|
||||
|
||||
This version also includes some preliminary BOOM support as I started
|
||||
integrating some of the BOOM source code with ZDoom:
|
||||
|
||||
* Medusa fix.
|
||||
* Openings limit removed.
|
||||
* Removed limit on switches and animations.
|
||||
* Added support for BOOM-like ANIMATED and SWITCHES lumps in PWADs.
|
||||
* Added support for BOOM-style scrollers (including conveyors).
|
||||
* Added partial deep-water support.
|
||||
|
||||
|
||||
1.14 (14 July 1998)
|
||||
===================
|
||||
Bugs fixed:
|
||||
* The bunny scroller at the end of E3M8 no longer crashes the game.
|
||||
* The IDKFA cheat gives the proper amount of armor again.
|
||||
* Demo recording works again.
|
||||
* Telefragging works again.
|
||||
* Picking up the invulnerability sphere displays the correct colors now.
|
||||
* DeHackEd patches containing text replacements no longer crash the game.
|
||||
* Printing a string containing "%s" to the console and then changing the
|
||||
video mode will no longer crash the game.
|
||||
* Chat mode finally works again.
|
||||
* If MIDAS can't initialize, you can still play the game but without sound.
|
||||
* Pistol and chaingun sounds no longer cut out when there are lots of
|
||||
zombie men shooting their pistols at you.
|
||||
* Mouse input should no longer be so jerky under Windows NT.
|
||||
* The crosshair is finally accurate for aiming.
|
||||
* Autoaim is properly remembered each time you start ZDoom.
|
||||
* Switches in the Ultimate Doom that aren't also in the shareware Doom
|
||||
properly change their appearance when switched.
|
||||
|
||||
New features:
|
||||
* Players can choose their own colors and names.
|
||||
(Player setup menu is included).
|
||||
* 8-player support (untested but should work).
|
||||
* Miscellaneous internal code changes have been borrowed from the BOOM
|
||||
source. (This does *not* mean that ZDoom supports BOOM levels yet.)
|
||||
* Cheats, chat messages, and gamestate changes are now recorded in demos.
|
||||
* Single-player demos recorded with ZDoom are generally smaller than
|
||||
before.
|
||||
* Quake 2-style deathmatch flags.
|
||||
* Cheats (optionally) work in multiplayer games.
|
||||
* Mode X is now supported under Win95, so all the machines that couldn't
|
||||
run ZDoom in 320x200 before should be able to now.
|
||||
* Fewer conditions result in error messages that quit the game. (If you
|
||||
have Heretic, try this: Start ZDoom with -file heretic and go to the
|
||||
console and type "MAP E1M1".)
|
||||
* Keys can repeat in the console.
|
||||
* The console and chat mode now use the localized keymap set with the
|
||||
Keyboard control panel.
|
||||
* Messages at the top of the screen now break along between words instead
|
||||
of in the middle of them.
|
||||
* Added -config command line parameter.
|
||||
* Added -fastdemo command line parameter.
|
||||
* Added new screen shot command. (bound to "Print Screen" key by default)
|
||||
* Added Quake-like +showscores command. (bound to "\" key by default)
|
||||
* Aliases are now saved in the config file.
|
||||
* Added support for multiple pitched sounds like in very old version of
|
||||
Doom. (Use the snd_pitched cvar to turn it on and off.)
|
||||
|
||||
|
||||
1.13 (26 May 1998)
|
||||
==================
|
||||
* Fixed some major bugs (that crashed the game) and other lesser bugs that were
|
||||
just annoying.
|
||||
* 3-D collisions for walking under and standing on other things.
|
||||
* The status bar can be scaled to the full width of the screen.
|
||||
* The screen mode can be selected from a menu inside the game.
|
||||
* ZDoom can run in a window on the desktop.
|
||||
* Better DeHackEd support. Only a few text replacements are not supported.
|
||||
Everything else works (including monster infighting which I haven't seen
|
||||
in any other port).
|
||||
* New features for level designers (see editing.txt for details):
|
||||
Specification of next and secret maps on a per-map basis.
|
||||
Specify sky texture on a per-map basis.
|
||||
Use any lump in a wad as music for a map.
|
||||
Give maps a custom name without using a DeHackEd patch.
|
||||
Maps can be named anything (not just E?M? or MAP??).
|
||||
Place any messages of any length between any two maps.
|
||||
Hexen-style fog (of any color).
|
||||
Ambient sounds--either point like Quake or global like Heretic and Hexen.
|
||||
Automatic use of DeHackEd patches in PWADs.
|
||||
No more tutti-frutti for short textures of certain heights.
|
||||
zdoom.wcf file for use with WadAuthor.
|
||||
* Rocket jumping. (One very important note about this: You need to be *in the
|
||||
air* when your rocket explodes for rocket jumping to work. This is different
|
||||
from Quake, and I will probably rewrite it for the next release.)
|
||||
* Dynamic palette flashes.
|
||||
* Supports stretching skies for freelook.
|
||||
* Larger freelook range.
|
||||
* Added tab-completion to the console.
|
||||
* zdoom.cfg is now the name of the default configuration file since Doom
|
||||
Legacy decided to start using config.cfg.
|
||||
* French language support. (Set language cvar to "french".)
|
||||
* Player obituaries.
|
||||
* Unlimited ammo cheat (use g_unlimitedammo cvar).
|
||||
|
||||
|
||||
1.12 (7 April 1998)
|
||||
===================
|
||||
* Some visual enhancements were made such as centering the menus and
|
||||
drawing borders around the status bar in higher resolutions.
|
||||
* Console commands can now be specified on the command line.
|
||||
* Removed some of DOOM's limits such as VisPlanes, VisSprites, and 2S
|
||||
HOM.
|
||||
* Rewrote some of the inner loops in assembly. (There was some assembly
|
||||
in 1.11, but it never got used.)
|
||||
* New cvars relating to mouse movement. (invertmouse, m_pitch, m_yaw,
|
||||
etc.)
|
||||
* Mouse movement doesn't get sluggish in high resolutions.
|
||||
* Automap colors are customizable.
|
||||
* Automap overlay and rotation are available.
|
||||
* Eight crosshairs.
|
||||
* Shoot up/down.
|
||||
* Alt-Tab and Pause work properly on all machines now.
|
||||
* The +jump command now works.
|
||||
* 25% and 75% translucency levels in addition to 50%. The translucency
|
||||
tables now get saved to disk, too, so they only need to be calculated
|
||||
once instead of every time the game is run.
|
||||
* The console font is now editable.
|
||||
* Near complete support for DeHackEd patches. (Only monster infighting
|
||||
and changing a few minor text strings are not supported.)
|
||||
* Sky height and position is now fixed for high resolutions. (It still
|
||||
wraps if you look up, but at least now if you look straight ahead, it
|
||||
never will.)
|
||||
* Weapon sprite is always drawn at the correct location. (It was being
|
||||
drawn too low in some resolutions like 400x300.)
|
||||
* New options menu, which includes a key configuration screen.
|
||||
* "Stealth" monsters.
|
||||
* New full-screen HUD.
|
||||
* And a few other things not worth mentioning separately.
|
||||
|
||||
|
||||
1.11 (6 March 1998) Initial Release
|
||||
===================================
|
||||
* Works under both Windows 95 and NT 4.0, although it works best under
|
||||
Win95.
|
||||
* Limited support for the Pause key. It works with some keyboards on
|
||||
some machines.
|
||||
* Supports any resolution compatible with your DirectDraw drivers.
|
||||
* Look up/down ala Heretic.
|
||||
* Translucency for selected objects.
|
||||
* Has a console with most of the functionality of Quake's. The only
|
||||
significant missing feature is Tab-completion.
|
||||
* Notarget cheat.
|
||||
* Command to kill all monsters in a level or yourself.
|
||||
* Can play MUS, MIDI, and MOD music.
|
||||
* Selected sounds are played in surround sound.
|
||||
* Doors that need keys to open are highlighted on the automap.
|
||||
* Automap now shows various statistics in addition to the level name.
|
||||
* True keybindings. Bind any key to any command or sequence of
|
||||
commands.
|
||||
* Intermission screen can now display your stats using absolute values
|
||||
rather than percentages.
|
||||
* A new more general demo format.
|
21756
docs/rh-log.txt
21756
docs/rh-log.txt
File diff suppressed because it is too large
Load diff
1134
docs/zdoom.txt
1134
docs/zdoom.txt
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue