2 Copyright (C) 1996-1997 Id Software, Inc.
4 This program is free software; you can redistribute it and/or
5 modify it under the terms of the GNU General Public License
6 as published by the Free Software Foundation; either version 2
7 of the License, or (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13 See the GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24 #define MAX_MAP_HULLS 16 // Q1BSP has 4, Hexen2 Q1BSP has 8, MCBSP has 16
26 //=============================================================================
30 #define HLBSPVERSION 30
31 #define _2PSBVERSION ('2' + 'P' * 256 + 'S' * 65536 + 'B' * 16777216)
32 #define BSP2VERSION ('B' + 'S' * 256 + 'P' * 65536 + '2' * 16777216)
33 #define VBSPVERSION ('V' + 'B' * 256 + 'S' * 65536 + 'P' * 16777216)
40 #define LUMP_ENTITIES 0
42 #define LUMP_TEXTURES 2
43 #define LUMP_VERTEXES 3
44 #define LUMP_VISIBILITY 4
46 #define LUMP_TEXINFO 6
48 #define LUMP_LIGHTING 8
49 #define LUMP_CLIPNODES 9
51 #define LUMP_MARKSURFACES 11
53 #define LUMP_SURFEDGES 13
54 #define LUMP_MODELS 14
55 #define HEADER_LUMPS 15
57 typedef struct hullinfo_s
60 float hullsizes[MAX_MAP_HULLS][2][3];
63 typedef struct mmodel_s
65 float mins[3], maxs[3];
67 int headnode[MAX_MAP_HULLS];
68 int visleafs; // not including the solid leaf 0
69 int firstface, numfaces;
73 // WARNING: this struct does NOT match q1bsp's disk format because MAX_MAP_HULLS has been changed by Sajt's MCBSP code, this struct is only being used in memory as a result
74 typedef struct dmodel_s
76 float mins[3], maxs[3];
78 int headnode[MAX_MAP_HULLS];
79 int visleafs; // not including the solid leaf 0
80 int firstface, numfaces;
83 typedef struct dheader_s
86 lump_t lumps[HEADER_LUMPS];
89 typedef struct dmiptexlump_s
92 int dataofs[4]; // [nummiptex]
98 typedef struct miptex_s
101 unsigned width, height;
102 unsigned offsets[MIPLEVELS]; // four mip maps stored
106 typedef struct dvertex_s
113 // 0-2 are axial planes
118 // 3-5 are non-axial planes snapped to the nearest
124 typedef struct dplane_s
128 int type; // PLANE_X - PLANE_ANYZ ?remove? trivial to regenerate
133 // contents values in Q1 maps
134 #define CONTENTS_EMPTY -1
135 #define CONTENTS_SOLID -2
136 #define CONTENTS_WATER -3
137 #define CONTENTS_SLIME -4
138 #define CONTENTS_LAVA -5
139 #define CONTENTS_SKY -6
140 // these were #ifdef QUAKE2 in the quake source
141 #define CONTENTS_ORIGIN -7 // removed at csg time
142 #define CONTENTS_CLIP -8 // changed to contents_solid
143 #define CONTENTS_CURRENT_0 -9
144 #define CONTENTS_CURRENT_90 -10
145 #define CONTENTS_CURRENT_180 -11
146 #define CONTENTS_CURRENT_270 -12
147 #define CONTENTS_CURRENT_UP -13
148 #define CONTENTS_CURRENT_DOWN -14
150 //contents flags in Q2 maps
151 #define CONTENTSQ2_SOLID 0x00000001 // an eye is never valid in a solid
152 #define CONTENTSQ2_WINDOW 0x00000002 // translucent, but not watery
153 #define CONTENTSQ2_AUX 0x00000004
154 #define CONTENTSQ2_LAVA 0x00000008
155 #define CONTENTSQ2_SLIME 0x00000010
156 #define CONTENTSQ2_WATER 0x00000020
157 #define CONTENTSQ2_MIST 0x00000040
158 #define CONTENTSQ2_AREAPORTAL 0x00008000
159 #define CONTENTSQ2_PLAYERCLIP 0x00010000
160 #define CONTENTSQ2_MONSTERCLIP 0x00020000
161 #define CONTENTSQ2_CURRENT_0 0x00040000
162 #define CONTENTSQ2_CURRENT_90 0x00080000
163 #define CONTENTSQ2_CURRENT_180 0x00100000
164 #define CONTENTSQ2_CURRENT_270 0x00200000
165 #define CONTENTSQ2_CURRENT_UP 0x00400000
166 #define CONTENTSQ2_CURRENT_DOWN 0x00800000
167 #define CONTENTSQ2_ORIGIN 0x01000000 // removed before bsping an entity
168 #define CONTENTSQ2_MONSTER 0x02000000 // should never be on a brush, only in game
169 #define CONTENTSQ2_DEADMONSTER 0x04000000
170 #define CONTENTSQ2_DETAIL 0x08000000 // brushes to be added after vis leafs
171 #define CONTENTSQ2_TRANSLUCENT 0x10000000 // auto set if any surface has trans
172 #define CONTENTSQ2_LADDER 0x20000000
174 //contents flags in Q3 maps
175 #define CONTENTSQ3_SOLID 0x00000001 // solid (opaque and transparent)
176 #define CONTENTSQ3_LAVA 0x00000008 // lava
177 #define CONTENTSQ3_SLIME 0x00000010 // slime
178 #define CONTENTSQ3_WATER 0x00000020 // water
179 #define CONTENTSQ3_FOG 0x00000040 // unused?
180 #define CONTENTSQ3_AREAPORTAL 0x00008000 // areaportal (separates areas)
181 #define CONTENTSQ3_PLAYERCLIP 0x00010000 // block players
182 #define CONTENTSQ3_MONSTERCLIP 0x00020000 // block monsters
183 #define CONTENTSQ3_TELEPORTER 0x00040000 // hint for Q3's bots
184 #define CONTENTSQ3_JUMPPAD 0x00080000 // hint for Q3's bots
185 #define CONTENTSQ3_CLUSTERPORTAL 0x00100000 // hint for Q3's bots
186 #define CONTENTSQ3_DONOTENTER 0x00200000 // hint for Q3's bots
187 #define CONTENTSQ3_BOTCLIP 0x00400000 // hint for Q3's bots
188 #define CONTENTSQ3_ORIGIN 0x01000000 // used by origin brushes to indicate origin of bmodel (removed by map compiler)
189 #define CONTENTSQ3_BODY 0x02000000 // used by bbox entities (should never be on a brush)
190 #define CONTENTSQ3_CORPSE 0x04000000 // used by dead bodies (SOLID_CORPSE in darkplaces)
191 #define CONTENTSQ3_DETAIL 0x08000000 // brushes that do not split the bsp tree (decorations)
192 #define CONTENTSQ3_STRUCTURAL 0x10000000 // brushes that split the bsp tree
193 #define CONTENTSQ3_TRANSLUCENT 0x20000000 // leaves surfaces that are inside for rendering
194 #define CONTENTSQ3_TRIGGER 0x40000000 // used by trigger entities
195 #define CONTENTSQ3_NODROP 0x80000000 // remove items that fall into this brush
197 #define SUPERCONTENTS_SOLID 0x00000001
198 #define SUPERCONTENTS_WATER 0x00000002
199 #define SUPERCONTENTS_SLIME 0x00000004
200 #define SUPERCONTENTS_LAVA 0x00000008
201 #define SUPERCONTENTS_SKY 0x00000010
202 #define SUPERCONTENTS_BODY 0x00000020
203 #define SUPERCONTENTS_CORPSE 0x00000040
204 #define SUPERCONTENTS_NODROP 0x00000080
205 #define SUPERCONTENTS_PLAYERCLIP 0x00000100
206 #define SUPERCONTENTS_MONSTERCLIP 0x00000200
207 #define SUPERCONTENTS_DONOTENTER 0x00000400
208 #define SUPERCONTENTS_BOTCLIP 0x00000800
209 #define SUPERCONTENTS_OPAQUE 0x00001000
210 // TODO: is there any reason to define:
216 // detail? (div0) no, game code should not be allowed to differentiate between structural and detail
217 // structural? (div0) no, game code should not be allowed to differentiate between structural and detail
218 // trigger? (div0) no, as these are always solid anyway, and that's all that matters for trigger brushes
219 #define SUPERCONTENTS_LIQUIDSMASK (SUPERCONTENTS_LAVA | SUPERCONTENTS_SLIME | SUPERCONTENTS_WATER)
220 #define SUPERCONTENTS_VISBLOCKERMASK SUPERCONTENTS_OPAQUE
223 #define SUPERCONTENTS_DEADMONSTER 0x00000000
224 #define SUPERCONTENTS_CURRENT_0 0x00000000
225 #define SUPERCONTENTS_CURRENT_90 0x00000000
226 #define SUPERCONTENTS_CURRENT_180 0x00000000
227 #define SUPERCONTENTS_CURRENT_270 0x00000000
228 #define SUPERCONTENTS_CURRENT_DOWN 0x00000000
229 #define SUPERCONTENTS_CURRENT_UP 0x00000000
230 #define SUPERCONTENTS_AREAPORTAL 0x00000000
231 #define SUPERCONTENTS_AUX 0x00000000
232 #define SUPERCONTENTS_CLUSTERPORTAL 0x00000000
233 #define SUPERCONTENTS_DETAIL 0x00000000
234 #define SUPERCONTENTS_STRUCTURAL 0x00000000
235 #define SUPERCONTENTS_DONOTENTER 0x00000000
236 #define SUPERCONTENTS_JUMPPAD 0x00000000
237 #define SUPERCONTENTS_LADDER 0x00000000
238 #define SUPERCONTENTS_MONSTER 0x00000000
239 #define SUPERCONTENTS_MONSTERCLIP 0x00000000
240 #define SUPERCONTENTS_PLAYERCLIP 0x00000000
241 #define SUPERCONTENTS_TELEPORTER 0x00000000
242 #define SUPERCONTENTS_TRANSLUCENT 0x00000000
243 #define SUPERCONTENTS_TRIGGER 0x00000000
244 #define SUPERCONTENTS_WINDOW 0x00000000
248 typedef struct dnode_s
251 short children[2]; // negative numbers are -(leafs+1), not nodes
252 short mins[3]; // for sphere culling
254 unsigned short firstface;
255 unsigned short numfaces; // counting both sides
258 typedef struct dclipnode_s
261 short children[2]; // negative numbers are contents
265 typedef struct texinfo_s
267 float vecs[2][4]; // [s/t][xyz offset]
272 #define TEX_SPECIAL 1 // sky or slime, no lightmap or 256 subdivision
274 // note that edge 0 is never used, because negative edge nums are used for
275 // counterclockwise use of the edge in a face
277 typedef struct dedge_s
279 unsigned short v[2]; // vertex numbers
283 #define MAXLIGHTMAPS 4
285 typedef struct dface_s
287 // LadyHavoc: changed from short to unsigned short for q2 support
288 unsigned short planenum;
291 int firstedge; // we must support > 64k edges
296 unsigned char styles[MAXLIGHTMAPS];
297 int lightofs; // start of [numstyles*surfsize] samples
303 #define AMBIENT_WATER 0
304 #define AMBIENT_SKY 1
305 #define AMBIENT_SLIME 2
306 #define AMBIENT_LAVA 3
308 #define NUM_AMBIENTS 4 // automatic ambient sounds
310 // leaf 0 is the generic CONTENTS_SOLID leaf, used for all solid areas
311 // all other leafs need visibility info
313 typedef struct dleaf_s
316 int visofs; // -1 = no visibility info
318 short mins[3]; // for frustum culling
321 unsigned short firstmarksurface;
322 unsigned short nummarksurfaces;
324 unsigned char ambient_level[NUM_AMBIENTS];