Add verification screens for deleting saves

git-svn-id: https://svn.eduke32.com/eduke32@6750 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
hendricks266 2018-03-08 03:55:45 +00:00
parent 10d67bdf9e
commit 328fec27fb
2 changed files with 73 additions and 13 deletions

View file

@ -1415,11 +1415,14 @@ static MenuPanel_t M_CREDITS5 = { "About " APPNAME, MENU_CREDITS4, MA_Return, ME
#define CURSOR_CENTER_3LINE { MENU_MARGIN_CENTER<<16, 129<<16, } #define CURSOR_CENTER_3LINE { MENU_MARGIN_CENTER<<16, 129<<16, }
#define CURSOR_BOTTOMRIGHT { 304<<16, 186<<16, } #define CURSOR_BOTTOMRIGHT { 304<<16, 186<<16, }
static MenuVerify_t M_SAVECLEANVERIFY = { CURSOR_CENTER_2LINE, MENU_SAVESETUP, MA_None, };
static MenuVerify_t M_QUIT = { CURSOR_CENTER_2LINE, MENU_CLOSE, MA_None, }; static MenuVerify_t M_QUIT = { CURSOR_CENTER_2LINE, MENU_CLOSE, MA_None, };
static MenuVerify_t M_QUITTOTITLE = { CURSOR_CENTER_2LINE, MENU_CLOSE, MA_None, }; static MenuVerify_t M_QUITTOTITLE = { CURSOR_CENTER_2LINE, MENU_CLOSE, MA_None, };
static MenuVerify_t M_LOADVERIFY = { CURSOR_CENTER_3LINE, MENU_CLOSE, MA_None, }; static MenuVerify_t M_LOADVERIFY = { CURSOR_CENTER_3LINE, MENU_CLOSE, MA_None, };
static MenuVerify_t M_LOADDELVERIFY = { CURSOR_CENTER_3LINE, MENU_CLOSE, MA_None, };
static MenuVerify_t M_NEWVERIFY = { CURSOR_CENTER_2LINE, MENU_EPISODE, MA_Advance, }; static MenuVerify_t M_NEWVERIFY = { CURSOR_CENTER_2LINE, MENU_EPISODE, MA_Advance, };
static MenuVerify_t M_SAVEVERIFY = { CURSOR_CENTER_2LINE, MENU_SAVE, MA_None, }; static MenuVerify_t M_SAVEVERIFY = { CURSOR_CENTER_2LINE, MENU_SAVE, MA_None, };
static MenuVerify_t M_SAVEDELVERIFY = { CURSOR_CENTER_3LINE, MENU_SAVE, MA_None, };
static MenuVerify_t M_RESETPLAYER = { CURSOR_CENTER_3LINE, MENU_CLOSE, MA_None, }; static MenuVerify_t M_RESETPLAYER = { CURSOR_CENTER_3LINE, MENU_CLOSE, MA_None, };
static MenuMessage_t M_NETWAITMASTER = { CURSOR_BOTTOMRIGHT, MENU_NULL, MA_None, }; static MenuMessage_t M_NETWAITMASTER = { CURSOR_BOTTOMRIGHT, MENU_NULL, MA_None, };
@ -1486,6 +1489,7 @@ static Menu_t Menus[] = {
{ &M_SOUND, MENU_SOUND_INGAME, MENU_CLOSE, MA_Return, Menu }, { &M_SOUND, MENU_SOUND_INGAME, MENU_CLOSE, MA_Return, Menu },
{ &M_ADVSOUND, MENU_ADVSOUND, MENU_SOUND, MA_Return, Menu }, { &M_ADVSOUND, MENU_ADVSOUND, MENU_SOUND, MA_Return, Menu },
{ &M_SAVESETUP, MENU_SAVESETUP, MENU_OPTIONS, MA_Return, Menu }, { &M_SAVESETUP, MENU_SAVESETUP, MENU_OPTIONS, MA_Return, Menu },
{ &M_SAVECLEANVERIFY, MENU_SAVECLEANVERIFY, MENU_SAVESETUP, MA_None, Verify },
#ifdef EDUKE32_SIMPLE_MENU #ifdef EDUKE32_SIMPLE_MENU
{ &M_CHEATS, MENU_CHEATS, MENU_OPTIONS, MA_Return, Menu }, { &M_CHEATS, MENU_CHEATS, MENU_OPTIONS, MA_Return, Menu },
#else #else
@ -1500,8 +1504,10 @@ static Menu_t Menus[] = {
{ &M_CREDITS4, MENU_CREDITS4, MENU_MAIN, MA_Return, Panel }, { &M_CREDITS4, MENU_CREDITS4, MENU_MAIN, MA_Return, Panel },
{ &M_CREDITS5, MENU_CREDITS5, MENU_MAIN, MA_Return, Panel }, { &M_CREDITS5, MENU_CREDITS5, MENU_MAIN, MA_Return, Panel },
{ &M_LOADVERIFY, MENU_LOADVERIFY, MENU_LOAD, MA_None, Verify }, { &M_LOADVERIFY, MENU_LOADVERIFY, MENU_LOAD, MA_None, Verify },
{ &M_NEWVERIFY, MENU_NEWVERIFY, MENU_MAIN, MA_Return, Verify }, { &M_LOADDELVERIFY, MENU_LOADDELVERIFY, MENU_LOAD, MA_None, Verify },
{ &M_NEWVERIFY, MENU_NEWVERIFY, MENU_PREVIOUS, MA_Return, Verify },
{ &M_SAVEVERIFY, MENU_SAVEVERIFY, MENU_SAVE, MA_None, Verify }, { &M_SAVEVERIFY, MENU_SAVEVERIFY, MENU_SAVE, MA_None, Verify },
{ &M_SAVEDELVERIFY, MENU_SAVEDELVERIFY, MENU_SAVE, MA_None, Verify },
{ &M_ADULTPASSWORD, MENU_ADULTPASSWORD, MENU_GAMESETUP, MA_None, TextForm }, { &M_ADULTPASSWORD, MENU_ADULTPASSWORD, MENU_GAMESETUP, MA_None, TextForm },
{ &M_RESETPLAYER, MENU_RESETPLAYER, MENU_CLOSE, MA_None, Verify }, { &M_RESETPLAYER, MENU_RESETPLAYER, MENU_CLOSE, MA_None, Verify },
{ &M_BUYDUKE, MENU_BUYDUKE, MENU_EPISODE, MA_Return, Message }, { &M_BUYDUKE, MENU_BUYDUKE, MENU_EPISODE, MA_Return, Message },
@ -2342,6 +2348,15 @@ static void Menu_PreDraw(MenuID_t cm, MenuEntry_t *entry, const vec2_t origin)
break; break;
#endif #endif
case MENU_SAVECLEANVERIFY:
fade_screen_black(1);
mgametextcenter(origin.x, origin.y + (90<<16), "Delete obsolete saves?"
#ifndef EDUKE32_ANDROID_MENU
"\n(Y/N)"
#endif
);
break;
case MENU_LOADVERIFY: case MENU_LOADVERIFY:
{ {
fade_screen_black(1); fade_screen_black(1);
@ -2376,6 +2391,20 @@ static void Menu_PreDraw(MenuID_t cm, MenuEntry_t *entry, const vec2_t origin)
); );
break; break;
case MENU_LOADDELVERIFY:
case MENU_SAVEDELVERIFY:
{
fade_screen_black(1);
menusave_t & msv = cm == MENU_LOADDELVERIFY ? g_menusaves[M_LOAD.currentEntry] : g_menusaves[M_SAVE.currentEntry-1];
Bsprintf(tempbuf, "Delete saved game:\n\"%s\""
#ifndef EDUKE32_ANDROID_MENU
"\n(Y/N)"
#endif
, msv.brief.name);
mgametextcenter(origin.x, origin.y + (90<<16), tempbuf);
break;
}
case MENU_NEWVERIFY: case MENU_NEWVERIFY:
fade_screen_black(1); fade_screen_black(1);
mgametextcenter(origin.x, origin.y + (90<<16), "Abort this game?" mgametextcenter(origin.x, origin.y + (90<<16), "Abort this game?"
@ -2703,11 +2732,7 @@ static void Menu_PreInput(MenuEntry_t *entry)
{ {
KB_ClearKeyDown(sc_Delete); KB_ClearKeyDown(sc_Delete);
if ((unsigned)M_LOAD.currentEntry < g_nummenusaves) if ((unsigned)M_LOAD.currentEntry < g_nummenusaves)
{ Menu_Change(MENU_LOADDELVERIFY);
G_DeleteSave(g_menusaves[M_LOAD.currentEntry].brief);
Menu_LoadReadHeaders();
M_LOAD.currentEntry = clamp(M_LOAD.currentEntry, 0, (int32_t)g_nummenusaves-1);
}
} }
break; break;
case MENU_SAVE: case MENU_SAVE:
@ -2715,11 +2740,7 @@ static void Menu_PreInput(MenuEntry_t *entry)
{ {
KB_ClearKeyDown(sc_Delete); KB_ClearKeyDown(sc_Delete);
if (0 < M_SAVE.currentEntry && M_SAVE.currentEntry <= (int32_t)g_nummenusaves) if (0 < M_SAVE.currentEntry && M_SAVE.currentEntry <= (int32_t)g_nummenusaves)
{ Menu_Change(MENU_SAVEDELVERIFY);
G_DeleteSave(g_menusaves[M_SAVE.currentEntry-1].brief);
Menu_SaveReadHeaders();
M_SAVE.currentEntry = clamp(M_SAVE.currentEntry, 0, (int32_t)g_nummenusaves);
}
} }
break; break;
@ -3029,7 +3050,7 @@ static void Menu_EntryLinkActivate(MenuEntry_t *entry)
} }
else if (entry == &ME_SAVESETUP_CLEANUP) else if (entry == &ME_SAVESETUP_CLEANUP)
{ {
G_DeleteOldSaves(); Menu_Change(MENU_SAVECLEANVERIFY);
} }
else if (entry == &ME_COLCORR_RESET) else if (entry == &ME_COLCORR_RESET)
{ {
@ -3420,6 +3441,13 @@ static void Menu_Verify(int32_t input)
{ {
switch (g_currentMenu) switch (g_currentMenu)
{ {
case MENU_SAVECLEANVERIFY:
if (input)
{
G_DeleteOldSaves();
}
break;
case MENU_RESETPLAYER: case MENU_RESETPLAYER:
if (input) if (input)
{ {
@ -3477,6 +3505,23 @@ static void Menu_Verify(int32_t input)
} }
break; break;
case MENU_LOADDELVERIFY:
if (input)
{
G_DeleteSave(g_menusaves[M_LOAD.currentEntry].brief);
Menu_LoadReadHeaders();
M_LOAD.currentEntry = clamp(M_LOAD.currentEntry, 0, (int32_t)g_nummenusaves-1);
}
break;
case MENU_SAVEDELVERIFY:
if (input)
{
G_DeleteSave(g_menusaves[M_SAVE.currentEntry-1].brief);
Menu_SaveReadHeaders();
M_SAVE.currentEntry = clamp(M_SAVE.currentEntry, 0, (int32_t)g_nummenusaves);
}
break;
case MENU_QUIT: case MENU_QUIT:
case MENU_QUIT_INGAME: case MENU_QUIT_INGAME:
if (input) if (input)
@ -3933,7 +3978,7 @@ static void Menu_AboutToStartDisplaying(Menu_t * m)
break; break;
case MENU_SAVE: case MENU_SAVE:
if (g_previousMenu == MENU_SAVEVERIFY) if (g_previousMenu == MENU_SAVEVERIFY || g_previousMenu == MENU_SAVEDELVERIFY)
break; break;
Menu_SaveReadHeaders(); Menu_SaveReadHeaders();
@ -4064,6 +4109,13 @@ int Menu_Change(MenuID_t cm)
if (search == NULL) if (search == NULL)
return 0; // intentional, so that users don't use any random value as "don't change" return 0; // intentional, so that users don't use any random value as "don't change"
// security
if (search->type == Verify &&
search->parentID != MENU_PREVIOUS &&
search->parentID != MENU_CLOSE &&
search->parentID != g_currentMenu)
return 1;
m_previousMenu = m_currentMenu; m_previousMenu = m_currentMenu;
g_previousMenu = g_currentMenu; g_previousMenu = g_currentMenu;
m_currentMenu = search; m_currentMenu = search;
@ -4194,7 +4246,9 @@ static inline int32_t Menu_UpdateScreenOK(MenuID_t cm)
case MENU_LOAD: case MENU_LOAD:
case MENU_SAVE: case MENU_SAVE:
case MENU_LOADVERIFY: case MENU_LOADVERIFY:
case MENU_LOADDELVERIFY:
case MENU_SAVEVERIFY: case MENU_SAVEVERIFY:
case MENU_SAVEDELVERIFY:
return 0; return 0;
break; break;
default: default:
@ -5335,8 +5389,11 @@ static void Menu_Recurse(MenuID_t cm, const vec2_t origin)
{ {
switch (cm) switch (cm)
{ {
case MENU_SAVECLEANVERIFY:
case MENU_LOADVERIFY: case MENU_LOADVERIFY:
case MENU_LOADDELVERIFY:
case MENU_SAVEVERIFY: case MENU_SAVEVERIFY:
case MENU_SAVEDELVERIFY:
case MENU_ADULTPASSWORD: case MENU_ADULTPASSWORD:
case MENU_CHEATENTRY: case MENU_CHEATENTRY:
case MENU_CHEAT_WARP: case MENU_CHEAT_WARP:

View file

@ -81,6 +81,7 @@ enum MenuIndex_t {
MENU_SOUND_INGAME = 701, MENU_SOUND_INGAME = 701,
MENU_ADVSOUND = 702, MENU_ADVSOUND = 702,
MENU_SAVESETUP = 750, MENU_SAVESETUP = 750,
MENU_SAVECLEANVERIFY = 751,
MENU_CHEATS = 800, MENU_CHEATS = 800,
MENU_CHEATENTRY = 801, MENU_CHEATENTRY = 801,
MENU_CHEAT_WARP = 802, MENU_CHEAT_WARP = 802,
@ -91,8 +92,10 @@ enum MenuIndex_t {
MENU_CREDITS4 = 993, MENU_CREDITS4 = 993,
MENU_CREDITS5 = 994, MENU_CREDITS5 = 994,
MENU_LOADVERIFY = 1000, MENU_LOADVERIFY = 1000,
MENU_LOADDELVERIFY = 1100,
MENU_NEWVERIFY = 1500, MENU_NEWVERIFY = 1500,
MENU_SAVEVERIFY = 2000, MENU_SAVEVERIFY = 2000,
MENU_SAVEDELVERIFY = 2100,
MENU_ADULTPASSWORD = 10001, MENU_ADULTPASSWORD = 10001,
MENU_RESETPLAYER = 15000, MENU_RESETPLAYER = 15000,
MENU_BUYDUKE = 20000, MENU_BUYDUKE = 20000,