mirror of https://github.com/stella-emu/stella.git
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:
parent
9263e7c62f
commit
d7bcde29dc
|
@ -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:
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue