Subversion Repositories eduke32

Rev

Rev 582 | Rev 587 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
5 Plagman 1
//-------------------------------------------------------------------------
2
/*
484 terminx 3
Copyright (C) 1996, 2003 - 3D Realms Entertainment
4
Copyright (C) 2000, 2003 - Matt Saettler (EDuke Enhancements)
5
Copyright (C) 2004, 2007 - EDuke32 developers
5 Plagman 6
 
7
This file is part of EDuke32
8
 
9
EDuke32 is free software; you can redistribute it and/or
10
modify it under the terms of the GNU General Public License version 2
11
as published by the Free Software Foundation.
12
 
13
This program is distributed in the hope that it will be useful,
14
but WITHOUT ANY WARRANTY; without even the implied warranty of
15
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
16
 
17
See the GNU General Public License for more details.
18
 
19
You should have received a copy of the GNU General Public License
20
along with this program; if not, write to the Free Software
21
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22
*/
23
//-------------------------------------------------------------------------
24
 
25
#include "duke3d.h"
26
#include "gamedef.h"
27
 
28
#include "osd.h"
29
 
561 terminx 30
int g_ScriptVersion = 13;
5 Plagman 31
 
398 terminx 32
char compilefile[BMAX_PATH] = "(none)";  // file we're currently compiling
5 Plagman 33
static char parsing_item_name[MAXVARLABEL] = "(none)", previous_item_name[MAXVARLABEL] = "NULL";
34
 
432 terminx 35
int total_lines,line_number;
36
static int checking_ifelse,parsing_state;
5 Plagman 37
char g_szBuf[1024];
38
 
584 terminx 39
int *casescriptptr=NULL;      // the pointer to the start of the case table in a switch statement
5 Plagman 40
// first entry is 'default' code.
432 terminx 41
static int casecount = 0;
42
static int checking_switch = 0, current_event = -1;
43
static int labelsonly = 0, nokeywordcheck = 0, dynamicremap = 0;
44
static int num_braces = 0;    // init to some sensible defaults
5 Plagman 45
 
92 terminx 46
int redefined_quote_count = 0;
5 Plagman 47
 
584 terminx 48
int *aplWeaponClip[MAX_WEAPONS];       // number of items in magazine
49
int *aplWeaponReload[MAX_WEAPONS];     // delay to reload (include fire)
50
int *aplWeaponFireDelay[MAX_WEAPONS];      // delay to fire
51
int *aplWeaponHoldDelay[MAX_WEAPONS];      // delay after release fire button to fire (0 for none)
52
int *aplWeaponTotalTime[MAX_WEAPONS];      // The total time the weapon is cycling before next fire.
53
int *aplWeaponFlags[MAX_WEAPONS];      // Flags for weapon
54
int *aplWeaponShoots[MAX_WEAPONS];     // what the weapon shoots
55
int *aplWeaponSpawnTime[MAX_WEAPONS];      // the frame at which to spawn an item
56
int *aplWeaponSpawn[MAX_WEAPONS];      // the item to spawn
57
int *aplWeaponShotsPerBurst[MAX_WEAPONS];  // number of shots per 'burst' (one ammo per 'burst'
58
int *aplWeaponWorksLike[MAX_WEAPONS];      // What original the weapon works like
59
int *aplWeaponInitialSound[MAX_WEAPONS];   // Sound made when initialy firing. zero for no sound
60
int *aplWeaponFireSound[MAX_WEAPONS];      // Sound made when firing (each time for automatic)
61
int *aplWeaponSound2Time[MAX_WEAPONS];     // Alternate sound time
62
int *aplWeaponSound2Sound[MAX_WEAPONS];    // Alternate sound sound ID
63
int *aplWeaponReloadSound1[MAX_WEAPONS];    // Sound of magazine being removed
64
int *aplWeaponReloadSound2[MAX_WEAPONS];    // Sound of magazine being inserted
5 Plagman 65
 
66
int g_iReturnVarID=-1;      // var ID of "RETURN"
67
int g_iWeaponVarID=-1;      // var ID of "WEAPON"
68
int g_iWorksLikeVarID=-1;   // var ID of "WORKSLIKE"
69
int g_iZRangeVarID=-1;      // var ID of "ZRANGE"
70
int g_iAngRangeVarID=-1;    // var ID of "ANGRANGE"
71
int g_iAimAngleVarID=-1;    // var ID of "AUTOAIMANGLE"
72
int g_iLoTagID=-1;          // var ID of "LOTAG"
73
int g_iHiTagID=-1;          // var ID of "HITAG"
74
int g_iTextureID=-1;        // var ID of "TEXTURE"
75
int g_iThisActorID=-1;      // var ID of "THISACTOR"
76
 
584 terminx 77
int *actorLoadEventScrptr[MAXTILES];
5 Plagman 78
 
584 terminx 79
int *apScriptGameEvent[MAXGAMEEVENTS];
80
int *parsing_event=NULL;
5 Plagman 81
 
580 terminx 82
gamevar_t aGameVars[MAXGAMEVARS];
5 Plagman 83
int iGameVarCount=0;
84
 
584 terminx 85
extern int qsetmode;
5 Plagman 86
 
432 terminx 87
char *textptr;
88
int error,warning;
89
 
335 terminx 90
enum labeltypes
91
{
255 terminx 92
    LABEL_ANY    = -1,
93
    LABEL_DEFINE = 1,
94
    LABEL_STATE  = 2,
95
    LABEL_ACTOR  = 4,
96
    LABEL_ACTION = 8,
97
    LABEL_AI     = 16,
98
    LABEL_MOVE   = 32,
5 Plagman 99
};
100
 
437 terminx 101
static const char *labeltypenames[] =
559 terminx 102
{
103
    "define",
104
    "state",
105
    "actor",
106
    "action",
107
    "ai",
108
    "move"
109
};
5 Plagman 110
 
584 terminx 111
static const char *translatelabeltype(int type)
5 Plagman 112
{
113
    int i;
114
    char x[64];
115
 
116
    x[0] = 0;
335 terminx 117
    for (i=0;i<6;i++)
118
    {
5 Plagman 119
        if (!(type & (1<<i))) continue;
120
        if (x[0]) Bstrcat(x, " or ");
121
        Bstrcat(x, labeltypenames[i]);
122
    }
123
    return strdup(x);
124
}
125
 
126
#define NUMKEYWORDS (signed int)(sizeof(keyw)/sizeof(keyw[0]))
127
 
484 terminx 128
static const char *keyw[] =
559 terminx 129
{
130
    "definelevelname",          // 0  defines level name
131
    "actor",                    // 1  defines an actor
132
    "addammo",                  // 2  adds ammo to a weapon
133
    "ifrnd",                    // 3  checks against a randomizer
134
    "enda",                     // 4  ends an actor definition
135
    "ifcansee",                 // 5  checks if the player can see an object
136
    "ifhitweapon",              // 6  checks if an object was hit by a weapon
137
    "action",                   // 7  defines an action if used outside a state or actor, otherwise triggers actor to perform action
138
    "ifpdistl",                 // 8  checks if player distance is less than value
139
    "ifpdistg",                 // 9  checks if player distance is more than value
140
    "else",                     // 10 used with if checks
141
    "strength",                 // 11 sets health
142
    "break",                    // 12 stops processing
143
    "shoot",                    // 13 shoots a projectile
144
    "palfrom",                  // 14 used for player screen shading effect, sets p->pals_time and p->pals[0-2]
145
    "sound",                    // 15 plays a sound that was defined with definesound
146
    "fall",                     // 16 causes actor to fall to sector floor height
147
    "state",                    // 17 begins defining a state if used outside a state or actor, otherwise calls a state
148
    "ends",                     // 18 ends defining a state
149
    "define",                   // 19 defines a value
150
    "<null>",                   // 20 was previously used to define a comment
151
    "ifai",                     // 21 checks if actor is currently performing a specific ai function
152
    "killit",                   // 22 kills an actor
153
    "addweapon",                // 23 adds a weapon to the closest player
154
    "ai",                       // 24 sets an ai function to be used by an actor
155
    "addphealth",               // 25 adds health to the player
156
    "ifdead",                   // 26 checks if actor is dead
157
    "ifsquished",               // 27 checks if actor has been squished
158
    "sizeto",                   // 28 gradually increases actor size until it matches parameters given
159
    "{",                        // 29 used to indicate segments of code
160
    "}",                        // 30 used to indicate segments of code
161
    "spawn",                    // 31 spawns an actor
162
    "move",                     // 32
163
    "ifwasweapon",              // 33
164
    "ifaction",                 // 34
165
    "ifactioncount",            // 35
166
    "resetactioncount",         // 36
167
    "debris",                   // 37
168
    "pstomp",                   // 38
169
    "<null>",                   // 39 was previously used to define the start of a comment block
170
    "cstat",                    // 40
171
    "ifmove",                   // 41
172
    "resetplayer",              // 42
173
    "ifonwater",                // 43
174
    "ifinwater",                // 44
175
    "ifcanshoottarget",         // 45
176
    "ifcount",                  // 46
177
    "resetcount",               // 47
178
    "addinventory",             // 48
179
    "ifactornotstayput",        // 49
180
    "hitradius",                // 50
181
    "ifp",                      // 51
182
    "count",                    // 52
183
    "ifactor",                  // 53
184
    "music",                    // 54
185
    "include",                  // 55
186
    "ifstrength",               // 56
187
    "definesound",              // 57
188
    "guts",                     // 58
189
    "ifspawnedby",              // 59
190
    "gamestartup",              // 60
191
    "wackplayer",               // 61
192
    "ifgapzl",                  // 62
193
    "ifhitspace",               // 63
194
    "ifoutside",                // 64
195
    "ifmultiplayer",            // 65
196
    "operate",                  // 66
197
    "ifinspace",                // 67
198
    "debug",                    // 68
199
    "endofgame",                // 69
200
    "ifbulletnear",             // 70
201
    "ifrespawn",                // 71
202
    "iffloordistl",             // 72
203
    "ifceilingdistl",           // 73
204
    "spritepal",                // 74
205
    "ifpinventory",             // 75
206
    "betaname",                 // 76
207
    "cactor",                   // 77
208
    "ifphealthl",               // 78
209
    "definequote",              // 79
210
    "quote",                    // 80
211
    "ifinouterspace",           // 81
212
    "ifnotmoving",              // 82
213
    "respawnhitag",             // 83
214
    "tip",                      // 84
215
    "ifspritepal",              // 85
216
    "money",                    // 86
217
    "soundonce",                // 87
218
    "addkills",                 // 88
219
    "stopsound",                // 89
220
    "ifawayfromwall",           // 90
221
    "ifcanseetarget",           // 91
222
    "globalsound",              // 92
223
    "lotsofglass",              // 93
224
    "ifgotweaponce",            // 94
225
    "getlastpal",               // 95
226
    "pkick",                    // 96
227
    "mikesnd",                  // 97
228
    "useractor",                // 98
229
    "sizeat",                   // 99
230
    "addstrength",              // 100  [#]
231
    "cstator",                  // 101
232
    "mail",                     // 102
233
    "paper",                    // 103
234
    "tossweapon",               // 104
235
    "sleeptime",                // 105
236
    "nullop",                   // 106
237
    "definevolumename",         // 107
238
    "defineskillname",          // 108
239
    "ifnosounds",               // 109
240
    "clipdist",                 // 110
241
    "ifangdiffl",               // 111
242
    "gamevar",                  // 112
243
    "ifvarl",                   // 113
244
    "ifvarg",                   // 114
245
    "setvarvar",                // 115
246
    "setvar",                   // 116
247
    "addvarvar",                // 117
248
    "addvar",                   // 118
249
    "ifvarvarl",                // 119
250
    "ifvarvarg",                // 120
251
    "addlogvar",                // 121
252
    "addlog",                   // 122
253
    "onevent",                  // 123
254
    "endevent",                 // 124
255
    "ifvare",                   // 125
256
    "ifvarvare",                // 126
257
    "spgetlotag",               // 127
258
    "spgethitag",               // 128
259
    "sectgetlotag",             // 129
260
    "sectgethitag",             // 130
261
    "ifsound",                  // 131
262
    "gettexturefloor",          // 132
263
    "gettextureceiling",        // 133
264
    "inittimer",                // 134
265
    "starttrack",               // 135
266
    "randvar",                  // 136
267
    "enhanced",                 // 137
268
    "getangletotarget",         // 138
269
    "getactorangle",            // 139
270
    "setactorangle",            // 140
271
    "mulvar",                   // 141
272
    "mulvarvar",                // 142
273
    "divvar",                   // 143
274
    "divvarvar",                // 144
275
    "modvar",                   // 145
276
    "modvarvar",                // 146
277
    "andvar",                   // 147
278
    "andvarvar",                // 148
279
    "orvar",                    // 149
280
    "orvarvar",                 // 150
281
    "getplayerangle",           // 151
282
    "setplayerangle",           // 152
283
    "lockplayer",               // 153
284
    "setsector",                // 154
285
    "getsector",                // 155
286
    "setactor",                 // 156
287
    "getactor",                 // 157
288
    "setwall",                  // 158
289
    "getwall",                  // 159
290
    "findnearactor",            // 160
291
    "findnearactorvar",         // 161
292
    "setactorvar",              // 162
293
    "getactorvar",              // 163
294
    "espawn",                   // 164
295
    "getplayer",                // 165
296
    "setplayer",                // 166
297
    "sqrt",                     // 167
298
    "eventloadactor",           // 168
299
    "espawnvar",                // 169
300
    "getuserdef",               // 170
301
    "setuserdef",               // 171
302
    "subvarvar",                // 172
303
    "subvar",                   // 173
304
    "ifvarn",                   // 174
305
    "ifvarvarn",                // 175
306
    "ifvarand",                 // 176
307
    "ifvarvarand",              // 177
308
    "myos",                     // 178
309
    "myospal",                  // 179
310
    "displayrand",              // 180
311
    "sin",                      // 181
312
    "xorvarvar",                // 182
313
    "xorvar",                   // 183
314
    "randvarvar",               // 184
315
    "myosx",                    // 185
316
    "myospalx",                 // 186
317
    "gmaxammo",                 // 187
318
    "smaxammo",                 // 188
319
    "startlevel",               // 189
320
    "eshoot",                   // 190
321
    "qspawn",                   // 191
322
    "rotatesprite",             // 192
323
    "defineprojectile",         // 193
324
    "spriteshadow",             // 194
325
    "cos",                      // 195
326
    "eshootvar",                // 196
327
    "findnearactor3d",          // 197
328
    "findnearactor3dvar",       // 198
329
    "flash",                    // 199
330
    "qspawnvar",                // 200
331
    "eqspawn",                  // 201
332
    "eqspawnvar",               // 202
333
    "minitext",                 // 203
334
    "gametext",                 // 204
335
    "digitalnumber",            // 205
336
    "addweaponvar",             // 206
337
    "setprojectile",            // 207
338
    "angoff",                   // 208
339
    "updatesector",             // 209
340
    "insertspriteq",            // 210
341
    "angoffvar",                // 211
342
    "whilevarn",                // 212
343
    "switch",                   // 213
344
    "case",                     // 214
345
    "default",                  // 215
346
    "endswitch",                // 216
347
    "shootvar",                 // 217
348
    "soundvar",                 // 218
349
    "findplayer",               // 219
350
    "findotherplayer",          // 220
351
    "activatebysector",         // 221 sectnum, spriteid
352
    "operatesectors",           // 222 sectnum, spriteid
353
    "operaterespawns",          // 223 lotag
354
    "operateactivators",        // 224 lotag, player index
355
    "operatemasterswitches",    // 225 lotag
356
    "checkactivatormotion",     // 226 lotag
357
    "zshoot",                   // 227 zvar projnum
358
    "dist",                     // 228 sprite1 sprite2
359
    "ldist",                    // 229 sprite1 sprite2
360
    "shiftvarl",                // 230
361
    "shiftvarr",                // 231
362
    "spritenvg",                // 232
363
    "getangle",                 // 233
364
    "whilevarvarn",             // 234
365
    "hitscan",                  // 235
366
    "time",                     // 236
367
    "getplayervar",             // 237
368
    "setplayervar",             // 238
369
    "mulscale",                 // 239
370
    "setaspect",                // 240
371
    "ezshoot",                  // 241
372
    "spritenoshade",            // 242
373
    "movesprite",               // 243
374
    "checkavailweapon",         // 244
375
    "soundoncevar",             // 245
376
    "updatesectorz",            // 246
377
    "stopallsounds",            // 247
378
    "ssp",                      // 248
379
    "stopsoundvar",             // 249
380
    "displayrandvar",           // 250
381
    "displayrandvarvar",        // 251
382
    "checkavailinven",          // 252
383
    "globalsoundvar",           // 253
384
    "guniqhudid",               // 254
385
    "getprojectile",            // 255
386
    "getthisprojectile",        // 256
387
    "setthisprojectile",        // 257
388
    "definecheat",              // 258
389
    "cheatkeys",                // 259
390
    "userquote",                // 260
391
    "precache",                 // 261
392
    "definegamefuncname",       // 262
393
    "redefinequote",            // 263
394
    "qsprintf",                 // 264
395
    "getpname",                 // 265
396
    "qstrcat",                  // 266
397
    "qstrcpy",                  // 267
398
    "setsprite",                // 268
399
    "rotatepoint",              // 269
400
    "dragpoint",                // 270
401
    "getzrange",                // 271
402
    "changespritestat",         // 272
403
    "getceilzofslope",          // 273
404
    "getflorzofslope",          // 274
405
    "neartag",                  // 275
406
    "definegametype",           // 276
407
    "changespritesect",         // 277
408
    "spriteflags",              // 278
409
    "savegamevar",              // 279
410
    "readgamevar",              // 280
411
    "findnearsprite",           // 281
412
    "findnearspritevar",        // 282
413
    "findnearsprite3d",         // 283
414
    "findnearsprite3dvar",      // 284
415
    "dynamicremap",             // 285
416
    "setinput",                 // 286
417
    "getinput",                 // 287
418
    "save",                                        // 288
419
    "cansee",                   // 289
420
    "canseespr",                // 290
421
    "findnearactorz",           // 291
422
    "findnearactorzvar",        // 292
423
    "findnearspritez",          // 293
424
    "findnearspritezvar",       // 294
425
    "zshootvar",                                   // 295
426
    "ezshootvar",                          // 296
427
    "getcurraddress",              // 297
428
    "jump",                                        // 298
429
    "qstrlen",                             // 299
430
    "getincangle",              // 300
431
    "quake",                    // 301
432
    "showview",                 // 302
433
    "headspritestat",           // 303
434
    "prevspritestat",           // 304
435
    "nextspritestat",           // 305
436
    "headspritesect",           // 306
437
    "prevspritesect",           // 307
438
    "nextspritesect",           // 308
582 terminx 439
    "spritenopal",              // 309
440
    "getkeyname",               // 310
559 terminx 441
    "<null>"
442
};
5 Plagman 443
 
484 terminx 444
LABELS sectorlabels[]=
559 terminx 445
{
446
    { "wallptr", SECTOR_WALLPTR, 0, 0 },
447
    { "wallnum", SECTOR_WALLNUM, 0, 0 },
448
    { "ceilingz", SECTOR_CEILINGZ, 0, 0 },
449
    { "floorz", SECTOR_FLOORZ, 0, 0 },
450
    { "ceilingstat", SECTOR_CEILINGSTAT, 0, 0 },
451
    { "floorstat", SECTOR_FLOORSTAT, 0, 0 },
452
    { "ceilingpicnum", SECTOR_CEILINGPICNUM, 0, 0 },
453
    { "ceilingslope", SECTOR_CEILINGSLOPE, 0, 0 },
454
    { "ceilingshade", SECTOR_CEILINGSHADE, 0, 0 },
455
    { "ceilingpal", SECTOR_CEILINGPAL, 0, 0 },
456
    { "ceilingxpanning", SECTOR_CEILINGXPANNING, 0, 0 },
457
    { "ceilingypanning", SECTOR_CEILINGYPANNING, 0, 0 },
458
    { "floorpicnum", SECTOR_FLOORPICNUM, 0, 0 },
459
    { "floorslope", SECTOR_FLOORSLOPE, 0, 0 },
460
    { "floorshade", SECTOR_FLOORSHADE, 0, 0 },
461
    { "floorpal", SECTOR_FLOORPAL, 0, 0 },
462
    { "floorxpanning", SECTOR_FLOORXPANNING, 0, 0 },
463
    { "floorypanning", SECTOR_FLOORYPANNING, 0, 0 },
464
    { "visibility", SECTOR_VISIBILITY, 0, 0 },
465
    { "alignto", SECTOR_ALIGNTO, 0, 0 },
466
    { "lotag", SECTOR_LOTAG, 0, 0 },
467
    { "hitag", SECTOR_HITAG, 0, 0 },
468
    { "extra", SECTOR_EXTRA, 0, 0 },
469
    { "", -1, 0, 0  }     // END OF LIST
470
};
5 Plagman 471
 
484 terminx 472
LABELS walllabels[]=
559 terminx 473
{
474
    { "x", WALL_X, 0, 0 },
475
    { "y", WALL_Y, 0, 0 },
476
    { "point2", WALL_POINT2, 0, 0 },
477
    { "nextwall", WALL_NEXTWALL, 0, 0 },
478
    { "nextsector", WALL_NEXTSECTOR, 0, 0 },
479
    { "cstat", WALL_CSTAT, 0, 0 },
480
    { "picnum", WALL_PICNUM, 0, 0 },
481
    { "overpicnum", WALL_OVERPICNUM, 0, 0 },
482
    { "shade", WALL_SHADE, 0, 0 },
483
    { "pal", WALL_PAL, 0, 0 },
484
    { "xrepeat", WALL_XREPEAT, 0, 0 },
485
    { "yrepeat", WALL_YREPEAT, 0, 0 },
486
    { "xpanning", WALL_XPANNING, 0, 0 },
487
    { "ypanning", WALL_YPANNING, 0, 0 },
488
    { "lotag", WALL_LOTAG, 0, 0 },
489
    { "hitag", WALL_HITAG, 0, 0 },
490
    { "extra", WALL_EXTRA, 0, 0 },
491
    { "", -1, 0, 0  }     // END OF LIST
492
};
5 Plagman 493
 
484 terminx 494
LABELS actorlabels[]=
559 terminx 495
{
496
    { "x", ACTOR_X, 0, 0 },
497
    { "y", ACTOR_Y, 0, 0 },
498
    { "z", ACTOR_Z, 0, 0 },
499
    { "cstat", ACTOR_CSTAT, 0, 0 },
500
    { "picnum", ACTOR_PICNUM, 0, 0 },
501
    { "shade", ACTOR_SHADE, 0, 0 },
502
    { "pal", ACTOR_PAL, 0, 0 },
503
    { "clipdist", ACTOR_CLIPDIST, 0, 0 },
504
    { "detail", ACTOR_DETAIL, 0, 0 },
505
    { "xrepeat", ACTOR_XREPEAT, 0, 0 },
506
    { "yrepeat", ACTOR_YREPEAT, 0, 0 },
507
    { "xoffset", ACTOR_XOFFSET, 0, 0 },
508
    { "yoffset", ACTOR_YOFFSET, 0, 0 },
509
    { "sectnum", ACTOR_SECTNUM, 0, 0 },
510
    { "statnum", ACTOR_STATNUM, 0, 0 },
511
    { "ang", ACTOR_ANG, 0, 0 },
512
    { "owner", ACTOR_OWNER, 0, 0 },
513
    { "xvel", ACTOR_XVEL, 0, 0 },
514
    { "yvel", ACTOR_YVEL, 0, 0 },
515
    { "zvel", ACTOR_ZVEL, 0, 0 },
516
    { "lotag", ACTOR_LOTAG, 0, 0 },
517
    { "hitag", ACTOR_HITAG, 0, 0 },
518
    { "extra", ACTOR_EXTRA, 0, 0 },
5 Plagman 519
 
559 terminx 520
    // hittype labels...
521
    { "htcgg", ACTOR_HTCGG, 0, 0 },
522
    { "htpicnum", ACTOR_HTPICNUM, 0, 0 },
523
    { "htang", ACTOR_HTANG, 0, 0 },
524
    { "htextra", ACTOR_HTEXTRA, 0, 0 },
525
    { "htowner", ACTOR_HTOWNER, 0, 0 },
526
    { "htmovflag", ACTOR_HTMOVFLAG, 0, 0 },
527
    { "httempang", ACTOR_HTTEMPANG, 0, 0 },
528
    { "htactorstayput", ACTOR_HTACTORSTAYPUT, 0, 0 },
529
    { "htdispicnum", ACTOR_HTDISPICNUM, 0, 0 },
530
    { "httimetosleep", ACTOR_HTTIMETOSLEEP, 0, 0 },
531
    { "htfloorz", ACTOR_HTFLOORZ, 0, 0 },
532
    { "htceilingz", ACTOR_HTCEILINGZ, 0, 0 },
533
    { "htlastvx", ACTOR_HTLASTVX, 0, 0 },
534
    { "htlastvy", ACTOR_HTLASTVY, 0, 0 },
535
    { "htbposx", ACTOR_HTBPOSX, 0, 0 },
536
    { "htbposy", ACTOR_HTBPOSY, 0, 0 },
537
    { "htbposz", ACTOR_HTBPOSZ, 0, 0 },
538
    { "htg_t", ACTOR_HTG_T, LABEL_HASPARM2, 8 },
5 Plagman 539
 
559 terminx 540
    // model flags
5 Plagman 541
 
559 terminx 542
    { "angoff", ACTOR_ANGOFF, 0, 0 },
543
    { "pitch", ACTOR_PITCH, 0, 0 },
544
    { "roll", ACTOR_ROLL, 0, 0 },
545
    { "mdxoff", ACTOR_MDXOFF, 0, 0 },
546
    { "mdyoff", ACTOR_MDYOFF, 0, 0 },
547
    { "mdzoff", ACTOR_MDZOFF, 0, 0 },
548
    { "mdflags", ACTOR_MDFLAGS, 0, 0 },
549
    { "", -1, 0, 0  }     // END OF LIST
550
};
5 Plagman 551
 
484 terminx 552
LABELS playerlabels[]=
559 terminx 553
{
554
    { "zoom", PLAYER_ZOOM, 0, 0 },
555
    { "exitx", PLAYER_EXITX, 0, 0 },
556
    { "exity", PLAYER_EXITY, 0, 0 },
557
    { "loogiex", PLAYER_LOOGIEX, LABEL_HASPARM2, 64 },
558
    { "loogiey", PLAYER_LOOGIEY, LABEL_HASPARM2, 64 },
559
    { "numloogs", PLAYER_NUMLOOGS, 0, 0 },
560
    { "loogcnt", PLAYER_LOOGCNT, 0, 0 },
561
    { "posx", PLAYER_POSX, 0, 0 },
562
    { "posy", PLAYER_POSY, 0, 0 },
563
    { "posz", PLAYER_POSZ, 0, 0 },
564
    { "horiz", PLAYER_HORIZ, 0, 0 },
565
    { "ohoriz", PLAYER_OHORIZ, 0, 0 },
566
    { "ohorizoff", PLAYER_OHORIZOFF, 0, 0 },
567
    { "invdisptime", PLAYER_INVDISPTIME, 0, 0 },
568
    { "bobposx", PLAYER_BOBPOSX, 0, 0 },
569
    { "bobposy", PLAYER_BOBPOSY, 0, 0 },
570
    { "oposx", PLAYER_OPOSX, 0, 0 },
571
    { "oposy", PLAYER_OPOSY, 0, 0 },
572
    { "oposz", PLAYER_OPOSZ, 0, 0 },
573
    { "pyoff", PLAYER_PYOFF, 0, 0 },
574
    { "opyoff", PLAYER_OPYOFF, 0, 0 },
575
    { "posxv", PLAYER_POSXV, 0, 0 },
576
    { "posyv", PLAYER_POSYV, 0, 0 },
577
    { "poszv", PLAYER_POSZV, 0, 0 },
578
    { "last_pissed_time", PLAYER_LAST_PISSED_TIME, 0, 0 },
579
    { "truefz", PLAYER_TRUEFZ, 0, 0 },
580
    { "truecz", PLAYER_TRUECZ, 0, 0 },
581
    { "player_par", PLAYER_PLAYER_PAR, 0, 0 },
582
    { "visibility", PLAYER_VISIBILITY, 0, 0 },
583
    { "bobcounter", PLAYER_BOBCOUNTER, 0, 0 },
584
    { "weapon_sway", PLAYER_WEAPON_SWAY, 0, 0 },
585
    { "pals_time", PLAYER_PALS_TIME, 0, 0 },
586
    { "randomflamex", PLAYER_RANDOMFLAMEX, 0, 0 },
587
    { "crack_time", PLAYER_CRACK_TIME, 0, 0 },
588
    { "aim_mode", PLAYER_AIM_MODE, 0, 0 },
589
    { "ang", PLAYER_ANG, 0, 0 },
590
    { "oang", PLAYER_OANG, 0, 0 },
591
    { "angvel", PLAYER_ANGVEL, 0, 0 },
592
    { "cursectnum", PLAYER_CURSECTNUM, 0, 0 },
593
    { "look_ang", PLAYER_LOOK_ANG, 0, 0 },
594
    { "last_extra", PLAYER_LAST_EXTRA, 0, 0 },
595
    { "subweapon", PLAYER_SUBWEAPON, 0, 0 },
596
    { "ammo_amount", PLAYER_AMMO_AMOUNT, LABEL_HASPARM2, MAX_WEAPONS },
597
    { "wackedbyactor", PLAYER_WACKEDBYACTOR, 0, 0 },
598
    { "frag", PLAYER_FRAG, 0, 0 },
599
    { "fraggedself", PLAYER_FRAGGEDSELF, 0, 0 },
600
    { "curr_weapon", PLAYER_CURR_WEAPON, 0, 0 },
601
    { "last_weapon", PLAYER_LAST_WEAPON, 0, 0 },
602
    { "tipincs", PLAYER_TIPINCS, 0, 0 },
603
    { "horizoff", PLAYER_HORIZOFF, 0, 0 },
604
    { "wantweaponfire", PLAYER_WANTWEAPONFIRE, 0, 0 },
605
    { "holoduke_amount", PLAYER_HOLODUKE_AMOUNT, 0, 0 },
606
    { "newowner", PLAYER_NEWOWNER, 0, 0 },
607
    { "hurt_delay", PLAYER_HURT_DELAY, 0, 0 },
608
    { "hbomb_hold_delay", PLAYER_HBOMB_HOLD_DELAY, 0, 0 },
609
    { "jumping_counter", PLAYER_JUMPING_COUNTER, 0, 0 },
610
    { "airleft", PLAYER_AIRLEFT, 0, 0 },
611
    { "knee_incs", PLAYER_KNEE_INCS, 0, 0 },
612
    { "access_incs", PLAYER_ACCESS_INCS, 0, 0 },
613
    { "fta", PLAYER_FTA, 0, 0 },
614
    { "ftq", PLAYER_FTQ, 0, 0 },
615
    { "access_wallnum", PLAYER_ACCESS_WALLNUM, 0, 0 },
616
    { "access_spritenum", PLAYER_ACCESS_SPRITENUM, 0, 0 },
617
    { "kickback_pic", PLAYER_KICKBACK_PIC, 0, 0 },
618
    { "got_access", PLAYER_GOT_ACCESS, 0, 0 },
619
    { "weapon_ang", PLAYER_WEAPON_ANG, 0, 0 },
620
    { "firstaid_amount", PLAYER_FIRSTAID_AMOUNT, 0, 0 },
621
    { "somethingonplayer", PLAYER_SOMETHINGONPLAYER, 0, 0 },
622
    { "on_crane", PLAYER_ON_CRANE, 0, 0 },
623
    { "i", PLAYER_I, 0, 0 },
624
    { "one_parallax_sectnum", PLAYER_ONE_PARALLAX_SECTNUM, 0, 0 },
625
    { "over_shoulder_on", PLAYER_OVER_SHOULDER_ON, 0, 0 },
626
    { "random_club_frame", PLAYER_RANDOM_CLUB_FRAME, 0, 0 },
627
    { "fist_incs", PLAYER_FIST_INCS, 0, 0 },
628
    { "one_eighty_count", PLAYER_ONE_EIGHTY_COUNT, 0, 0 },
629
    { "cheat_phase", PLAYER_CHEAT_PHASE, 0, 0 },
630
    { "dummyplayersprite", PLAYER_DUMMYPLAYERSPRITE, 0, 0 },
631
    { "extra_extra8", PLAYER_EXTRA_EXTRA8, 0, 0 },
632
    { "quick_kick", PLAYER_QUICK_KICK, 0, 0 },
633
    { "heat_amount", PLAYER_HEAT_AMOUNT, 0, 0 },
634
    { "actorsqu", PLAYER_ACTORSQU, 0, 0 },
635
    { "timebeforeexit", PLAYER_TIMEBEFOREEXIT, 0, 0 },
636
    { "customexitsound", PLAYER_CUSTOMEXITSOUND, 0, 0 },
637
    { "weaprecs[16]", PLAYER_WEAPRECS, 0, 0 },
638
    { "weapreccnt", PLAYER_WEAPRECCNT, 0, 0 },
639
    { "interface_toggle_flag", PLAYER_INTERFACE_TOGGLE_FLAG, 0, 0 },
640
    { "rotscrnang", PLAYER_ROTSCRNANG, 0, 0 },
641
    { "dead_flag", PLAYER_DEAD_FLAG, 0, 0 },
642
    { "show_empty_weapon", PLAYER_SHOW_EMPTY_WEAPON, 0, 0 },
643
    { "scuba_amount", PLAYER_SCUBA_AMOUNT, 0, 0 },
644
    { "jetpack_amount", PLAYER_JETPACK_AMOUNT, 0, 0 },
645
    { "steroids_amount", PLAYER_STEROIDS_AMOUNT, 0, 0 },
646
    { "shield_amount", PLAYER_SHIELD_AMOUNT, 0, 0 },
647
    { "holoduke_on", PLAYER_HOLODUKE_ON, 0, 0 },
648
    { "pycount", PLAYER_PYCOUNT, 0, 0 },
649
    { "weapon_pos", PLAYER_WEAPON_POS, 0, 0 },
650
    { "frag_ps", PLAYER_FRAG_PS, 0, 0 },
651
    { "transporter_hold", PLAYER_TRANSPORTER_HOLD, 0, 0 },
652
    { "last_full_weapon", PLAYER_LAST_FULL_WEAPON, 0, 0 },
653
    { "footprintshade", PLAYER_FOOTPRINTSHADE, 0, 0 },
654
    { "boot_amount", PLAYER_BOOT_AMOUNT, 0, 0 },
655
    { "scream_voice", PLAYER_SCREAM_VOICE, 0, 0 },
656
    { "gm", PLAYER_GM, 0, 0 },
657
    { "on_warping_sector", PLAYER_ON_WARPING_SECTOR, 0, 0 },
658
    { "footprintcount", PLAYER_FOOTPRINTCOUNT, 0, 0 },
659
    { "hbomb_on", PLAYER_HBOMB_ON, 0, 0 },
660
    { "jumping_toggle", PLAYER_JUMPING_TOGGLE, 0, 0 },
661
    { "rapid_fire_hold", PLAYER_RAPID_FIRE_HOLD, 0, 0 },
662
    { "on_ground", PLAYER_ON_GROUND, 0, 0 },
663
    { "name", PLAYER_NAME,  LABEL_ISSTRING, 32 },
664
    { "inven_icon", PLAYER_INVEN_ICON, 0, 0 },
665
    { "buttonpalette", PLAYER_BUTTONPALETTE, 0, 0 },
666
    { "jetpack_on", PLAYER_JETPACK_ON, 0, 0 },
667
    { "spritebridge", PLAYER_SPRITEBRIDGE, 0, 0 },
668
    { "lastrandomspot", PLAYER_LASTRANDOMSPOT, 0, 0 },
669
    { "scuba_on", PLAYER_SCUBA_ON, 0, 0 },
670
    { "footprintpal", PLAYER_FOOTPRINTPAL, 0, 0 },
671
    { "heat_on", PLAYER_HEAT_ON, 0, 0 },
672
    { "holster_weapon", PLAYER_HOLSTER_WEAPON, 0, 0 },
673
    { "falling_counter", PLAYER_FALLING_COUNTER, 0, 0 },
674
    { "gotweapon", PLAYER_GOTWEAPON, LABEL_HASPARM2, MAX_WEAPONS },
675
    { "refresh_inventory", PLAYER_REFRESH_INVENTORY, 0, 0 },
676
    { "palette", PLAYER_PALETTE, 0, 0 },
677
    { "toggle_key_flag", PLAYER_TOGGLE_KEY_FLAG, 0, 0 },
678
    { "knuckle_incs", PLAYER_KNUCKLE_INCS, 0, 0 },
679
    { "walking_snd_toggle", PLAYER_WALKING_SND_TOGGLE, 0, 0 },
680
    { "palookup", PLAYER_PALOOKUP, 0, 0 },
681
    { "hard_landing", PLAYER_HARD_LANDING, 0, 0 },
682
    { "max_secret_rooms", PLAYER_MAX_SECRET_ROOMS, 0, 0 },
683
    { "secret_rooms", PLAYER_SECRET_ROOMS, 0, 0 },
684
    { "pals", PLAYER_PALS, LABEL_HASPARM2, 2 },
685
    { "max_actors_killed", PLAYER_MAX_ACTORS_KILLED, 0, 0 },
686
    { "actors_killed", PLAYER_ACTORS_KILLED, 0, 0 },
687
    { "return_to_center", PLAYER_RETURN_TO_CENTER, 0, 0 },
688
    { "runspeed", PLAYER_RUNSPEED, 0, 0 },
689
    { "sbs", PLAYER_SBS, 0, 0 },
690
    { "reloading", PLAYER_RELOADING, 0, 0 },
691
    { "auto_aim", PLAYER_AUTO_AIM, 0, 0 },
692
    { "movement_lock", PLAYER_MOVEMENT_LOCK, 0, 0 },
693
    { "sound_pitch", PLAYER_SOUND_PITCH, 0, 0 },
694
    { "weaponswitch", PLAYER_WEAPONSWITCH, 0, 0 },
695
    { "team", PLAYER_TEAM, 0, 0 },
566 terminx 696
    { "max_player_health", PLAYER_MAX_PLAYER_HEALTH, 0, 0 },
697
    { "max_shield_amount", PLAYER_MAX_SHIELD_AMOUNT, 0, 0 },
698
    { "max_ammo_amount", PLAYER_MAX_AMMO_AMOUNT, LABEL_HASPARM2, MAX_WEAPONS },
559 terminx 699
    { "", -1, 0, 0  }     // END OF LIST
700
};
5 Plagman 701
 
484 terminx 702
LABELS projectilelabels[]=
559 terminx 703
{
704
    { "workslike", PROJ_WORKSLIKE, 0, 0 },
705
    { "spawns", PROJ_SPAWNS, 0, 0 },
706
    { "sxrepeat", PROJ_SXREPEAT, 0, 0 },
707
    { "syrepeat", PROJ_SYREPEAT, 0, 0 },
708
    { "sound", PROJ_SOUND, 0, 0 },
709
    { "isound", PROJ_ISOUND, 0, 0 },
710
    { "vel", PROJ_VEL, 0, 0 },
711
    { "extra", PROJ_EXTRA, 0, 0 },
712
    { "decal", PROJ_DECAL, 0, 0 },
713
    { "trail", PROJ_TRAIL, 0, 0 },
714
    { "txrepeat", PROJ_TXREPEAT, 0, 0 },
715
    { "tyrepeat", PROJ_TYREPEAT, 0, 0 },
716
    { "toffset", PROJ_TOFFSET, 0, 0 },
717
    { "tnum", PROJ_TNUM, 0, 0 },
718
    { "drop", PROJ_DROP, 0, 0 },
719
    { "cstat", PROJ_CSTAT, 0, 0 },
720
    { "clipdist", PROJ_CLIPDIST, 0, 0 },
721
    { "shade", PROJ_SHADE, 0, 0 },
722
    { "xrepeat", PROJ_XREPEAT, 0, 0 },
723
    { "yrepeat", PROJ_YREPEAT, 0, 0 },
724
    { "pal", PROJ_PAL, 0, 0 },
725
    { "extra_rand", PROJ_EXTRA_RAND, 0, 0 },
726
    { "hitradius", PROJ_HITRADIUS, 0, 0 },
727
    { "velmult", PROJ_VEL_MULT, 0, 0 },
728
    { "offset", PROJ_OFFSET, 0, 0 },
729
    { "bounces", PROJ_BOUNCES, 0, 0 },
730
    { "bsound", PROJ_BSOUND, 0, 0 },
731
    { "range", PROJ_RANGE, 0, 0 },
732
    { "", -1, 0, 0  }     // END OF LIST
733
};
5 Plagman 734
 
484 terminx 735
LABELS userdefslabels[]=
559 terminx 736
{
737
    //        { "<null>", 1, 0, 0 },
738
    { "god", USERDEFS_GOD, 0, 0 },
739
    { "warp_on", USERDEFS_WARP_ON, 0, 0 },
740
    { "cashman", USERDEFS_CASHMAN, 0, 0 },
741
    { "eog", USERDEFS_EOG, 0, 0 },
742
    { "showallmap", USERDEFS_SHOWALLMAP, 0, 0 },
743
    { "show_help", USERDEFS_SHOW_HELP, 0, 0 },
744
    { "scrollmode", USERDEFS_SCROLLMODE, 0, 0 },
745
    { "clipping", USERDEFS_CLIPPING, 0, 0 },
746
    { "user_name", USERDEFS_USER_NAME, LABEL_HASPARM2, MAXPLAYERS },
747
    { "ridecule", USERDEFS_RIDECULE, LABEL_HASPARM2 | LABEL_ISSTRING, 10 },
748
    { "savegame", USERDEFS_SAVEGAME, LABEL_HASPARM2 | LABEL_ISSTRING, 10 },
749
    { "pwlockout", USERDEFS_PWLOCKOUT, LABEL_ISSTRING, 128 },
750
    { "rtsname;", USERDEFS_RTSNAME,  LABEL_ISSTRING, 128 },
751
    { "overhead_on", USERDEFS_OVERHEAD_ON, 0, 0 },
752
    { "last_overhead", USERDEFS_LAST_OVERHEAD, 0, 0 },
753
    { "showweapons", USERDEFS_SHOWWEAPONS, 0, 0 },
5 Plagman 754
 
559 terminx 755
    { "pause_on", USERDEFS_PAUSE_ON, 0, 0 },
756
    { "from_bonus", USERDEFS_FROM_BONUS, 0, 0 },
757
    { "camerasprite", USERDEFS_CAMERASPRITE, 0, 0 },
758
    { "last_camsprite", USERDEFS_LAST_CAMSPRITE, 0, 0 },
759
    { "last_level", USERDEFS_LAST_LEVEL, 0, 0 },
760
    { "secretlevel", USERDEFS_SECRETLEVEL, 0, 0 },
5 Plagman 761
 
559 terminx 762
    { "const_visibility", USERDEFS_CONST_VISIBILITY, 0, 0 },
763
    { "uw_framerate", USERDEFS_UW_FRAMERATE, 0, 0 },
764
    { "camera_time", USERDEFS_CAMERA_TIME, 0, 0 },
765
    { "folfvel", USERDEFS_FOLFVEL, 0, 0 },
766
    { "folavel", USERDEFS_FOLAVEL, 0, 0 },
767
    { "folx", USERDEFS_FOLX, 0, 0 },
768
    { "foly", USERDEFS_FOLY, 0, 0 },
769
    { "fola", USERDEFS_FOLA, 0, 0 },
770
    { "reccnt", USERDEFS_RECCNT, 0, 0 },
5 Plagman 771
 
559 terminx 772
    { "entered_name", USERDEFS_ENTERED_NAME, 0, 0 },
773
    { "screen_tilting", USERDEFS_SCREEN_TILTING, 0, 0 },
774
    { "shadows", USERDEFS_SHADOWS, 0, 0 },
775
    { "fta_on", USERDEFS_FTA_ON, 0, 0 },
776
    { "executions", USERDEFS_EXECUTIONS, 0, 0 },
777
    { "auto_run", USERDEFS_AUTO_RUN, 0, 0 },
778
    { "coords", USERDEFS_COORDS, 0, 0 },
779
    { "tickrate", USERDEFS_TICKRATE, 0, 0 },
780
    { "m_coop", USERDEFS_M_COOP, 0, 0 },
781
    { "coop", USERDEFS_COOP, 0, 0 },
782
    { "screen_size", USERDEFS_SCREEN_SIZE, 0, 0 },
783
    { "lockout", USERDEFS_LOCKOUT, 0, 0 },
784
    { "crosshair", USERDEFS_CROSSHAIR, 0, 0 },
785
    { "wchoice[MAXPLAYERS][MAX_WEAPONS]", USERDEFS_WCHOICE, 0, 0 },
786
    { "playerai", USERDEFS_PLAYERAI, 0, 0 },
787
    { "respawn_monsters", USERDEFS_RESPAWN_MONSTERS, 0, 0 },
788
    { "respawn_items", USERDEFS_RESPAWN_ITEMS, 0, 0 },
789
    { "respawn_inventory", USERDEFS_RESPAWN_INVENTORY, 0, 0 },
790
    { "recstat", USERDEFS_RECSTAT, 0, 0 },
791
    { "monsters_off", USERDEFS_MONSTERS_OFF, 0, 0 },
792
    { "brightness", USERDEFS_BRIGHTNESS, 0, 0 },
793
    { "m_respawn_items", USERDEFS_M_RESPAWN_ITEMS, 0, 0 },
794
    { "m_respawn_monsters", USERDEFS_M_RESPAWN_MONSTERS, 0, 0 },
795
    { "m_respawn_inventory", USERDEFS_M_RESPAWN_INVENTORY, 0, 0 },
796
    { "m_recstat", USERDEFS_M_RECSTAT, 0, 0 },
797
    { "m_monsters_off", USERDEFS_M_MONSTERS_OFF, 0, 0 },
798
    { "detail", USERDEFS_DETAIL, 0, 0 },
799
    { "m_ffire", USERDEFS_M_FFIRE, 0, 0 },
800
    { "ffire", USERDEFS_FFIRE, 0, 0 },
801
    { "m_player_skill", USERDEFS_M_PLAYER_SKILL, 0, 0 },
802
    { "m_level_number", USERDEFS_M_LEVEL_NUMBER, 0, 0 },
803
    { "m_volume_number", USERDEFS_M_VOLUME_NUMBER, 0, 0 },
804
    { "multimode", USERDEFS_MULTIMODE, 0, 0 },
805
    { "player_skill", USERDEFS_PLAYER_SKILL, 0, 0 },
806
    { "level_number", USERDEFS_LEVEL_NUMBER, 0, 0 },
807
    { "volume_number", USERDEFS_VOLUME_NUMBER, 0, 0 },
808
    { "m_marker", USERDEFS_M_MARKER, 0, 0 },
809
    { "marker", USERDEFS_MARKER, 0, 0 },
810
    { "mouseflip", USERDEFS_MOUSEFLIP, 0, 0 },
811
    { "statusbarscale", USERDEFS_STATUSBARSCALE, 0, 0 },
812
    { "drawweapon", USERDEFS_DRAWWEAPON, 0, 0 },
813
    { "mouseaiming", USERDEFS_MOUSEAIMING, 0, 0 },
814
    { "weaponswitch", USERDEFS_WEAPONSWITCH, 0, 0 },
815
    { "democams", USERDEFS_DEMOCAMS, 0, 0 },
816
    { "color", USERDEFS_COLOR, 0, 0 },
817
    { "msgdisptime", USERDEFS_MSGDISPTIME, 0, 0 },
818
    { "statusbarmode", USERDEFS_STATUSBARMODE, 0, 0 },
819
    { "m_noexits", USERDEFS_M_NOEXITS, 0, 0 },
820
    { "noexits", USERDEFS_NOEXITS, 0, 0 },
821
    { "autovote", USERDEFS_AUTOVOTE, 0, 0 },
822
    { "automsg", USERDEFS_AUTOMSG, 0, 0 },
823
    { "idplayers", USERDEFS_IDPLAYERS, 0, 0 },
824
    { "team", USERDEFS_TEAM, 0, 0 },
825
    { "viewbob", USERDEFS_VIEWBOB, 0, 0 },
826
    { "weaponsway", USERDEFS_WEAPONSWAY, 0, 0 },
827
    { "angleinterpolation", USERDEFS_ANGLEINTERPOLATION, 0, 0 },
828
    { "deathmsgs", USERDEFS_DEATHMSGS, 0, 0 },
829
    { "", -1, 0, 0  }     // END OF LIST
830
};
5 Plagman 831
 
484 terminx 832
LABELS inputlabels[]=
559 terminx 833
{
834
    { "avel", INPUT_AVEL, 0, 0 },
835
    { "horz", INPUT_HORZ, 0, 0 },
836
    { "fvel", INPUT_FVEL, 0, 0 },
837
    { "svel", INPUT_SVEL, 0, 0 },
838
    { "bits", INPUT_BITS, 0, 0 },
839
    { "extbits", INPUT_EXTBITS, 0, 0 },
840
    { "", -1, 0, 0  }     // END OF LIST
841
};
5 Plagman 842
 
570 terminx 843
static int skipcomments(void)
5 Plagman 844
{
845
    char c;
570 terminx 846
    int i,j;
484 terminx 847
 
5 Plagman 848
    while ((c = *textptr))
849
    {
850
        if (c == ' ' || c == '\t' || c == '\r')
851
            textptr++;
335 terminx 852
        else if (c == '\n')
853
        {
5 Plagman 854
            line_number++;
855
            textptr++;
856
        }
857
        else if (c == '/' && textptr[1] == '/')
858
        {
564 terminx 859
            if (!(error || warning) && g_ScriptDebug > 1)
584 terminx 860
                initprintf("%s:%d: debug: got comment.\n",compilefile,line_number);
333 terminx 861
            while (*textptr != 0x0a && *textptr != 0x0d && *textptr != 0)
5 Plagman 862
                textptr++;
863
        }
864
        else if (c == '/' && textptr[1] == '*')
865
        {
564 terminx 866
            if (!(error || warning) && g_ScriptDebug > 1)
584 terminx 867
                initprintf("%s:%d: debug: got start of comment block.\n",compilefile,line_number);
5 Plagman 868
            while (*textptr && !(textptr[0] == '*' && textptr[1] == '/'))
869
            {
870
                if (*textptr == '\n')
871
                    line_number++;
872
                textptr++;
873
            }
564 terminx 874
            if ((!(error || warning) && g_ScriptDebug > 1) && (textptr[0] == '*' && textptr[1] == '/'))
584 terminx 875
                initprintf("%s:%d: debug: got end of comment block.\n",compilefile,line_number);
5 Plagman 876
            if (!*textptr)
877
            {
564 terminx 878
                if (!(error || warning) && g_ScriptDebug)
584 terminx 879
                    initprintf("%s:%d: debug: EOF in comment!\n",compilefile,line_number);
5 Plagman 880
                ReportError(-1);
584 terminx 881
                initprintf("%s:%d: error: found `/*' with no `*/'.\n",compilefile,line_number);
5 Plagman 882
                parsing_state = num_braces = 0;
883
                parsing_actor = 0;
884
                error++;
885
                break;
886
            }
887
            else textptr+=2;
888
        }
889
        else break;
890
    }
570 terminx 891
 
892
    if ((unsigned)(scriptptr-script) > (unsigned)(g_ScriptSize-32))
893
    {
584 terminx 894
        int oscriptptr = (unsigned)(scriptptr-script);
895
        int ocasescriptptr = (unsigned)(casescriptptr-script);
896
        int oparsing_event = (unsigned)(parsing_event-script);
897
        int oparsing_actor = (unsigned)(parsing_actor-script);
570 terminx 898
        char *scriptptrs;
584 terminx 899
        int *newscript;
570 terminx 900
 
901
        for (i=0;i<MAXSECTORS;i++)
902
        {
903
            if (labelcode[i] && labeltype[i] != LABEL_DEFINE)
904
            {
584 terminx 905
                labelcode[i] -= (int)&script[0];
570 terminx 906
            }
907
        }
908
 
909
        scriptptrs = Bcalloc(1,g_ScriptSize * sizeof(char));
910
        for (i=0;i<g_ScriptSize;i++)
911
        {
584 terminx 912
//            initprintf("%d\n",i);
913
            if ((int)script[i] >= (int)(&script[0]) && (int)script[i] < (int)(&script[g_ScriptSize]))
570 terminx 914
            {
915
                scriptptrs[i] = 1;
584 terminx 916
                j = (int)script[i] - (int)&script[0];
570 terminx 917
                script[i] = j;
918
            }
919
            else scriptptrs[i] = 0;
920
        }
921
 
922
        for (i=0;i<MAXTILES;i++)
923
            if (actorscrptr[i])
924
            {
584 terminx 925
                j = (int)actorscrptr[i]-(int)&script[0];
926
                actorscrptr[i] = (int *)j;
570 terminx 927
            }
928
 
929
        for (i=0;i<MAXTILES;i++)
930
            if (actorLoadEventScrptr[i])
931
            {
584 terminx 932
                j = (int)actorLoadEventScrptr[i]-(int)&script[0];
933
                actorLoadEventScrptr[i] = (int *)j;
570 terminx 934
            }
935
 
936
        for (i=0;i<MAXGAMEEVENTS;i++)
937
            if (apScriptGameEvent[i])
938
            {
584 terminx 939
                j = (int)apScriptGameEvent[i]-(int)&script[0];
940
                apScriptGameEvent[i] = (int *)j;
570 terminx 941
            }
942
 
584 terminx 943
        //initprintf("offset: %d\n",(unsigned)(scriptptr-script));
570 terminx 944
        g_ScriptSize += 16384;
584 terminx 945
        initprintf("Increasing script buffer size to %d bytes...\n",g_ScriptSize);
946
        newscript = (int *)Brealloc(script, g_ScriptSize * sizeof(int));
570 terminx 947
 
948
        if (newscript == NULL)
949
        {
950
            ReportError(-1);
584 terminx 951
            initprintf("%s:%d: out of memory: Aborted (%ud)\n",compilefile,line_number,(unsigned)(scriptptr-script));
570 terminx 952
            initprintf(tempbuf);
953
            error++;
954
            return 1;
955
        }
956
        script = newscript;
584 terminx 957
        scriptptr = (int *)(script+oscriptptr);
958
        //initprintf("offset: %d\n",(unsigned)(scriptptr-script));
570 terminx 959
        if (casescriptptr != NULL)
584 terminx 960
            casescriptptr = (int *)(script+ocasescriptptr);
570 terminx 961
        if (parsing_event != NULL)
584 terminx 962
            parsing_event = (int *)(script+oparsing_event);
570 terminx 963
        if (parsing_actor != NULL)
584 terminx 964
            parsing_actor = (int *)(script+oparsing_actor);
570 terminx 965
 
966
        for (i=0;i<MAXSECTORS;i++)
967
        {
968
            if (labelcode[i] && labeltype[i] != LABEL_DEFINE)
969
            {
584 terminx 970
                labelcode[i] += (int)&script[0];
570 terminx 971
            }
972
        }
973
 
974
        for (i=0;i<g_ScriptSize-16384;i++)
975
            if (scriptptrs[i])
976
            {
584 terminx 977
                j = (int)script[i]+(int)&script[0];
570 terminx 978
                script[i] = j;
979
            }
980
 
981
        for (i=0;i<MAXTILES;i++)
982
            if (actorscrptr[i])
983
            {
584 terminx 984
                j = (int)actorscrptr[i]+(int)&script[0];
985
                actorscrptr[i] = (int *)j;
570 terminx 986
            }
987
 
988
        for (i=0;i<MAXTILES;i++)
989
            if (actorLoadEventScrptr[i])
990
            {
584 terminx 991
                j = (int)actorLoadEventScrptr[i]+(int)&script[0];
992
                actorLoadEventScrptr[i] = (int *)j;
570 terminx 993
            }
994
 
995
        for (i=0;i<MAXGAMEEVENTS;i++)
996
            if (apScriptGameEvent[i])
997
            {
584 terminx 998
                j = (int)apScriptGameEvent[i]+(int)&script[0];
999
                apScriptGameEvent[i] = (int *)j;
570 terminx 1000
            }
1001
        Bfree(scriptptrs);
1002
    }
1003
 
1004
    return 0;
5 Plagman 1005
}
1006
 
584 terminx 1007
static void DefineProjectile(int lVar1, int lLabelID, int lVar2)
5 Plagman 1008
{
331 terminx 1009
    switch (lLabelID)
5 Plagman 1010
    {
337 terminx 1011
    case PROJ_WORKSLIKE:
1012
        projectile[lVar1].workslike=lVar2;
1013
        break;
5 Plagman 1014
 
337 terminx 1015
    case PROJ_SPAWNS:
1016
        projectile[lVar1].spawns=lVar2;
1017
        break;
5 Plagman 1018
 
337 terminx 1019
    case PROJ_SXREPEAT:
1020
        projectile[lVar1].sxrepeat=lVar2;
1021
        break;
5 Plagman 1022
 
337 terminx 1023
    case PROJ_SYREPEAT:
1024
        projectile[lVar1].syrepeat=lVar2;
1025
        break;
5 Plagman 1026
 
337 terminx 1027
    case PROJ_SOUND:
1028
        projectile[lVar1].sound=lVar2;
1029
        break;
5 Plagman 1030
 
337 terminx 1031
    case PROJ_ISOUND:
1032
        projectile[lVar1].isound=lVar2;
1033
        break;
5 Plagman 1034
 
337 terminx 1035
    case PROJ_VEL:
1036
        projectile[lVar1].vel=lVar2;
1037
        break;
5 Plagman 1038
 
337 terminx 1039
    case PROJ_EXTRA:
1040
        projectile[lVar1].extra=lVar2;
1041
        break;
5 Plagman 1042
 
337 terminx 1043
    case PROJ_DECAL:
1044
        projectile[lVar1].decal=lVar2;
1045
        break;
5 Plagman 1046
 
337 terminx 1047
    case PROJ_TRAIL:
1048
        projectile[lVar1].trail=lVar2;
1049
        break;
5 Plagman 1050
 
337 terminx 1051
    case PROJ_TXREPEAT:
1052
        projectile[lVar1].txrepeat=lVar2;
1053
        break;
5 Plagman 1054
 
337 terminx 1055
    case PROJ_TYREPEAT:
1056
        projectile[lVar1].tyrepeat=lVar2;
1057
        break;
5 Plagman 1058
 
337 terminx 1059
    case PROJ_TOFFSET:
1060
        projectile[lVar1].toffset=lVar2;
1061
        break;
5 Plagman 1062
 
337 terminx 1063
    case PROJ_TNUM:
1064
        projectile[lVar1].tnum=lVar2;
1065
        break;
5 Plagman 1066
 
337 terminx 1067
    case PROJ_DROP:
1068
        projectile[lVar1].drop=lVar2;
1069
        break;
5 Plagman 1070
 
337 terminx 1071
    case PROJ_CSTAT:
1072
        projectile[lVar1].cstat=lVar2;
1073
        break;
5 Plagman 1074
 
337 terminx 1075
    case PROJ_CLIPDIST:
1076
        projectile[lVar1].clipdist=lVar2;
1077
        break;
5 Plagman 1078
 
337 terminx 1079
    case PROJ_SHADE:
1080
        projectile[lVar1].shade=lVar2;
1081
        break;
5 Plagman 1082
 
337 terminx 1083
    case PROJ_XREPEAT:
1084
        projectile[lVar1].xrepeat=lVar2;
1085
        break;
5 Plagman 1086
 
337 terminx 1087
    case PROJ_YREPEAT:
1088
        projectile[lVar1].yrepeat=lVar2;
1089
        break;
5 Plagman 1090
 
337 terminx 1091
    case PROJ_PAL:
1092
        projectile[lVar1].pal=lVar2;
1093
        break;
5 Plagman 1094
 
337 terminx 1095
    case PROJ_EXTRA_RAND:
1096
        projectile[lVar1].extra_rand=lVar2;
1097
        break;
5 Plagman 1098
 
337 terminx 1099
    case PROJ_HITRADIUS:
1100
        projectile[lVar1].hitradius=lVar2;
1101
        break;
5 Plagman 1102
 
337 terminx 1103
    case PROJ_VEL_MULT:
1104
        projectile[lVar1].velmult=lVar2;
1105
        break;
5 Plagman 1106
 
337 terminx 1107
    case PROJ_OFFSET:
1108
        projectile[lVar1].offset=lVar2;
1109
        break;
5 Plagman 1110
 
337 terminx 1111
    case PROJ_BOUNCES:
1112
        projectile[lVar1].bounces=lVar2;
1113
        break;
5 Plagman 1114
 
337 terminx 1115
    case PROJ_BSOUND:
1116
        projectile[lVar1].bsound=lVar2;
1117
        break;
5 Plagman 1118
 
337 terminx 1119
    case PROJ_RANGE:
1120
        projectile[lVar1].range=lVar2;
1121
        break;
5 Plagman 1122
 
337 terminx 1123
    default:
1124
        break;
5 Plagman 1125
    }
1126
 
1127
    //  defaultprojectile[lVar1] = projectile[lVar1];
1128
    Bmemcpy(&defaultprojectile[lVar1], &projectile[lVar1], sizeof(projectile[lVar1]));
1129
 
1130
    return;
1131
}
1132
 
546 terminx 1133
static int CheckEventSync(int iEventID)
5 Plagman 1134
{
331 terminx 1135
    if (parsing_event || parsing_actor)
5 Plagman 1136
    {
331 terminx 1137
        switch (iEventID)
5 Plagman 1138
        {
337 terminx 1139
        case EVENT_CHEATGETSTEROIDS:
1140
        case EVENT_CHEATGETHEAT:
1141
        case EVENT_CHEATGETBOOT:
1142
        case EVENT_CHEATGETSHIELD:
1143
        case EVENT_CHEATGETSCUBA:
1144
        case EVENT_CHEATGETHOLODUKE:
1145
        case EVENT_CHEATGETJETPACK:
1146
        case EVENT_CHEATGETFIRSTAID:
1147
        case EVENT_DISPLAYCROSSHAIR:
1148
        case EVENT_DISPLAYREST:
487 terminx 1149
        case EVENT_DISPLAYROOMS:
492 terminx 1150
        case EVENT_DISPLAYSBAR:
491 terminx 1151
        case EVENT_DISPLAYWEAPON:
1152
        case EVENT_DRAWWEAPON:
337 terminx 1153
        case EVENT_ENTERLEVEL:
1154
        case EVENT_FAKEDOMOVETHINGS:
1155
        case EVENT_GETLOADTILE:
1156
        case EVENT_GETMENUTILE:
1157
        case EVENT_INIT:
1158
        case EVENT_LOGO:
1159
            return 0;
1160
        default:
1161
            return 1;
5 Plagman 1162
        }
1163
    }
1164
    return 1;
1165
}
1166
 
484 terminx 1167
#if 0
1168
void AddLog(const char *psz, ...)
5 Plagman 1169
{
484 terminx 1170
    va_list va;
1171
 
1172
    va_start(va, psz);
1173
    Bvsnprintf(tempbuf, sizeof(tempbuf), psz, va);
1174
    va_end(va);
1175
 
1176
    if (tempbuf[Bstrlen(tempbuf)] != '\n')
5 Plagman 1177
        Bstrcat(tempbuf,"\n");
1178
    if (qsetmode == 200) OSD_Printf(tempbuf);
1179
    else initprintf(tempbuf);
1180
}
484 terminx 1181
#endif
5 Plagman 1182
 
584 terminx 1183
static int GetDefID(const char *szGameLabel)
5 Plagman 1184
{
1185
    int i;
331 terminx 1186
    for (i=0;i<iGameVarCount;i++)
5 Plagman 1187
    {
331 terminx 1188
        if (aGameVars[i].szLabel != NULL)
5 Plagman 1189
        {
333 terminx 1190
            if (Bstrcmp(szGameLabel, aGameVars[i].szLabel) == 0)
102 terminx 1191
            {
1192
                return i;
1193
            }
5 Plagman 1194
        }
1195
    }
1196
    return -1;
1197
}
1198
 
437 terminx 1199
static int ispecial(char c)
5 Plagman 1200
{
331 terminx 1201
    if (c == 0x0a)
5 Plagman 1202
    {
1203
        line_number++;
1204
        return 1;
1205
    }
1206
 
331 terminx 1207
    if (c == ' ' || c == 0x0d)
5 Plagman 1208
        return 1;
1209
 
1210
    return 0;
1211
}
1212
 
398 terminx 1213
static inline int isaltok(char c)
5 Plagman 1214
{
333 terminx 1215
    return (isalnum(c) || c == '{' || c == '}' || c == '/' || c == '*' || c == '-' || c == '_' || c == '.');
5 Plagman 1216
}
1217
 
584 terminx 1218
static int getlabelid(LABELS *pLabel, const char *psz)
5 Plagman 1219
{
1220
    // find the label psz in the table pLabel.
1221
    // returns the ID for the label, or -1
1222
 
584 terminx 1223
    int l=-1;
5 Plagman 1224
    int i;
1225
 
331 terminx 1226
    for (i=0;pLabel[i].lId >=0 ; i++)
5 Plagman 1227
    {
331 terminx 1228
        if (!Bstrcasecmp(pLabel[i].name,psz))
5 Plagman 1229
        {
1230
            l= pLabel[i].lId;
1231
            break;  // stop for loop
1232
        }
1233
    }
1234
    return l;
1235
}
1236
 
584 terminx 1237
static int getlabeloffset(LABELS *pLabel, const char *psz)
5 Plagman 1238
{
1239
    // find the label psz in the table pLabel.
1240
    // returns the offset in the array for the label, or -1
1241
    int i;
1242
 
331 terminx 1243
    for (i=0;pLabel[i].lId >=0 ; i++)
5 Plagman 1244
    {
331 terminx 1245
        if (!Bstrcasecmp(pLabel[i].name,psz))
5 Plagman 1246
        {
1247
            //    printf("Label has flags of %02X\n",pLabel[i].flags);
1248
            return i;
1249
        }
1250
    }
1251
    return -1;
1252
}
1253
 
398 terminx 1254
static void getlabel(void)
5 Plagman 1255
{
584 terminx 1256
    int i;
5 Plagman 1257
 
1258
    skipcomments();
1259
 
333 terminx 1260
    while (isalnum(*textptr) == 0)
5 Plagman 1261
    {
331 terminx 1262
        if (*textptr == 0x0a) line_number++;
5 Plagman 1263
        textptr++;
333 terminx 1264
        if (*textptr == 0)
5 Plagman 1265
            return;
1266
    }
1267
 
1268
    i = 0;
333 terminx 1269
    while (ispecial(*textptr) == 0 && *textptr!=']' && *textptr!='\t' && *textptr!='\n' && *textptr!='\r')
5 Plagman 1270
        label[(labelcnt<<6)+i++] = *(textptr++);
1271
 
1272
    label[(labelcnt<<6)+i] = 0;
564 terminx 1273
    if (!(error || warning) && g_ScriptDebug > 1)
584 terminx 1274
        initprintf("%s:%d: debug: got label `%s'.\n",compilefile,line_number,label+(labelcnt<<6));
5 Plagman 1275
}
1276
 
584 terminx 1277
static int keyword(void)
5 Plagman 1278
{
584 terminx 1279
    int i;
5 Plagman 1280
    char *temptextptr;
1281
 
1282
    skipcomments();
1283
 
1284
    temptextptr = textptr;
1285
 
333 terminx 1286
    while (isaltok(*temptextptr) == 0)
5 Plagman 1287
    {
1288
        temptextptr++;
333 terminx 1289
        if (*temptextptr == 0)
5 Plagman 1290
            return 0;
1291
    }
1292
 
1293
    i = 0;
333 terminx 1294
    while (isaltok(*temptextptr))
5 Plagman 1295
    {
1296
        tempbuf[i] = *(temptextptr++);
1297
        i++;
1298
    }
1299
    tempbuf[i] = 0;
331 terminx 1300
    for (i=0;i<NUMKEYWORDS;i++)
333 terminx 1301
        if (Bstrcmp(tempbuf,keyw[i]) == 0)
5 Plagman 1302
            return i;
1303
 
1304
    return -1;
1305
}
1306
 
584 terminx 1307
static int transword(void) //Returns its code #
5 Plagman 1308
{
584 terminx 1309
    int i, l;
5 Plagman 1310
 
1311
    skipcomments();
1312
 
333 terminx 1313
    while (isaltok(*textptr) == 0)
5 Plagman 1314
    {
331 terminx 1315
        if (*textptr == 0x0a) line_number++;
333 terminx 1316
        if (*textptr == 0)
5 Plagman 1317
            return -1;
1318
        textptr++;
1319
    }
1320
 
1321
    l = 0;
333 terminx 1322
    while (isaltok(*(textptr+l)) && !(*(textptr + l) == '.'))
5 Plagman 1323
    {
1324
        tempbuf[l] = textptr[l];
1325
        l++;
1326
    }
333 terminx 1327
    while (isaltok(*(textptr+l)))
5 Plagman 1328
    {
1329
        tempbuf[l] = textptr[l];
1330
        l++;
1331
    }
1332
    tempbuf[l] = 0;
1333
 
331 terminx 1334
    for (i=0;i<NUMKEYWORDS;i++)
5 Plagman 1335
    {
333 terminx 1336
        if (Bstrcmp(tempbuf,keyw[i]) == 0)
5 Plagman 1337
        {
1338
            *scriptptr = i;
1339
            textptr += l;
1340
            scriptptr++;
564 terminx 1341
            if (!(error || warning) && g_ScriptDebug)
584 terminx 1342
                initprintf("%s:%d: debug: translating keyword `%s'.\n",compilefile,line_number,keyw[i]);
5 Plagman 1343
            return i;
1344
        }
1345
    }
1346
 
1347
    textptr += l;
1348
 
333 terminx 1349
    if (tempbuf[0] == '{' && tempbuf[1] != 0)
5 Plagman 1350
    {
1351
        ReportError(-1);
584 terminx 1352
        initprintf("%s:%d: error: expected a SPACE or CR between `{' and `%s'.\n",compilefile,line_number,tempbuf+1);
5 Plagman 1353
    }
333 terminx 1354
    else if (tempbuf[0] == '}' && tempbuf[1] != 0)
5 Plagman 1355
    {
1356
        ReportError(-1);
584 terminx 1357
        initprintf("%s:%d: error: expected a SPACE or CR between `}' and `%s'.\n",compilefile,line_number,tempbuf+1);
5 Plagman 1358
    }
1359
    else ReportError(ERROR_EXPECTEDKEYWORD);
1360
    error++;
1361
    return -1;
1362
}
1363
 
398 terminx 1364
static void transvartype(int type)
5 Plagman 1365
{
91 terminx 1366
    int i=0,f=0;
5 Plagman 1367
 
1368
    skipcomments();
331 terminx 1369
    if (!type && !labelsonly && (isdigit(*textptr) || ((*textptr == '-') && (isdigit(*(textptr+1))))))
5 Plagman 1370
    {
564 terminx 1371
        if (!(error || warning) && g_ScriptDebug)
584 terminx 1372
            initprintf("%s:%d: debug: accepted constant %d in place of gamevar.\n",compilefile,line_number,atol(textptr));
5 Plagman 1373
        *scriptptr++=MAXGAMEVARS;
1374
        *scriptptr++=atol(textptr);
1375
        getlabel();
1376
        return;
1377
    }
331 terminx 1378
    else if ((*textptr == '-') && !isdigit(*(textptr+1)))
5 Plagman 1379
    {
331 terminx 1380
        if (!type)
5 Plagman 1381
        {
564 terminx 1382
            if (!(error || warning) && g_ScriptDebug)
584 terminx 1383
                initprintf("%s:%d: debug: flagging gamevar as negative.\n",compilefile,line_number,atol(textptr));
5 Plagman 1384
            f = (MAXGAMEVARS<<1);
1385
        }
1386
        else
1387
        {
1388
            error++;
1389
            ReportError(ERROR_SYNTAXERROR);
1390
            getlabel();
1391
            return;
1392
        }
1393
    }
1394
    getlabel();
331 terminx 1395
    if (!nokeywordcheck)
1396
        for (i=0;i<NUMKEYWORDS;i++)
333 terminx 1397
            if (Bstrcmp(label+(labelcnt<<6),keyw[i]) == 0)
5 Plagman 1398
            {
1399
                error++;
1400
                ReportError(ERROR_ISAKEYWORD);
1401
                return;
1402
            }
1403
    i=GetDefID(label+(labelcnt<<6));
331 terminx 1404
    if (i<0)
5 Plagman 1405
    {
331 terminx 1406
        if (!type && !labelsonly)
5 Plagman 1407
        {
1408
            Bstrcpy(tempbuf,label+(labelcnt<<6));
331 terminx 1409
            for (i=0;i<labelcnt;i++)
5 Plagman 1410
            {
333 terminx 1411
                if (Bstrcmp(tempbuf,label+(i<<6)) == 0 && (labeltype[i] & LABEL_DEFINE))
5 Plagman 1412
                {
564 terminx 1413
                    if (!(error || warning) && g_ScriptDebug)
584 terminx 1414
                        initprintf("%s:%d: debug: accepted defined label `%s' instead of gamevar.\n",compilefile,line_number,label+(i<<6));
5 Plagman 1415
                    *scriptptr++=MAXGAMEVARS;
1416
                    *scriptptr++=labelcode[i];
1417
                    textptr++;
1418
                    return;
1419
                }
1420
            }
1421
            error++;
1422
            ReportError(ERROR_NOTAGAMEVAR);
1423
            textptr++;
1424
            return;
1425
        }
437 terminx 1426
        error++;
1427
        ReportError(ERROR_NOTAGAMEVAR);
1428
        textptr++;
1429
        return;
5 Plagman 1430
    }
331 terminx 1431
    if (type == GAMEVAR_FLAG_READONLY && aGameVars[i].dwFlags & GAMEVAR_FLAG_READONLY)
5 Plagman 1432
    {
1433
        error++;
1434
        ReportError(ERROR_VARREADONLY);
1435
        return;
1436
    }
331 terminx 1437
    else if (aGameVars[i].dwFlags & type)
5 Plagman 1438
    {
1439
        error++;
1440
        ReportError(ERROR_VARTYPEMISMATCH);
1441
        return;
1442
    }
331 terminx 1443
    if ((aGameVars[i].dwFlags & GAMEVAR_FLAG_SYNCCHECK) && parsing_actor && CheckEventSync(current_event))
5 Plagman 1444
    {
1445
        ReportError(-1);
584 terminx 1446
        initprintf("%s:%d: warning: found local gamevar `%s' used within %s; expect multiplayer synchronization issues.\n",compilefile,line_number,label+(labelcnt<<6),parsing_event?"a synced event":"an actor");
5 Plagman 1447
    }
564 terminx 1448
    if (!(error || warning) && g_ScriptDebug > 1)
584 terminx 1449
        initprintf("%s:%d: debug: accepted gamevar `%s'.\n",compilefile,line_number,label+(labelcnt<<6));
5 Plagman 1450
    i |= f;
1451
    *scriptptr++=i;
1452
}
1453
 
296 terminx 1454
static inline void transvar(void)
5 Plagman 1455
{
1456
    transvartype(0);
1457
}
1458
 
437 terminx 1459
static inline void transmultvarstype(int type, int num)
5 Plagman 1460
{
437 terminx 1461
    int i;
331 terminx 1462
    for (i=0;i<num;i++)
5 Plagman 1463
        transvartype(type);
1464
}
1465
 
437 terminx 1466
static inline void transmultvars(int num)
5 Plagman 1467
{
1468
    transmultvarstype(0,num);
1469
}
1470
 
584 terminx 1471
static int transnum(int type)
5 Plagman 1472
{
584 terminx 1473
    int i, l;
5 Plagman 1474
 
1475
    skipcomments();
1476
 
333 terminx 1477
    while (isaltok(*textptr) == 0)
5 Plagman 1478
    {
331 terminx 1479
        if (*textptr == 0x0a) line_number++;
5 Plagman 1480
        textptr++;
333 terminx 1481
        if (*textptr == 0)
5 Plagman 1482
            return -1; // eof
1483
    }
1484
 
1485
    l = 0;
333 terminx 1486
    while (isaltok(*(textptr+l)))
5 Plagman 1487
    {
1488
        tempbuf[l] = textptr[l];
1489
        l++;
1490
    }
1491
    tempbuf[l] = 0;
1492
 
331 terminx 1493
    if (!nokeywordcheck)
1494
        for (i=0;i<NUMKEYWORDS;i++)
333 terminx 1495
            if (Bstrcmp(label+(labelcnt<<6),keyw[i]) == 0)
5 Plagman 1496
            {
1497
                error++;
1498
                ReportError(ERROR_ISAKEYWORD);
1499
                textptr+=l;
1500
            }
121 terminx 1501
 
331 terminx 1502
    for (i=0;i<labelcnt;i++)
5 Plagman 1503
    {
333 terminx 1504
        if (!Bstrcmp(tempbuf,label+(i<<6)))
5 Plagman 1505
        {
1506
            char *el,*gl;
1507
 
1508
            if (labeltype[i] & type)
1509
            {
564 terminx 1510
                if (!(error || warning) && g_ScriptDebug > 1)
5 Plagman 1511
                {
437 terminx 1512
                    gl = (char *)translatelabeltype(labeltype[i]);
584 terminx 1513
                    initprintf("%s:%d: debug: accepted %s label `%s'.\n",compilefile,line_number,gl,label+(i<<6));
5 Plagman 1514
                    Bfree(gl);
1515
                }
1516
                *(scriptptr++) = labelcode[i];
1517
                textptr += l;
1518
                return labeltype[i];
1519
            }
1520
            *(scriptptr++) = 0;
1521
            textptr += l;
437 terminx 1522
            el = (char *)translatelabeltype(type);
1523
            gl = (char *)translatelabeltype(labeltype[i]);
5 Plagman 1524
            ReportError(-1);
584 terminx 1525
            initprintf("%s:%d: warning: expected a %s, found a %s.\n",compilefile,line_number,el,gl);
5 Plagman 1526
            Bfree(el);
1527
            Bfree(gl);
1528
            return -1;  // valid label name, but wrong type
1529
        }
1530
    }
1531
 
333 terminx 1532
    if (isdigit(*textptr) == 0 && *textptr != '-')
5 Plagman 1533
    {
1534
        ReportError(ERROR_PARAMUNDEFINED);
1535
        error++;
1536
        textptr+=l;
1537
        return -1; // error!
1538
    }
1539
 
333 terminx 1540
    if (isdigit(*textptr) && labelsonly)
5 Plagman 1541
    {
1542
        ReportError(WARNING_LABELSONLY);
1543
        //         warning++;
1544
    }
564 terminx 1545
    if (!(error || warning) && g_ScriptDebug > 1)
584 terminx 1546
        initprintf("%s:%d: debug: accepted constant %d.\n",compilefile,line_number,atol(textptr));
5 Plagman 1547
    *scriptptr = atol(textptr);
1548
    scriptptr++;
1549
 
1550
    textptr += l;
1551
 
1552
    return 0;   // literal value
1553
}
1554
 
437 terminx 1555
static int parsecommand(void);
398 terminx 1556
 
584 terminx 1557
static int CountCaseStatements()
5 Plagman 1558
{
584 terminx 1559
    int lCount;
437 terminx 1560
    char *temptextptr = textptr;
1561
    int temp_line_number = line_number;
584 terminx 1562
    int scriptoffset = (unsigned)(scriptptr-script);
1563
    int caseoffset = (unsigned)(casescriptptr-script);
570 terminx 1564
    int i;
5 Plagman 1565
 
1566
    casecount=0;
1567
    casescriptptr=NULL;
1568
    //Bsprintf(g_szBuf,"CSS: %.12s",textptr);
1569
    //AddLog(g_szBuf);
331 terminx 1570
    while (parsecommand() == 0)
5 Plagman 1571
    {
1572
        //Bsprintf(g_szBuf,"CSSL: %.20s",textptr);
1573
        //AddLog(g_szBuf);
1574
        ;
1575
    }
1576
    // since we processed the endswitch, we need to re-increment checking_switch
1577
    checking_switch++;
1578
 
1579
    textptr=temptextptr;
584 terminx 1580
    scriptptr = (int *)(script+scriptoffset);
5 Plagman 1581
 
1582
    line_number = temp_line_number;
1583
 
1584
    lCount=casecount;
1585
    casecount=0;
584 terminx 1586
    casescriptptr = (int *)(script+caseoffset);
570 terminx 1587
    casecount = 0;
5 Plagman 1588
    return lCount;
1589
}
1590
 
437 terminx 1591
static int parsecommand(void)
5 Plagman 1592
{
584 terminx 1593
    int i, j=0, k=0, done, tw;
437 terminx 1594
    char *temptextptr;
584 terminx 1595
    int *tempscrptr;
5 Plagman 1596
 
569 terminx 1597
    if (quitevent)
1598
    {
1599
        initprintf("Aborted.\n");
1600
        Shutdown();
1601
        exit(0);
1602
    }
1603
 
333 terminx 1604
    if ((error+warning) > 63 || (*textptr == '\0') || (*(textptr+1) == '\0')) return 1;
5 Plagman 1605
 
564 terminx 1606
    if (g_ScriptDebug)
296 terminx 1607
        ReportError(-1);
1608
 
333 terminx 1609
    if (checking_switch > 0)
5 Plagman 1610
    {
1611
        //Bsprintf(g_szBuf,"PC(): '%.25s'",textptr);
1612
        //AddLog(g_szBuf);
1613
    }
1614
    tw = transword();
1615
    //    Bsprintf(tempbuf,"%s",keyw[tw]);
1616
    //    AddLog(tempbuf);
1617
 
570 terminx 1618
    if (skipcomments())
1619
        return 1;
5 Plagman 1620
 
331 terminx 1621
    switch (tw)
5 Plagman 1622
    {
337 terminx 1623
    default:
1624
    case -1:
1625
        return 0; //End
1626
    case CON_STATE:
1627
        if (parsing_actor == 0 && parsing_state == 0)
1628
        {
1629
            getlabel();
1630
            scriptptr--;
584 terminx 1631
            labelcode[labelcnt] = (int) scriptptr;
337 terminx 1632
            labeltype[labelcnt] = LABEL_STATE;
1633
 
1634
            parsing_state = 1;
1635
            Bsprintf(parsing_item_name,"%s",label+(labelcnt<<6));
1636
            labelcnt++;
1637
            return 0;
1638
        }
1639
 
1640
        getlabel();
1641
 
1642
        for (i=0;i<NUMKEYWORDS;i++)
1643
            if (Bstrcmp(label+(labelcnt<<6),keyw[i]) == 0)
335 terminx 1644
            {
337 terminx 1645
                error++;
1646
                ReportError(ERROR_ISAKEYWORD);
335 terminx 1647
                return 0;
1648
            }
337 terminx 1649
        for (j=0;j<labelcnt;j++)
1650
        {
1651
            if (Bstrcmp(label+(j<<6),label+(labelcnt<<6)) == 0)
1652
            {
1653
                if (labeltype[j] & LABEL_STATE)
5 Plagman 1654
                {
564 terminx 1655
                    if (!(error || warning) && g_ScriptDebug > 1)
584 terminx 1656
                        initprintf("%s:%d: debug: accepted state label `%s'.\n",compilefile,line_number,label+(j<<6));
337 terminx 1657
                    *scriptptr = labelcode[j];
1658
                    break;
5 Plagman 1659
                }
337 terminx 1660
                else
5 Plagman 1661
                {
337 terminx 1662
                    char *gl;
437 terminx 1663
                    gl = (char *)translatelabeltype(labeltype[j]);
337 terminx 1664
                    ReportError(-1);
584 terminx 1665
                    initprintf("%s:%d: warning: expected a state, found a %s.\n",compilefile,line_number,gl);
337 terminx 1666
                    Bfree(gl);
1667
                    *(scriptptr-1) = CON_NULLOP; // get rid of the state, leaving a nullop to satisfy if conditions
1668
                    return 0;  // valid label name, but wrong type
5 Plagman 1669
                }
1670
            }
337 terminx 1671
        }
1672
        if (j==labelcnt)
1673
        {
1674
            ReportError(-1);
584 terminx 1675
            initprintf("%s:%d: error: state `%s' not found.\n",compilefile,line_number,label+(labelcnt<<6));
337 terminx 1676
            error++;
1677
        }
1678
        scriptptr++;
1679
        return 0;
1680
 
1681
    case CON_ENDS:
1682
        if (parsing_state == 0)
1683
        {
1684
            ReportError(-1);
584 terminx 1685
            initprintf("%s:%d: error: found `ends' without open `state'.\n",compilefile,line_number);
337 terminx 1686
            error++;
1687
        }
1688
        //            else
1689
        {
1690
            if (num_braces > 0)
5 Plagman 1691
            {
337 terminx 1692
                ReportError(ERROR_OPENBRACKET);
5 Plagman 1693
                error++;
1694
            }
337 terminx 1695
            if (num_braces < 0)
5 Plagman 1696
            {
337 terminx 1697
                ReportError(ERROR_CLOSEBRACKET);
5 Plagman 1698
                error++;
1699
            }
337 terminx 1700
            if (checking_switch > 0)
5 Plagman 1701
            {
337 terminx 1702
                ReportError(ERROR_NOENDSWITCH);
1703
                error++;
5 Plagman 1704
 
337 terminx 1705
                checking_switch = 0; // can't be checking anymore...
1706
            }
335 terminx 1707
 
337 terminx 1708
            parsing_state = 0;
1709
            Bsprintf(parsing_item_name,"(none)");
1710
        }
1711
        return 0;
1712
 
1713
    case CON_SETTHISPROJECTILE:
1714
    case CON_SETPROJECTILE:
1715
        if (!CheckEventSync(current_event))
1716
            ReportError(WARNING_EVENTSYNC);
1717
    case CON_GETTHISPROJECTILE:
1718
    case CON_GETPROJECTILE:
1719
    {
584 terminx 1720
        int lLabelID;
337 terminx 1721
 
1722
        // syntax getwall[<var>].x <VAR>
1723
        // gets the value of wall[<var>].xxx into <VAR>
1724
 
1725
        // now get name of .xxx
1726
        while ((*textptr != '['))
1727
        {
1728
            textptr++;
1729
        }
1730
        if (*textptr == '[')
1731
            textptr++;
1732
 
1733
        // get the ID of the DEF
1734
        if (tw == CON_SETTHISPROJECTILE)
1735
            labelsonly = 1;
1736
        transvar();
1737
        labelsonly = 0;
1738
        // now get name of .xxx
1739
        while (*textptr != '.')
1740
        {
1741
            if (*textptr == 0xa)
1742
                break;
1743
            if (!*textptr)
1744
                break;
1745
 
1746
            textptr++;
1747
        }
1748
        if (*textptr!='.')
1749
        {
1750
            error++;
1751
            ReportError(ERROR_SYNTAXERROR);
331 terminx 1752
            return 0;
337 terminx 1753
        }
1754
        textptr++;
1755
        /// now pointing at 'xxx'
1756
        getlabel();
1757
        //printf("found xxx label of '%s'\n",   label+(labelcnt<<6));
5 Plagman 1758
 
337 terminx 1759
        lLabelID=getlabeloffset(projectilelabels,label+(labelcnt<<6));
584 terminx 1760
        //printf("LabelID is %d\n",lLabelID);
337 terminx 1761
        if (lLabelID == -1)
331 terminx 1762
        {
337 terminx 1763
            error++;
1764
            ReportError(ERROR_SYMBOLNOTRECOGNIZED);
1765
            return 0;
1766
        }
5 Plagman 1767
 
337 terminx 1768
        *scriptptr++=projectilelabels[lLabelID].lId;
5 Plagman 1769
 
337 terminx 1770
        //printf("member's flags are: %02Xh\n",playerlabels[lLabelID].flags);
5 Plagman 1771
 
337 terminx 1772
        // now at target VAR...
1773
 
1774
        // get the ID of the DEF
1775
        switch (tw)
1776
        {
1777
        case CON_SETPROJECTILE:
1778
        case CON_SETTHISPROJECTILE:
331 terminx 1779
            transvar();
337 terminx 1780
            break;
1781
        default:
1782
            transvartype(GAMEVAR_FLAG_READONLY);
1783
            break;
1784
        }
1785
        break;
1786
    }
5 Plagman 1787
 
337 terminx 1788
    case CON_GAMEVAR:
1789
        // syntax: gamevar <var1> <initial value> <flags>
1790
        // defines var1 and sets initial value.
1791
        // flags are used to define usage
1792
        // (see top of this files for flags)
1793
        //printf("Got gamedef. Getting Label. '%.20s'\n",textptr);
1794
 
1795
        if (isdigit(*textptr) || (*textptr == '-'))
1796
        {
5 Plagman 1797
            getlabel();
337 terminx 1798
            error++;
1799
            ReportError(ERROR_SYNTAXERROR);
1800
            transnum(LABEL_DEFINE);
1801
            transnum(LABEL_DEFINE);
1802
            scriptptr -= 3; // we complete the process anyways just to skip past the fucked up section
1803
            return 0;
1804
        }
5 Plagman 1805
 
337 terminx 1806
        getlabel();
1807
        //printf("Got Label '%.20s'\n",textptr);
1808
        // Check to see it's already defined
1809
 
1810
        for (i=0;i<NUMKEYWORDS;i++)
1811
            if (Bstrcmp(label+(labelcnt<<6),keyw[i]) == 0)
5 Plagman 1812
            {
1813
                error++;
337 terminx 1814
                ReportError(ERROR_ISAKEYWORD);
5 Plagman 1815
                return 0;
1816
            }
337 terminx 1817
#if 0
1818
        for (i=0;i<iGameVarCount;i++)
1819
        {
1820
            if (aGameVars[i].szLabel != NULL)
5 Plagman 1821
            {
337 terminx 1822
                if (Bstrcmp(label+(labelcnt<<6),aGameVars[i].szLabel) == 0)
1823
                {
1824
                    warning++;
584 terminx 1825
                    initprintf("  * WARNING.(L%d) duplicate Game definition `%s' ignored.\n",line_number,label+(labelcnt<<6));
102 terminx 1826
                    break;
337 terminx 1827
                }
5 Plagman 1828
            }
1829
        }
337 terminx 1830
#endif
5 Plagman 1831
 
337 terminx 1832
        //printf("Translating number  '%.20s'\n",textptr);
1833
        transnum(LABEL_DEFINE); // get initial value
1834
        //printf("Done Translating number.  '%.20s'\n",textptr);
5 Plagman 1835
 
337 terminx 1836
        transnum(LABEL_DEFINE); // get flags
1837
        //Bsprintf(g_szBuf,"Adding GameVar='%s', val=%l, flags=%lX",label+(labelcnt<<6),
1838
        //      *(scriptptr-2), *(scriptptr-1));
1839
        //AddLog(g_szBuf);
1840
 
1841
        AddGameVar(label+(labelcnt<<6),*(scriptptr-2),
1842
                   (*(scriptptr-1))
1843
                   // can't define default or secret
1844
                   & (~(GAMEVAR_FLAG_DEFAULT | GAMEVAR_FLAG_SECRET))
1845
                  );
1846
        //AddLog("Added gamevar");
1847
        scriptptr -= 3; // no need to save in script...
1848
        return 0;
1849
 
1850
    case CON_DEFINE:
1851
    {
1852
        //printf("Got definition. Getting Label. '%.20s'\n",textptr);
1853
        getlabel();
1854
        //printf("Got label. '%.20s'\n",textptr);
1855
        // Check to see it's already defined
1856
 
1857
        for (i=0;i<NUMKEYWORDS;i++)
1858
            if (Bstrcmp(label+(labelcnt<<6),keyw[i]) == 0)
331 terminx 1859
            {
1860
                error++;
337 terminx 1861
                ReportError(ERROR_ISAKEYWORD);
331 terminx 1862
                return 0;
1863
            }
5 Plagman 1864
 
337 terminx 1865
        for (i=0;i<labelcnt;i++)
1866
        {
546 terminx 1867
            if (Bstrcmp(label+(labelcnt<<6),label+(i<<6)) == 0 /* && (labeltype[i] & LABEL_DEFINE) */)
5 Plagman 1868
            {
337 terminx 1869
                if (i >= defaultlabelcnt)
5 Plagman 1870
                {
337 terminx 1871
                    warning++;
1872
                    ReportError(WARNING_DUPLICATEDEFINITION);
5 Plagman 1873
                }
337 terminx 1874
                break;
5 Plagman 1875
            }
337 terminx 1876
        }
1877
        //printf("Translating. '%.20s'\n",textptr);
1878
        transnum(LABEL_DEFINE);
1879
        //printf("Translated. '%.20s'\n",textptr);
1880
        if (i == labelcnt)
1881
        {
1882
            //              printf("Defining Definition '%s' to be '%d'\n",label+(labelcnt<<6),*(scriptptr-1));
1883
            labeltype[labelcnt] = LABEL_DEFINE;
1884
            labelcode[labelcnt++] = *(scriptptr-1);
1885
            if (*(scriptptr-1) >= 0 && *(scriptptr-1) < MAXTILES && dynamicremap)
1886
                processnames(label+(i<<6),*(scriptptr-1));
1887
        }
1888
        scriptptr -= 2;
1889
        return 0;
1890
    }
5 Plagman 1891
 
337 terminx 1892
    case CON_PALFROM:
1893
        for (j=0;j<4;j++)
1894
        {
1895
            if (keyword() == -1)
1896
                transnum(LABEL_DEFINE);
1897
            else break;
1898
        }
5 Plagman 1899
 
337 terminx 1900
        while (j<4)
1901
        {
1902
            *scriptptr = 0;
1903
            scriptptr++;
1904
            j++;
1905
        }
1906
        return 0;
5 Plagman 1907
 
337 terminx 1908
    case CON_MOVE:
1909
        if (parsing_actor || parsing_state)
1910
        {
1911
            if (!CheckEventSync(current_event))
1912
                ReportError(WARNING_EVENTSYNC);
5 Plagman 1913
 
337 terminx 1914
            if ((transnum(LABEL_MOVE|LABEL_DEFINE) == 0) && (*(scriptptr-1) != 0) && (*(scriptptr-1) != 1))
1915
            {
1916
                ReportError(-1);
1917
                *(scriptptr-1) = 0;
584 terminx 1918
                initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number);
337 terminx 1919
            }
1920
 
1921
            j = 0;
1922
            while (keyword() == -1)
1923
            {
1924
                transnum(LABEL_DEFINE);
1925
                scriptptr--;
1926
                j |= *scriptptr;
1927
            }
1928
            *scriptptr = j;
1929
 
1930
            scriptptr++;
1931
        }
1932
        else
5 Plagman 1933
        {
337 terminx 1934
            scriptptr--;
5 Plagman 1935
            getlabel();
1936
            // Check to see it's already defined
1937
 
331 terminx 1938
            for (i=0;i<NUMKEYWORDS;i++)
333 terminx 1939
                if (Bstrcmp(label+(labelcnt<<6),keyw[i]) == 0)
5 Plagman 1940
                {
1941
                    error++;
1942
                    ReportError(ERROR_ISAKEYWORD);
1943
                    return 0;
1944
                }
1945
 
331 terminx 1946
            for (i=0;i<labelcnt;i++)
546 terminx 1947
                if (Bstrcmp(label+(labelcnt<<6),label+(i<<6)) == 0 /* && (labeltype[i] & LABEL_MOVE) */)
5 Plagman 1948
                {
337 terminx 1949
                    warning++;
584 terminx 1950
                    initprintf("%s:%d: warning: duplicate move `%s' ignored.\n",compilefile,line_number,label+(labelcnt<<6));
5 Plagman 1951
                    break;
1952
                }
331 terminx 1953
            if (i == labelcnt)
5 Plagman 1954
            {
337 terminx 1955
                labeltype[labelcnt] = LABEL_MOVE;
584 terminx 1956
                labelcode[labelcnt++] = (int) scriptptr;
5 Plagman 1957
            }
337 terminx 1958
            for (j=0;j<2;j++)
5 Plagman 1959
            {
337 terminx 1960
                if (keyword() >= 0) break;
1961
                transnum(LABEL_DEFINE);
5 Plagman 1962
            }
337 terminx 1963
            for (k=j;k<2;k++)
5 Plagman 1964
            {
1965
                *scriptptr = 0;
1966
                scriptptr++;
1967
            }
337 terminx 1968
        }
1969
        return 0;
5 Plagman 1970
 
337 terminx 1971
    case CON_MUSIC:
1972
    {
1973
        // NOTE: this doesn't get stored in the PCode...
1974
 
1975
        // music 1 stalker.mid dethtoll.mid streets.mid watrwld1.mid snake1.mid
1976
        //    thecall.mid ahgeez.mid dethtoll.mid streets.mid watrwld1.mid snake1.mid
1977
        scriptptr--;
1978
        transnum(LABEL_DEFINE); // Volume Number (0/4)
1979
        scriptptr--;
1980
 
1981
        k = *scriptptr-1;
1982
 
1983
        if (k >= 0) // if it's background music
1984
        {
1985
            i = 0;
1986
            // get the file name...
1987
            while (keyword() == -1)
335 terminx 1988
            {
337 terminx 1989
                while (isaltok(*textptr) == 0)
5 Plagman 1990
                {
337 terminx 1991
                    if (*textptr == 0x0a) line_number++;
1992
                    textptr++;
1993
                    if (*textptr == 0) break;
5 Plagman 1994
                }
331 terminx 1995
                j = 0;
412 terminx 1996
                tempbuf[j] = '/';
337 terminx 1997
                while (isaltok(*(textptr+j)))
331 terminx 1998
                {
412 terminx 1999
                    tempbuf[j+1] = textptr[j];
337 terminx 2000
                    j++;
331 terminx 2001
                }
412 terminx 2002
                tempbuf[j+1] = '\0';
385 terminx 2003
 
562 terminx 2004
                if (map[(k*MAXLEVELS)+i].musicfn == NULL)
2005
                    map[(k*MAXLEVELS)+i].musicfn = Bcalloc(Bstrlen(tempbuf)+1,sizeof(char));
2006
                else if ((Bstrlen(tempbuf)+1) > sizeof(map[(k*MAXLEVELS)+i].musicfn))
2007
                    map[(k*MAXLEVELS)+i].musicfn = Brealloc(map[(k*MAXLEVELS)+i].musicfn,(Bstrlen(tempbuf)+1));
385 terminx 2008
 
562 terminx 2009
                Bstrcpy(map[(k*MAXLEVELS)+i].musicfn,tempbuf);
385 terminx 2010
 
337 terminx 2011
                textptr += j;
381 terminx 2012
                if (i > MAXLEVELS-1) break;
337 terminx 2013
                i++;
5 Plagman 2014
            }
337 terminx 2015
        }
2016
        else
2017
        {
2018
            i = 0;
2019
            while (keyword() == -1)
5 Plagman 2020
            {
337 terminx 2021
                while (isaltok(*textptr) == 0)
5 Plagman 2022
                {
337 terminx 2023
                    if (*textptr == 0x0a) line_number++;
2024
                    textptr++;
2025
                    if (*textptr == 0) break;
331 terminx 2026
                }
337 terminx 2027
                j = 0;
381 terminx 2028
 
337 terminx 2029
                while (isaltok(*(textptr+j)))
331 terminx 2030
                {
337 terminx 2031
                    env_music_fn[i][j] = textptr[j];
2032
                    j++;
331 terminx 2033
                }
337 terminx 2034
                env_music_fn[i][j] = '\0';
2035
 
2036
                textptr += j;
381 terminx 2037
                if (i > MAXVOLUMES-1) break;
337 terminx 2038
                i++;
5 Plagman 2039
            }
337 terminx 2040
        }
2041
    }
2042
    return 0;
5 Plagman 2043
 
337 terminx 2044
    case CON_INCLUDE:
2045
        scriptptr--;
2046
        while (isaltok(*textptr) == 0)
5 Plagman 2047
        {
337 terminx 2048
            if (*textptr == 0x0a) line_number++;
2049
            textptr++;
2050
            if (*textptr == 0) break;
2051
        }
2052
        j = 0;
2053
        while (isaltok(*textptr))
2054
        {
2055
            tempbuf[j] = *(textptr++);
2056
            j++;
2057
        }
2058
        tempbuf[j] = '\0';
5 Plagman 2059
 
337 terminx 2060
        {
437 terminx 2061
            int temp_line_number;
2062
            int  temp_ifelse_check;
337 terminx 2063
            char *origtptr, *mptr;
2064
            char parentcompilefile[255];
2065
            int fp;
5 Plagman 2066
 
337 terminx 2067
            fp = kopen4load(tempbuf,loadfromgrouponly);
2068
            if (fp < 0)
2069
            {
2070
                error++;
584 terminx 2071
                initprintf("%s:%d: error: could not find file `%s'.\n",compilefile,line_number,tempbuf);
337 terminx 2072
                return 0;
2073
            }
335 terminx 2074
 
337 terminx 2075
            j = kfilelength(fp);
2076
 
2077
            mptr = (char *)Bmalloc(j+1);
2078
            if (!mptr)
5 Plagman 2079
            {
337 terminx 2080
                kclose(fp);
2081
                error++;
584 terminx 2082
                initprintf("%s:%d: error: could not allocate %d bytes to include `%s'.\n",
337 terminx 2083
                           line_number,compilefile,j,tempbuf);
2084
                return 0;
5 Plagman 2085
            }
2086
 
584 terminx 2087
            initprintf("Including: %s (%d bytes)\n",tempbuf, j);
337 terminx 2088
            kread(fp, mptr, j);
2089
            kclose(fp);
2090
            mptr[j] = 0;
2091
 
2092
            if (*textptr == '"') // skip past the closing quote if it's there so we don't screw up the next line
2093
                textptr++;
2094
            origtptr = textptr;
2095
 
2096
            Bstrcpy(parentcompilefile, compilefile);
2097
            Bstrcpy(compilefile, tempbuf);
2098
            temp_line_number = line_number;
2099
            line_number = 1;
2100
            temp_ifelse_check = checking_ifelse;
2101
            checking_ifelse = 0;
2102
 
2103
            textptr = mptr;
2104
            do done = parsecommand();
2105
            while (!done);
2106
 
2107
            Bstrcpy(compilefile, parentcompilefile);
2108
            total_lines += line_number;
2109
            line_number = temp_line_number;
2110
            checking_ifelse = temp_ifelse_check;
2111
 
2112
            textptr = origtptr;
2113
 
2114
            Bfree(mptr);
5 Plagman 2115
        }
2116
        return 0;
2117
 
337 terminx 2118
    case CON_AI:
2119
        if (parsing_actor || parsing_state)
2120
        {
2121
            if (!CheckEventSync(current_event))
2122
                ReportError(WARNING_EVENTSYNC);
2123
            transnum(LABEL_AI);
2124
        }
2125
        else
2126
        {
5 Plagman 2127
            scriptptr--;
337 terminx 2128
            getlabel();
5 Plagman 2129
 
337 terminx 2130
            for (i=0;i<NUMKEYWORDS;i++)
2131
                if (Bstrcmp(label+(labelcnt<<6),keyw[i]) == 0)
5 Plagman 2132
                {
2133
                    error++;
337 terminx 2134
                    ReportError(ERROR_ISAKEYWORD);
5 Plagman 2135
                    return 0;
2136
                }
2137
 
337 terminx 2138
            for (i=0;i<labelcnt;i++)
546 terminx 2139
                if (Bstrcmp(label+(labelcnt<<6),label+(i<<6)) == 0 /* && (labeltype[i] & LABEL_AI) */)
5 Plagman 2140
                {
337 terminx 2141
                    warning++;
584 terminx 2142
                    initprintf("%s:%d: warning: duplicate ai `%s' ignored.\n",compilefile,line_number,label+(labelcnt<<6));
337 terminx 2143
                    break;
5 Plagman 2144
                }
2145
 
337 terminx 2146
            if (i == labelcnt)
2147
            {
2148
                labeltype[labelcnt] = LABEL_AI;
584 terminx 2149
                labelcode[labelcnt++] = (int) scriptptr;
335 terminx 2150
            }
2151
 
337 terminx 2152
            for (j=0;j<3;j++)
5 Plagman 2153
            {
337 terminx 2154
                if (keyword() >= 0) break;
2155
                if (j == 1)
2156
                    transnum(LABEL_ACTION);
2157
                else if (j == 2)
2158
                {
2159
                    if ((transnum(LABEL_MOVE|LABEL_DEFINE) == 0) && (*(scriptptr-1) != 0) && (*(scriptptr-1) != 1))
254 terminx 2160
                    {
337 terminx 2161
                        ReportError(-1);
2162
                        *(scriptptr-1) = 0;
584 terminx 2163
                        initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number);
254 terminx 2164
                    }
337 terminx 2165
                    k = 0;
2166
                    while (keyword() == -1)
5 Plagman 2167
                    {
337 terminx 2168
                        transnum(LABEL_DEFINE);
2169
                        scriptptr--;
2170
                        k |= *scriptptr;
5 Plagman 2171
                    }
337 terminx 2172
                    *scriptptr = k;
5 Plagman 2173
                    scriptptr++;
337 terminx 2174
                    return 0;
5 Plagman 2175
                }
2176
            }
337 terminx 2177
            for (k=j;k<3;k++)
5 Plagman 2178
            {
337 terminx 2179
                *scriptptr = 0;
2180
                scriptptr++;
5 Plagman 2181
            }
337 terminx 2182
        }
2183
        return 0;
5 Plagman 2184
 
337 terminx 2185
    case CON_ACTION:
2186
        if (parsing_actor || parsing_state)
2187
        {
2188
            if (!CheckEventSync(current_event))
2189
                ReportError(WARNING_EVENTSYNC);
2190
            transnum(LABEL_ACTION);
2191
        }
2192
        else
2193
        {
2194
            scriptptr--;
2195
            getlabel();
2196
            // Check to see it's already defined
5 Plagman 2197
 
337 terminx 2198
            for (i=0;i<NUMKEYWORDS;i++)
2199
                if (Bstrcmp(label+(labelcnt<<6),keyw[i]) == 0)
5 Plagman 2200
                {
337 terminx 2201
                    error++;
2202
                    ReportError(ERROR_ISAKEYWORD);
2203
                    return 0;
5 Plagman 2204
                }
337 terminx 2205
            for (i=0;i<labelcnt;i++)
546 terminx 2206
                if (Bstrcmp(label+(labelcnt<<6),label+(i<<6)) == 0 /* && (labeltype[i] & LABEL_ACTION) */)
5 Plagman 2207
                {
337 terminx 2208
                    warning++;
584 terminx 2209
                    initprintf("%s:%d: warning: duplicate action `%s' ignored.\n",compilefile,line_number,label+(labelcnt<<6));
337 terminx 2210
                    break;
5 Plagman 2211
                }
337 terminx 2212
 
2213
            if (i == labelcnt)
2214
            {
2215
                labeltype[labelcnt] = LABEL_ACTION;
584 terminx 2216
                labelcode[labelcnt] = (int) scriptptr;
337 terminx 2217
                labelcnt++;
5 Plagman 2218
            }
2219
 
337 terminx 2220
            for (j=0;j<5;j++)
5 Plagman 2221
            {
337 terminx 2222
                if (keyword() >= 0) break;
2223
                transnum(LABEL_DEFINE);
5 Plagman 2224
            }
337 terminx 2225
            for (k=j;k<5;k++)
2226
            {
2227
                *scriptptr = 0;
2228
                scriptptr++;
2229
            }
2230
        }
2231
        return 0;
5 Plagman 2232
 
337 terminx 2233
    case CON_ACTOR:
2234
        if (parsing_state || parsing_actor)
2235
        {
2236
            ReportError(ERROR_FOUNDWITHIN);
2237
            error++;
2238
        }
5 Plagman 2239
 
337 terminx 2240
        num_braces = 0;
2241
        scriptptr--;
2242
        parsing_actor = scriptptr;
2243
 
2244
        skipcomments();
2245
        j = 0;
2246
        while (isaltok(*(textptr+j)))
2247
        {
2248
            parsing_item_name[j] = textptr[j];
2249
            j++;
2250
        }
2251
        parsing_item_name[j] = 0;
2252
        transnum(LABEL_DEFINE);
2253
        //         Bsprintf(parsing_item_name,"%s",label+(labelcnt<<6));
2254
        scriptptr--;
2255
        actorscrptr[*scriptptr] = parsing_actor;
2256
 
2257
        for (j=0;j<4;j++)
2258
        {
2259
            *(parsing_actor+j) = 0;
2260
            if (j == 3)
5 Plagman 2261
            {
337 terminx 2262
                j = 0;
2263
                while (keyword() == -1)
2264
                {
2265
                    transnum(LABEL_DEFINE);
2266
                    scriptptr--;
2267
                    j |= *scriptptr;
2268
                }
2269
                *scriptptr = j;
2270
                scriptptr++;
2271
                break;
5 Plagman 2272
            }
337 terminx 2273
            else
5 Plagman 2274
            {
337 terminx 2275
                if (keyword() >= 0)
5 Plagman 2276
                {
337 terminx 2277
                    for (i=4-j; i; i--) *(scriptptr++) = 0;
5 Plagman 2278
                    break;
2279
                }
337 terminx 2280
                switch (j)
5 Plagman 2281
                {
337 terminx 2282
                case 0:
2283
                    transnum(LABEL_DEFINE);
2284
                    break;
2285
                case 1:
2286
                    transnum(LABEL_ACTION);
2287
                    break;
2288
                case 2:
2289
                    if ((transnum(LABEL_MOVE|LABEL_DEFINE) == 0) && (*(scriptptr-1) != 0) && (*(scriptptr-1) != 1))
254 terminx 2290
                    {
337 terminx 2291
                        ReportError(-1);
2292
                        *(scriptptr-1) = 0;
584 terminx 2293
                        initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number);
254 terminx 2294
                    }
337 terminx 2295
                    break;
5 Plagman 2296
                }
337 terminx 2297
                *(parsing_actor+j) = *(scriptptr-1);
5 Plagman 2298
            }
337 terminx 2299
        }
2300
        checking_ifelse = 0;
2301
        return 0;
2302
 
2303
    case CON_ONEVENT:
2304
        if (parsing_state || parsing_actor)
2305
        {
2306
            ReportError(ERROR_FOUNDWITHIN);
2307
            error++;
2308
        }
2309
 
2310
        num_braces = 0;
2311
        scriptptr--;
2312
        parsing_event = scriptptr;
2313
        parsing_actor = scriptptr;
2314
 
2315
        skipcomments();
2316
        j = 0;
2317
        while (isaltok(*(textptr+j)))
2318
        {
2319
            parsing_item_name[j] = textptr[j];
2320
            j++;
2321
        }
2322
        parsing_item_name[j] = 0;
2323
        labelsonly = 1;
2324
        transnum(LABEL_DEFINE);
2325
        labelsonly = 0;
2326
        scriptptr--;
2327
        j= *scriptptr;  // type of event
2328
        current_event = j;