mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 11:10:39 +00:00
Add a THISACTOR for tiledata and paldata, referring to the current actor's picnum and pal.
git-svn-id: https://svn.eduke32.com/eduke32@6351 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
ebe2e67439
commit
bbff77b20e
1 changed files with 15 additions and 3 deletions
|
@ -703,11 +703,15 @@ special:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case STRUCT_TILEDATA:
|
case STRUCT_TILEDATA:
|
||||||
|
if (arrayIndexVar == g_thisActorVarID)
|
||||||
|
arrayIndex = vm.pSprite->picnum;
|
||||||
CHECK_INDEX(MAXTILES);
|
CHECK_INDEX(MAXTILES);
|
||||||
returnValue = VM_GetTileData(arrayIndex, labelNum);
|
returnValue = VM_GetTileData(arrayIndex, labelNum);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case STRUCT_PALDATA:
|
case STRUCT_PALDATA:
|
||||||
|
if (arrayIndexVar == g_thisActorVarID)
|
||||||
|
arrayIndex = vm.pSprite->pal;
|
||||||
CHECK_INDEX(MAXPALOOKUPS);
|
CHECK_INDEX(MAXPALOOKUPS);
|
||||||
returnValue = VM_GetPalData(arrayIndex, labelNum);
|
returnValue = VM_GetPalData(arrayIndex, labelNum);
|
||||||
break;
|
break;
|
||||||
|
@ -721,18 +725,21 @@ special:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case STRUCT_INPUT:
|
case STRUCT_INPUT:
|
||||||
if (arrayIndexVar == g_thisActorVarID) arrayIndex = vm.playerNum;
|
if (arrayIndexVar == g_thisActorVarID)
|
||||||
|
arrayIndex = vm.playerNum;
|
||||||
CHECK_INDEX(MAXPLAYERS);
|
CHECK_INDEX(MAXPLAYERS);
|
||||||
returnValue = VM_GetPlayerInput(arrayIndex, labelNum);
|
returnValue = VM_GetPlayerInput(arrayIndex, labelNum);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case STRUCT_ACTORVAR:
|
case STRUCT_ACTORVAR:
|
||||||
case STRUCT_PLAYERVAR:
|
case STRUCT_PLAYERVAR:
|
||||||
|
// no THISACTOR check here because we convert those cases to setvarvar
|
||||||
returnValue = Gv_GetVar(labelNum, arrayIndex, playerNum);
|
returnValue = Gv_GetVar(labelNum, arrayIndex, playerNum);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case STRUCT_SECTOR:
|
case STRUCT_SECTOR:
|
||||||
if (arrayIndexVar == g_thisActorVarID) arrayIndex = sprite[vm.spriteNum].sectnum;
|
if (arrayIndexVar == g_thisActorVarID)
|
||||||
|
arrayIndex = vm.pSprite->sectnum;
|
||||||
CHECK_INDEX(MAXSECTORS);
|
CHECK_INDEX(MAXSECTORS);
|
||||||
returnValue = VM_GetSector(arrayIndex, labelNum);
|
returnValue = VM_GetSector(arrayIndex, labelNum);
|
||||||
break;
|
break;
|
||||||
|
@ -894,11 +901,15 @@ int __fastcall Gv_GetSpecialVarX(int gameVar)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case STRUCT_TILEDATA:
|
case STRUCT_TILEDATA:
|
||||||
|
if (arrayIndexVar == g_thisActorVarID)
|
||||||
|
arrayIndex = vm.pSprite->picnum;
|
||||||
CHECK_INDEX(MAXTILES, GVX_BADTILE);
|
CHECK_INDEX(MAXTILES, GVX_BADTILE);
|
||||||
returnValue = VM_GetTileData(arrayIndex, labelNum);
|
returnValue = VM_GetTileData(arrayIndex, labelNum);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case STRUCT_PALDATA:
|
case STRUCT_PALDATA:
|
||||||
|
if (arrayIndexVar == g_thisActorVarID)
|
||||||
|
arrayIndex = vm.pSprite->pal;
|
||||||
CHECK_INDEX(MAXPALOOKUPS, GVX_BADPAL);
|
CHECK_INDEX(MAXPALOOKUPS, GVX_BADPAL);
|
||||||
returnValue = VM_GetPalData(arrayIndex, labelNum);
|
returnValue = VM_GetPalData(arrayIndex, labelNum);
|
||||||
break;
|
break;
|
||||||
|
@ -921,12 +932,13 @@ int __fastcall Gv_GetSpecialVarX(int gameVar)
|
||||||
|
|
||||||
case STRUCT_ACTORVAR:
|
case STRUCT_ACTORVAR:
|
||||||
case STRUCT_PLAYERVAR:
|
case STRUCT_PLAYERVAR:
|
||||||
|
// no THISACTOR check here because we convert those cases to setvarvar
|
||||||
returnValue = Gv_GetVar(labelNum, arrayIndex, vm.playerNum);
|
returnValue = Gv_GetVar(labelNum, arrayIndex, vm.playerNum);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case STRUCT_SECTOR:
|
case STRUCT_SECTOR:
|
||||||
if (arrayIndexVar == g_thisActorVarID)
|
if (arrayIndexVar == g_thisActorVarID)
|
||||||
arrayIndex = sprite[vm.spriteNum].sectnum;
|
arrayIndex = vm.pSprite->sectnum;
|
||||||
CHECK_INDEX(MAXSECTORS, GVX_BADSECTOR);
|
CHECK_INDEX(MAXSECTORS, GVX_BADSECTOR);
|
||||||
returnValue = VM_GetSector(arrayIndex, labelNum);
|
returnValue = VM_GetSector(arrayIndex, labelNum);
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue