mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-13 19:40:43 +00:00
Add blood specific parameters to tilefromtexture
This commit is contained in:
parent
f6ce571075
commit
0a74187512
1 changed files with 81 additions and 0 deletions
|
@ -149,6 +149,12 @@ enum gametokens
|
||||||
T_FORCENOFILTER,
|
T_FORCENOFILTER,
|
||||||
T_TEXTUREFILTER,
|
T_TEXTUREFILTER,
|
||||||
T_RFFDEFINEID,
|
T_RFFDEFINEID,
|
||||||
|
T_TILEFROMTEXTURE,
|
||||||
|
T_IFCRC,
|
||||||
|
T_SURFACE,
|
||||||
|
T_VOXEL,
|
||||||
|
T_VIEW,
|
||||||
|
T_SHADE,
|
||||||
};
|
};
|
||||||
|
|
||||||
int blood_globalflags;
|
int blood_globalflags;
|
||||||
|
@ -1933,6 +1939,7 @@ static int parsedefinitions_game(scriptfile *pScript, int firstPass)
|
||||||
{ "renamefile", T_RENAMEFILE },
|
{ "renamefile", T_RENAMEFILE },
|
||||||
{ "globalgameflags", T_GLOBALGAMEFLAGS },
|
{ "globalgameflags", T_GLOBALGAMEFLAGS },
|
||||||
{ "rffdefineid", T_RFFDEFINEID },
|
{ "rffdefineid", T_RFFDEFINEID },
|
||||||
|
{ "tilefromtexture", T_TILEFROMTEXTURE },
|
||||||
};
|
};
|
||||||
|
|
||||||
static const tokenlist soundTokens[] =
|
static const tokenlist soundTokens[] =
|
||||||
|
@ -2081,6 +2088,80 @@ static int parsedefinitions_game(scriptfile *pScript, int firstPass)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case T_TILEFROMTEXTURE:
|
||||||
|
{
|
||||||
|
char *texturetokptr = pScript->ltextptr, *textureend;
|
||||||
|
int32_t tile = -1;
|
||||||
|
int32_t havesurface = 0, havevox = 0, haveview = 0, haveshade = 0;
|
||||||
|
int32_t surface = 0, vox = 0, view = 0, shade = 0;
|
||||||
|
int32_t tilecrc = 0, origcrc = 0;
|
||||||
|
|
||||||
|
static const tokenlist tilefromtexturetokens[] =
|
||||||
|
{
|
||||||
|
{ "surface", T_SURFACE },
|
||||||
|
{ "voxel", T_VOXEL },
|
||||||
|
{ "ifcrc", T_IFCRC },
|
||||||
|
{ "view", T_VIEW },
|
||||||
|
{ "shade", T_SHADE },
|
||||||
|
};
|
||||||
|
|
||||||
|
if (scriptfile_getsymbol(pScript,&tile)) break;
|
||||||
|
if (scriptfile_getbraces(pScript,&textureend)) break;
|
||||||
|
while (pScript->textptr < textureend)
|
||||||
|
{
|
||||||
|
int32_t token = getatoken(pScript,tilefromtexturetokens,ARRAY_SIZE(tilefromtexturetokens));
|
||||||
|
switch (token)
|
||||||
|
{
|
||||||
|
case T_IFCRC:
|
||||||
|
scriptfile_getsymbol(pScript, &tilecrc);
|
||||||
|
break;
|
||||||
|
case T_SURFACE:
|
||||||
|
havesurface = 1;
|
||||||
|
scriptfile_getsymbol(pScript, &surface);
|
||||||
|
break;
|
||||||
|
case T_VOXEL:
|
||||||
|
havevox = 1;
|
||||||
|
scriptfile_getsymbol(pScript, &vox);
|
||||||
|
break;
|
||||||
|
case T_VIEW:
|
||||||
|
haveview = 1;
|
||||||
|
scriptfile_getsymbol(pScript, &view);
|
||||||
|
break;
|
||||||
|
case T_SHADE:
|
||||||
|
haveshade = 1;
|
||||||
|
scriptfile_getsymbol(pScript, &shade);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (EDUKE32_PREDICT_FALSE((unsigned)tile >= MAXUSERTILES))
|
||||||
|
{
|
||||||
|
initprintf("Error: missing or invalid 'tile number' for texture definition near line %s:%d\n",
|
||||||
|
pScript->filename, scriptfile_getlinum(pScript,texturetokptr));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tilecrc)
|
||||||
|
{
|
||||||
|
origcrc = tileCRC(tile);
|
||||||
|
if (origcrc != tilecrc)
|
||||||
|
{
|
||||||
|
//initprintf("CRC of tile %d doesn't match! CRC: %d, Expected: %d\n", tile, origcrc, tilecrc);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (havesurface)
|
||||||
|
surfType[tile] = surface;
|
||||||
|
if (havevox)
|
||||||
|
voxelIndex[tile] = vox;
|
||||||
|
if (haveshade)
|
||||||
|
tileShade[tile] = shade;
|
||||||
|
if (haveview)
|
||||||
|
picanm[tile].extra = view&7;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
case T_CUTSCENE:
|
case T_CUTSCENE:
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue