mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-17 21:10:53 +00:00
- added CCMDs for all 'holly' cheats that didn't have an equivalent yet.
This commit is contained in:
parent
6b1d6a44d7
commit
6d852c33dd
2 changed files with 56 additions and 209 deletions
|
@ -64,7 +64,6 @@ bool EndLevel = false;
|
||||||
/* these are XORed in the original game executable then XORed back to normal when the game first starts. Here they are normally */
|
/* these are XORed in the original game executable then XORed back to normal when the game first starts. Here they are normally */
|
||||||
const char *gString[] =
|
const char *gString[] =
|
||||||
{
|
{
|
||||||
"PASSWORDS",
|
|
||||||
"HOLLY",
|
"HOLLY",
|
||||||
"KIMBERLY",
|
"KIMBERLY",
|
||||||
"LOBOCOP",
|
"LOBOCOP",
|
||||||
|
@ -76,22 +75,6 @@ const char *gString[] =
|
||||||
"LOBOSPHERE",
|
"LOBOSPHERE",
|
||||||
"LOBOSWAG",
|
"LOBOSWAG",
|
||||||
"LOBOXY",
|
"LOBOXY",
|
||||||
"",
|
|
||||||
"PASSINFO",
|
|
||||||
"",
|
|
||||||
"HI SWEETIE, I LOVE YOU",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"FLASHES TOGGLED",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"FULL MAP",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"EOF",
|
|
||||||
"",
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -358,14 +341,6 @@ void HandleAsync()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ResetPassword()
|
|
||||||
{
|
|
||||||
nCodeMin = nFirstPassword;
|
|
||||||
nCodeIndex = 0;
|
|
||||||
|
|
||||||
nCodeMax = (nFirstPassword + nPasswordCount) - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DoPassword(int nPassword)
|
void DoPassword(int nPassword)
|
||||||
{
|
{
|
||||||
if (nNetPlayerCount) {
|
if (nNetPlayerCount) {
|
||||||
|
@ -563,145 +538,6 @@ void CheckKeys()
|
||||||
{
|
{
|
||||||
char ch = inputState.keyGetChar();
|
char ch = inputState.keyGetChar();
|
||||||
|
|
||||||
if (bHolly)
|
|
||||||
{
|
|
||||||
if (ch)
|
|
||||||
{
|
|
||||||
size_t nStringLen = strlen(sHollyStr);
|
|
||||||
|
|
||||||
if (ch == asc_Enter)
|
|
||||||
{
|
|
||||||
const char *pToken = safeStrtok(sHollyStr, " ");
|
|
||||||
|
|
||||||
if (!strcmp(pToken, "GOTO"))
|
|
||||||
{
|
|
||||||
// move player to X, Y coordinates
|
|
||||||
int nSprite = PlayerList[0].nSprite;
|
|
||||||
|
|
||||||
pToken = safeStrtok(NULL, ",");
|
|
||||||
sprite[nSprite].x = atoi(pToken);
|
|
||||||
pToken = safeStrtok(NULL, ",");
|
|
||||||
sprite[nSprite].y = atoi(pToken);
|
|
||||||
|
|
||||||
setsprite(nSprite, &sprite[nSprite].pos);
|
|
||||||
sprite[nSprite].z = sector[sprite[nSprite].sectnum].floorz;
|
|
||||||
}
|
|
||||||
else if (!strcmp(pToken, "LEVEL"))
|
|
||||||
{
|
|
||||||
pToken = safeStrtok(NULL, " ");
|
|
||||||
levelnew = atoi(pToken);
|
|
||||||
}
|
|
||||||
else if (!strcmp(pToken, "DOORS"))
|
|
||||||
{
|
|
||||||
for (int i = 0; i < kMaxChannels; i++)
|
|
||||||
{
|
|
||||||
// CHECKME - does this toggle?
|
|
||||||
if (sRunChannels[i].c == 0) {
|
|
||||||
runlist_ChangeChannel(i, 1);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
runlist_ChangeChannel(i, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (!strcmp(pToken, "EXIT"))
|
|
||||||
{
|
|
||||||
EndLevel = true;
|
|
||||||
}
|
|
||||||
else if (!strcmp(pToken, "CREATURE"))
|
|
||||||
{
|
|
||||||
// i = nNetPlayerCount;
|
|
||||||
if (!nNetPlayerCount)
|
|
||||||
{
|
|
||||||
pToken = safeStrtok(NULL, " ");
|
|
||||||
switch (atoi(pToken))
|
|
||||||
{
|
|
||||||
// TODO - enums?
|
|
||||||
case 0:
|
|
||||||
BuildAnubis(-1, initx, inity, sector[initsect].floorz, initsect, inita, false);
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
BuildSpider(-1, initx, inity, sector[initsect].floorz, initsect, inita);
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
BuildMummy(-1, initx, inity, sector[initsect].floorz, initsect, inita);
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
BuildFish(-1, initx, inity, initz + eyelevel[nLocalPlayer], initsect, inita);
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
BuildLion(-1, initx, inity, sector[initsect].floorz, initsect, inita);
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
BuildLava(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
BuildRex(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
|
||||||
break;
|
|
||||||
case 7:
|
|
||||||
BuildSet(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
|
||||||
break;
|
|
||||||
case 8:
|
|
||||||
BuildQueen(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
|
||||||
break;
|
|
||||||
case 9:
|
|
||||||
BuildRoach(0, -1, initx, inity, sector[initsect].floorz, initsect, inita);
|
|
||||||
break;
|
|
||||||
case 10:
|
|
||||||
BuildRoach(1, -1, initx, inity, sector[initsect].floorz, initsect, inita);
|
|
||||||
break;
|
|
||||||
case 11:
|
|
||||||
BuildWasp(-1, initx, inity, sector[initsect].floorz - 25600, initsect, inita);
|
|
||||||
break;
|
|
||||||
case 12:
|
|
||||||
BuildScorp(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
|
||||||
break;
|
|
||||||
case 13:
|
|
||||||
BuildRat(-1, initx, inity, sector[initsect].floorz, initsect, inita);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (nStringLen == 0)
|
|
||||||
{
|
|
||||||
bHolly = false;
|
|
||||||
StatusMessage(1, " ");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for (int i = 0; i < nPasswordCount; ++i)
|
|
||||||
{
|
|
||||||
if (!strcmp(sHollyStr, gString[i + nFirstPassword]))
|
|
||||||
{
|
|
||||||
DoPassword(i);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
sHollyStr[0] = '\0';
|
|
||||||
}
|
|
||||||
else if (ch == asc_BackSpace)
|
|
||||||
{
|
|
||||||
if (nStringLen != 0) {
|
|
||||||
sHollyStr[nStringLen - 1] = '\0';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (nStringLen < (sizeof(sHollyStr) - 1)) // do we have room to add a char and null terminator?
|
|
||||||
{
|
|
||||||
sHollyStr[nStringLen] = toupper(ch);
|
|
||||||
sHollyStr[nStringLen + 1] = '\0';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
inputState.keyGetChar(); //???
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isalpha(ch))
|
if (isalpha(ch))
|
||||||
{
|
{
|
||||||
|
@ -724,7 +560,6 @@ void CheckKeys()
|
||||||
ebx -= nFirstPassword;
|
ebx -= nFirstPassword;
|
||||||
|
|
||||||
DoPassword(ebx);
|
DoPassword(ebx);
|
||||||
ResetPassword();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
@ -1007,29 +842,6 @@ static void GameMove(void)
|
||||||
|
|
||||||
int32_t r_maxfpsoffset = 0;
|
int32_t r_maxfpsoffset = 0;
|
||||||
|
|
||||||
void PatchDemoStrings()
|
|
||||||
{
|
|
||||||
#if 0
|
|
||||||
if (!ISDEMOVER)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (EXHUMED) {
|
|
||||||
gString[60] = "PICK UP A COPY OF EXHUMED";
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
gString[60] = "PICK UP A COPY OF POWERSLAVE";
|
|
||||||
}
|
|
||||||
|
|
||||||
gString[61] = "TODAY TO CONTINUE THE ADVENTURE!";
|
|
||||||
gString[62] = "MORE LEVELS, NASTIER CREATURES";
|
|
||||||
gString[63] = "AND THE EVIL DOINGS OF THE";
|
|
||||||
gString[64] = "KILMAAT AWAIT YOU IN THE FULL";
|
|
||||||
gString[65] = "VERSION OF THE GAME.";
|
|
||||||
gString[66] = "TWENTY LEVELS, PLUS 12 NETWORK";
|
|
||||||
gString[67] = "PLAY LEVELS CAN BE YOURS!";
|
|
||||||
gString[68] = "END";
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void ExitGame()
|
void ExitGame()
|
||||||
{
|
{
|
||||||
|
@ -1146,7 +958,6 @@ int GameInterface::app_main()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
PatchDemoStrings();
|
|
||||||
// loc_115F5:
|
// loc_115F5:
|
||||||
nFirstPassword = FindGString("PASSWORDS");
|
nFirstPassword = FindGString("PASSWORDS");
|
||||||
nFirstPassInfo = FindGString("PASSINFO");
|
nFirstPassInfo = FindGString("PASSINFO");
|
||||||
|
@ -2255,10 +2066,4 @@ void LoadTextureState()
|
||||||
TileFiles.InvalidateTile(kEnergy2);
|
TileFiles.InvalidateTile(kEnergy2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
CCMD(ex_endlevel)
|
|
||||||
{
|
|
||||||
EndLevel = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
END_PS_NS
|
END_PS_NS
|
||||||
|
|
|
@ -27,6 +27,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
#include "player.h"
|
#include "player.h"
|
||||||
#include "view.h"
|
#include "view.h"
|
||||||
#include "mapinfo.h"
|
#include "mapinfo.h"
|
||||||
|
#include "aistuff.h"
|
||||||
|
|
||||||
BEGIN_PS_NS
|
BEGIN_PS_NS
|
||||||
|
|
||||||
|
@ -147,27 +148,68 @@ static int osdcmd_warptocoords(CCmdFuncPtr parm)
|
||||||
return CCMD_OK;
|
return CCMD_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int osdcmd_exitmap(CCmdFuncPtr parm)
|
||||||
|
{
|
||||||
|
EndLevel = true;
|
||||||
|
return CCMD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int osdcmd_doors(CCmdFuncPtr parm)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < kMaxChannels; i++)
|
||||||
|
{
|
||||||
|
// CHECKME - does this toggle?
|
||||||
|
if (sRunChannels[i].c == 0) {
|
||||||
|
runlist_ChangeChannel(i, 1);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
runlist_ChangeChannel(i, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return CCMD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern int initx;
|
||||||
|
extern int inity;
|
||||||
|
extern int initz;
|
||||||
|
extern short inita;
|
||||||
|
extern short initsect;
|
||||||
|
|
||||||
|
static int osdcmd_spawn(CCmdFuncPtr parm)
|
||||||
|
{
|
||||||
|
if (parm->numparms != 1) return CCMD_SHOWHELP;
|
||||||
|
auto c = parm->parms[0];
|
||||||
|
|
||||||
|
if (!stricmp(c, "anubis")) BuildAnubis(-1, initx, inity, sector[initsect].floorz, initsect, inita, false);
|
||||||
|
else if (!stricmp(c, "spider")) BuildSpider(-1, initx, inity, sector[initsect].floorz, initsect, inita);
|
||||||
|
else if (!stricmp(c, "mummy")) BuildMummy(-1, initx, inity, sector[initsect].floorz, initsect, inita);
|
||||||
|
else if (!stricmp(c, "fish")) BuildFish(-1, initx, inity, initz + eyelevel[nLocalPlayer], initsect, inita);
|
||||||
|
else if (!stricmp(c, "lion")) BuildLion(-1, initx, inity, sector[initsect].floorz, initsect, inita);
|
||||||
|
else if (!stricmp(c, "lava")) BuildLava(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
||||||
|
else if (!stricmp(c, "rex")) BuildRex(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
||||||
|
else if (!stricmp(c, "set")) BuildSet(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
||||||
|
else if (!stricmp(c, "queen")) BuildQueen(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
||||||
|
else if (!stricmp(c, "roach")) BuildRoach(0, -1, initx, inity, sector[initsect].floorz, initsect, inita);
|
||||||
|
else if (!stricmp(c, "roach2")) BuildRoach(1, -1, initx, inity, sector[initsect].floorz, initsect, inita);
|
||||||
|
else if (!stricmp(c, "wasp")) BuildWasp(-1, initx, inity, sector[initsect].floorz - 25600, initsect, inita);
|
||||||
|
else if (!stricmp(c, "scorp")) BuildScorp(-1, initx, inity, sector[initsect].floorz, initsect, inita, nNetPlayerCount);
|
||||||
|
else if (!stricmp(c, "rat")) BuildRat(-1, initx, inity, sector[initsect].floorz, initsect, inita);
|
||||||
|
else Printf("Unknown creature type %s\n", c);
|
||||||
|
return CCMD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int32_t registerosdcommands(void)
|
int32_t registerosdcommands(void)
|
||||||
{
|
{
|
||||||
//if (VOLUMEONE)
|
//if (VOLUMEONE)
|
||||||
C_RegisterFunction("changelevel","changelevel <level>: warps to the given level", osdcmd_changelevel);
|
C_RegisterFunction("changelevel","changelevel <level>: warps to the given level", osdcmd_changelevel);
|
||||||
C_RegisterFunction("map","map <mapname>: loads the given map", osdcmd_map);
|
C_RegisterFunction("map","map <mapname>: loads the given map", osdcmd_map);
|
||||||
// C_RegisterFunction("demo","demo <demofile or demonum>: starts the given demo", osdcmd_demo);
|
C_RegisterFunction("exitmap", "exits current map", osdcmd_exitmap);
|
||||||
//}
|
C_RegisterFunction("doors", "opens/closes doors", osdcmd_doors);
|
||||||
|
|
||||||
//C_RegisterFunction("cmenu","cmenu <#>: jumps to menu", osdcmd_cmenu);
|
|
||||||
|
|
||||||
|
|
||||||
//C_RegisterFunction("give","give <all|health|weapons|ammo|armor|keys|inventory>: gives requested item", osdcmd_give);
|
|
||||||
C_RegisterFunction("god","god: toggles god mode", osdcmd_god);
|
C_RegisterFunction("god","god: toggles god mode", osdcmd_god);
|
||||||
//C_RegisterFunction("activatecheat","activatecheat <id>: activates a cheat code", osdcmd_activatecheat);
|
|
||||||
|
|
||||||
C_RegisterFunction("noclip","noclip: toggles clipping mode", osdcmd_noclip);
|
C_RegisterFunction("noclip","noclip: toggles clipping mode", osdcmd_noclip);
|
||||||
//C_RegisterFunction("restartmap", "restartmap: restarts the current map", osdcmd_restartmap);
|
C_RegisterFunction("spawn","spawn <creaturetype>: spawns a creature",osdcmd_spawn);
|
||||||
//C_RegisterFunction("restartsound","restartsound: reinitializes the sound system",osdcmd_restartsound);
|
|
||||||
|
|
||||||
//C_RegisterFunction("spawn","spawn <picnum> [palnum] [cstat] [ang] [x y z]: spawns a sprite with the given properties",osdcmd_spawn);
|
|
||||||
|
|
||||||
C_RegisterFunction("warptocoords","warptocoords [x] [y] [z] [ang] (optional) [horiz] (optional): warps the player to the specified coordinates",osdcmd_warptocoords);
|
C_RegisterFunction("warptocoords","warptocoords [x] [y] [z] [ang] (optional) [horiz] (optional): warps the player to the specified coordinates",osdcmd_warptocoords);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in a new issue