A different implementation of testing whether debugger can be exited.

- basically check whether the current dialog is the 'base' one (ie, the debugger window)
 - this solution is more robust, in that we don't have to modify every dialog that can appear in the debugger
This commit is contained in:
Stephen Anthony 2018-01-20 11:45:07 -03:30
parent 9263e7c62f
commit d7bcde29dc
5 changed files with 11 additions and 14 deletions

View File

@ -64,8 +64,7 @@ Debugger::Debugger(OSystem& osystem, Console& console)
mySystem(console.system()), mySystem(console.system()),
myDialog(nullptr), myDialog(nullptr),
myWidth(DebuggerDialog::kSmallFontMinW), myWidth(DebuggerDialog::kSmallFontMinW),
myHeight(DebuggerDialog::kSmallFontMinH), myHeight(DebuggerDialog::kSmallFontMinH)
myMenuMode(false)
{ {
// Init parser // Init parser
myParser = make_unique<DebuggerParser>(*this, osystem.settings()); myParser = make_unique<DebuggerParser>(*this, osystem.settings());
@ -784,6 +783,12 @@ void Debugger::unlockBankswitchState()
myConsole.cartridge().unlockBank(); myConsole.cartridge().unlockBank();
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
bool Debugger::canExit() const
{
return myDialogStack.top() == baseDialog();
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Debugger::BuiltinFunction Debugger::ourBuiltinFunctions[NUM_BUILTIN_FUNCS] = { Debugger::BuiltinFunction Debugger::ourBuiltinFunctions[NUM_BUILTIN_FUNCS] = {
// left joystick: // left joystick:

View File

@ -241,11 +241,10 @@ class Debugger : public DialogContainer
void unlockBankswitchState(); void unlockBankswitchState();
/** /**
Used to make sure that debugger cannot be exited while Options dialog is open. Answers whether the debugger can be exited. Currently this only
(ugly hack!) happens when no other dialogs are active.
*/ */
void setMenuMode(bool enable) { myMenuMode = enable; }; bool canExit() const;
bool inMenuMode() { return myMenuMode; };
private: private:
/** /**
@ -330,8 +329,6 @@ class Debugger : public DialogContainer
static BuiltinFunction ourBuiltinFunctions[NUM_BUILTIN_FUNCS]; static BuiltinFunction ourBuiltinFunctions[NUM_BUILTIN_FUNCS];
static PseudoRegister ourPseudoRegisters[NUM_PSEUDO_REGS]; static PseudoRegister ourPseudoRegisters[NUM_PSEUDO_REGS];
bool myMenuMode;
private: private:
// rewind/unwind n states // rewind/unwind n states
uInt16 windStates(uInt16 numStates, bool unwind, string& message); uInt16 windStates(uInt16 numStates, bool unwind, string& message);

View File

@ -174,7 +174,6 @@ void DebuggerDialog::handleCommand(CommandSender* sender, int cmd,
break; break;
case kDDOptionsCmd: case kDDOptionsCmd:
instance().debugger().setMenuMode(true);
myOptions->open(); myOptions->open();
loadConfig(); loadConfig();
break; break;

View File

@ -1275,7 +1275,7 @@ bool EventHandler::eventStateChange(Event::Type type)
case Event::DebuggerMode: case Event::DebuggerMode:
if(myState == EventHandlerState::EMULATION || myState == EventHandlerState::PAUSE) if(myState == EventHandlerState::EMULATION || myState == EventHandlerState::PAUSE)
enterDebugMode(); enterDebugMode();
else if(myState == EventHandlerState::DEBUGGER && !myOSystem.debugger().inMenuMode()) else if(myState == EventHandlerState::DEBUGGER && myOSystem.debugger().canExit())
leaveDebugMode(); leaveDebugMode();
else else
handled = false; handled = false;

View File

@ -36,7 +36,6 @@
#include "HelpDialog.hxx" #include "HelpDialog.hxx"
#include "AboutDialog.hxx" #include "AboutDialog.hxx"
#include "OptionsDialog.hxx" #include "OptionsDialog.hxx"
#include "Debugger.hxx"
#include "Launcher.hxx" #include "Launcher.hxx"
#ifdef CHEATCODE_SUPPORT #ifdef CHEATCODE_SUPPORT
@ -252,10 +251,7 @@ void OptionsDialog::handleCommand(CommandSender* sender, int cmd,
case kExitCmd: case kExitCmd:
if(myMode != emulator) if(myMode != emulator)
{
instance().debugger().setMenuMode(false);
close(); close();
}
else else
instance().eventHandler().leaveMenuMode(); instance().eventHandler().leaveMenuMode();
break; break;