mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-11 18:50:46 +00:00
Merge branch 'master' of https://github.com/coelckers/Raze
This commit is contained in:
commit
b8ac5aea84
6 changed files with 19 additions and 23 deletions
|
@ -17,9 +17,7 @@ class CompositeSavegameWriter
|
||||||
public:
|
public:
|
||||||
void Clear()
|
void Clear()
|
||||||
{
|
{
|
||||||
subfiles.Reset();
|
subfiles.DeleteAndClear();
|
||||||
subfilenames.Reset();
|
|
||||||
isCompressed.Reset();
|
|
||||||
}
|
}
|
||||||
void SetFileName(const char* fn)
|
void SetFileName(const char* fn)
|
||||||
{
|
{
|
||||||
|
|
|
@ -717,7 +717,6 @@ class DTextEnterMenu : public DMenu
|
||||||
|
|
||||||
FString mEnterString;
|
FString mEnterString;
|
||||||
int mEnterSize;
|
int mEnterSize;
|
||||||
int mEnterPos;
|
|
||||||
bool mInputGridOkay;
|
bool mInputGridOkay;
|
||||||
int InputGridX;
|
int InputGridX;
|
||||||
int InputGridY;
|
int InputGridY;
|
||||||
|
|
|
@ -67,7 +67,7 @@ DTextEnterMenu::DTextEnterMenu(DMenu *parent, FFont *dpf, FString textbuffer, in
|
||||||
: DMenu(parent)
|
: DMenu(parent)
|
||||||
{
|
{
|
||||||
mEnterString = textbuffer;
|
mEnterString = textbuffer;
|
||||||
mEnterPos = maxlen;
|
mEnterSize = maxlen;
|
||||||
mInputGridOkay = (showgrid && (m_showinputgrid == 0)) || (m_showinputgrid >= 1);
|
mInputGridOkay = (showgrid && (m_showinputgrid == 0)) || (m_showinputgrid >= 1);
|
||||||
if (mEnterString.Len() > 0)
|
if (mEnterString.Len() > 0)
|
||||||
{
|
{
|
||||||
|
@ -116,7 +116,7 @@ bool DTextEnterMenu::Responder(event_t *ev)
|
||||||
char ch = (char)ev->data1;
|
char ch = (char)ev->data1;
|
||||||
if ((ev->subtype == EV_GUI_KeyDown || ev->subtype == EV_GUI_KeyRepeat) && ch == '\b')
|
if ((ev->subtype == EV_GUI_KeyDown || ev->subtype == EV_GUI_KeyRepeat) && ch == '\b')
|
||||||
{
|
{
|
||||||
if (mEnterPos > 0)
|
if (mEnterString.Len() > 0)
|
||||||
{
|
{
|
||||||
mEnterString.DeleteLastCharacter();
|
mEnterString.DeleteLastCharacter();
|
||||||
}
|
}
|
||||||
|
|
|
@ -979,6 +979,13 @@ void mysetbrightness(char nBrightness)
|
||||||
g_visibility = 2048 - (nBrightness << 9);
|
g_visibility = 2048 - (nBrightness << 9);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Replicate original DOS EXE behaviour when pointer is null
|
||||||
|
static const char *safeStrtok(char *s, const char *d)
|
||||||
|
{
|
||||||
|
const char *r = strtok(s, d);
|
||||||
|
return r ? r : "";
|
||||||
|
}
|
||||||
|
|
||||||
void CheckKeys()
|
void CheckKeys()
|
||||||
{
|
{
|
||||||
if (buttonMap.ButtonDown(gamefunc_Enlarge_Screen))
|
if (buttonMap.ButtonDown(gamefunc_Enlarge_Screen))
|
||||||
|
@ -1074,21 +1081,16 @@ void CheckKeys()
|
||||||
|
|
||||||
if (ch == asc_Enter)
|
if (ch == asc_Enter)
|
||||||
{
|
{
|
||||||
char *pToken = strtok(sHollyStr, " ");
|
const char *pToken = safeStrtok(sHollyStr, " ");
|
||||||
|
|
||||||
if (nStringLen == 0 || pToken == NULL) // bjd - added this check. watcom allows passing NULL to strcmp so the below checks will all fail OK on DOS but will cause a crash on Windows
|
if (!strcmp(pToken, "GOTO"))
|
||||||
{
|
|
||||||
bHolly = kFalse;
|
|
||||||
StatusMessage(1, " ");
|
|
||||||
}
|
|
||||||
else if (!strcmp(pToken, "GOTO"))
|
|
||||||
{
|
{
|
||||||
// move player to X, Y coordinates
|
// move player to X, Y coordinates
|
||||||
int nSprite = PlayerList[0].nSprite;
|
int nSprite = PlayerList[0].nSprite;
|
||||||
|
|
||||||
pToken = strtok(NULL, ",");
|
pToken = safeStrtok(NULL, ",");
|
||||||
sprite[nSprite].x = atoi(pToken);
|
sprite[nSprite].x = atoi(pToken);
|
||||||
pToken = strtok(NULL, ",");
|
pToken = safeStrtok(NULL, ",");
|
||||||
sprite[nSprite].y = atoi(pToken);
|
sprite[nSprite].y = atoi(pToken);
|
||||||
|
|
||||||
setsprite(nSprite, &sprite[nSprite].pos);
|
setsprite(nSprite, &sprite[nSprite].pos);
|
||||||
|
@ -1096,14 +1098,9 @@ void CheckKeys()
|
||||||
}
|
}
|
||||||
else if (!strcmp(pToken, "LEVEL"))
|
else if (!strcmp(pToken, "LEVEL"))
|
||||||
{
|
{
|
||||||
pToken = strtok(NULL, " ");
|
pToken = safeStrtok(NULL, " ");
|
||||||
if (pToken) {
|
|
||||||
levelnew = atoi(pToken);
|
levelnew = atoi(pToken);
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
levelnew = 0; // replicate original DOS EXE behaviour when no level number is specified.
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (!strcmp(pToken, "DOORS"))
|
else if (!strcmp(pToken, "DOORS"))
|
||||||
{
|
{
|
||||||
for (int i = 0; i < kMaxChannels; i++)
|
for (int i = 0; i < kMaxChannels; i++)
|
||||||
|
@ -1126,7 +1123,7 @@ void CheckKeys()
|
||||||
// i = nNetPlayerCount;
|
// i = nNetPlayerCount;
|
||||||
if (!nNetPlayerCount)
|
if (!nNetPlayerCount)
|
||||||
{
|
{
|
||||||
pToken = strtok(NULL, " ");
|
pToken = safeStrtok(NULL, " ");
|
||||||
switch (atoi(pToken))
|
switch (atoi(pToken))
|
||||||
{
|
{
|
||||||
// TODO - enums?
|
// TODO - enums?
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 83 KiB After Width: | Height: | Size: 129 KiB |
|
@ -2605,11 +2605,13 @@ static saveable_data saveable_ninja_data[] =
|
||||||
SAVE_DATA(sg_NinjaGrabThroat),
|
SAVE_DATA(sg_NinjaGrabThroat),
|
||||||
SAVE_DATA(s_NinjaDie),
|
SAVE_DATA(s_NinjaDie),
|
||||||
SAVE_DATA(s_NinjaDieSliced),
|
SAVE_DATA(s_NinjaDieSliced),
|
||||||
|
SAVE_DATA(s_NinjaDieSlicedHack),
|
||||||
SAVE_DATA(s_NinjaDead),
|
SAVE_DATA(s_NinjaDead),
|
||||||
SAVE_DATA(s_NinjaDeathJump),
|
SAVE_DATA(s_NinjaDeathJump),
|
||||||
SAVE_DATA(s_NinjaDeathFall),
|
SAVE_DATA(s_NinjaDeathFall),
|
||||||
SAVE_DATA(sg_NinjaDie),
|
SAVE_DATA(sg_NinjaDie),
|
||||||
SAVE_DATA(sg_NinjaDieSliced),
|
SAVE_DATA(sg_NinjaDieSliced),
|
||||||
|
SAVE_DATA(sg_NinjaDieSlicedHack),
|
||||||
SAVE_DATA(sg_NinjaDead),
|
SAVE_DATA(sg_NinjaDead),
|
||||||
SAVE_DATA(sg_NinjaDeathJump),
|
SAVE_DATA(sg_NinjaDeathJump),
|
||||||
SAVE_DATA(sg_NinjaDeathFall),
|
SAVE_DATA(sg_NinjaDeathFall),
|
||||||
|
|
Loading…
Reference in a new issue