mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
CON: add sprite pseudo-member 'isvalid', getting 1 if the sprite is valid.
And 0 otherwise. Before accessing a sprite that is not not known to be definitely valid (e.g. a loop over all sprites from 0 to MAXSPRITES-1), one should check for validity before accessing it in any other fashion. git-svn-id: https://svn.eduke32.com/eduke32@4146 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
92594f09c8
commit
8029aceaa4
5 changed files with 20 additions and 1 deletions
|
@ -824,6 +824,8 @@ const memberlabel_t ActorLabels[]=
|
||||||
{ "ulotag", ACTOR_ULOTAG, 0, 0 },
|
{ "ulotag", ACTOR_ULOTAG, 0, 0 },
|
||||||
{ "uhitag", ACTOR_UHITAG, 0, 0 },
|
{ "uhitag", ACTOR_UHITAG, 0, 0 },
|
||||||
|
|
||||||
|
{ "isvalid", ACTOR_ISVALID, 0, 0 },
|
||||||
|
|
||||||
{ "", -1, 0, 0 } // END OF LIST
|
{ "", -1, 0, 0 } // END OF LIST
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -518,6 +518,7 @@ enum ActorLabel_t
|
||||||
ACTOR_ALPHA,
|
ACTOR_ALPHA,
|
||||||
ACTOR_ULOTAG,
|
ACTOR_ULOTAG,
|
||||||
ACTOR_UHITAG,
|
ACTOR_UHITAG,
|
||||||
|
ACTOR_ISVALID,
|
||||||
ACTOR_END
|
ACTOR_END
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -2930,6 +2930,10 @@ static void __fastcall VM_GetSprite(int32_t lVar1, int32_t lLabelID, int32_t lVa
|
||||||
Gv_SetVarX(lVar2, (uint8_t)(spriteext[iActor].alpha * 255.0f));
|
Gv_SetVarX(lVar2, (uint8_t)(spriteext[iActor].alpha * 255.0f));
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
case ACTOR_ISVALID:
|
||||||
|
Gv_SetVarX(lVar2, sprite[iActor].statnum != MAXSTATUS);
|
||||||
|
return;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -3553,6 +3557,7 @@ static int32_t __fastcall VM_AccessSpriteX(int32_t iActor, int32_t lLabelID, int
|
||||||
case ACTOR_YPANNING: return spriteext[iActor].ypanning;
|
case ACTOR_YPANNING: return spriteext[iActor].ypanning;
|
||||||
case ACTOR_HTFLAGS: return actor[iActor].flags;
|
case ACTOR_HTFLAGS: return actor[iActor].flags;
|
||||||
case ACTOR_ALPHA: return (uint8_t)(spriteext[iActor].alpha*255.0f);
|
case ACTOR_ALPHA: return (uint8_t)(spriteext[iActor].alpha*255.0f);
|
||||||
|
case ACTOR_ISVALID: return (sprite[iActor].statnum != MAXSTATUS);
|
||||||
default: return -1;
|
default: return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -414,6 +414,8 @@ local ActorLabels = {
|
||||||
|
|
||||||
-- Read access differs from write, write not available:
|
-- Read access differs from write, write not available:
|
||||||
alpha = { "_math.floor(spriteext[%s].alpha*255)", "spriteext[%s].alpha=(%%s)/255" },
|
alpha = { "_math.floor(spriteext[%s].alpha*255)", "spriteext[%s].alpha=(%%s)/255" },
|
||||||
|
|
||||||
|
isvalid = { "_con._isvalid(%s)" },
|
||||||
}
|
}
|
||||||
|
|
||||||
local function spr2tspr(code)
|
local function spr2tspr(code)
|
||||||
|
|
|
@ -1424,11 +1424,20 @@ function _cansee(aci, ps)
|
||||||
return can
|
return can
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function _isvalid(i)
|
||||||
|
check_sprite_idx(i)
|
||||||
|
return ffiC.sprite[i].statnum ~= ffiC.MAXSTATUS and 1 or 0
|
||||||
|
end
|
||||||
|
|
||||||
function _canseespr(s1, s2)
|
function _canseespr(s1, s2)
|
||||||
local spr1, spr2 = sprite[s1], sprite[s2]
|
check_sprite_idx(s1)
|
||||||
|
check_sprite_idx(s2)
|
||||||
|
|
||||||
|
local spr1, spr2 = ffiC.sprite[s1], ffiC.sprite[s2]
|
||||||
-- Redundant, but points the error messages to the CON code:
|
-- Redundant, but points the error messages to the CON code:
|
||||||
check_sector_idx(spr1.sectnum)
|
check_sector_idx(spr1.sectnum)
|
||||||
check_sector_idx(spr2.sectnum)
|
check_sector_idx(spr2.sectnum)
|
||||||
|
|
||||||
return cansee(spr1, spr1.sectnum, spr2, spr2.sectnum) and 1 or 0
|
return cansee(spr1, spr1.sectnum, spr2, spr2.sectnum) and 1 or 0
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue