mirror of https://github.com/stella-emu/stella.git
Several large infrastructure changes for upcoming Time Machine stuff:
- renamed Rewinder and associated dialog to TimeMachine and friends - changed EventHandler state enum to stronger 'enum class' type (and associated changes to the codebase) - moved EventHandlerState into separate class, allowing a few files to not need to include EventHandler.hxx (reduce compile dependency) - plumbed EventHandlerState::TIMEMACHINE into the codebase; still TODO is activate it and add a usable dialog)
This commit is contained in:
parent
6313c98fdc
commit
7890a94144
|
@ -227,7 +227,7 @@ uInt32 RewindManager::unwindState(uInt32 numStates)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void RewindManager::compressStates()
|
void RewindManager::compressStates()
|
||||||
{
|
{
|
||||||
uInt64 currentCycles = myOSystem.console().tia().cycles();
|
// uInt64 currentCycles = myOSystem.console().tia().cycles();
|
||||||
double expectedCycles = myInterval * myFactor * (1 + myFactor);
|
double expectedCycles = myInterval * myFactor * (1 + myFactor);
|
||||||
double maxError = 1;
|
double maxError = 1;
|
||||||
uInt32 idx = myStateList.size() - 2;
|
uInt32 idx = myStateList.size() - 2;
|
||||||
|
@ -302,7 +302,7 @@ string RewindManager::getUnitString(Int64 cycles)
|
||||||
stringstream result;
|
stringstream result;
|
||||||
Int32 i;
|
Int32 i;
|
||||||
|
|
||||||
cycles = abs(cycles);
|
cycles = std::abs(cycles);
|
||||||
|
|
||||||
for(i = 0; i < NUM_UNITS - 1; ++i)
|
for(i = 0; i < NUM_UNITS - 1; ++i)
|
||||||
{
|
{
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include "Version.hxx"
|
#include "Version.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "FSNode.hxx"
|
#include "FSNode.hxx"
|
||||||
#include "Settings.hxx"
|
#include "Settings.hxx"
|
||||||
#include "DebuggerDialog.hxx"
|
#include "DebuggerDialog.hxx"
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
|
|
||||||
class OSystem;
|
class OSystem;
|
||||||
class Console;
|
class Console;
|
||||||
|
class EventHandler;
|
||||||
class TiaInfoWidget;
|
class TiaInfoWidget;
|
||||||
class TiaOutputWidget;
|
class TiaOutputWidget;
|
||||||
class TiaZoomWidget;
|
class TiaZoomWidget;
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include "Dialog.hxx"
|
#include "Dialog.hxx"
|
||||||
#include "Font.hxx"
|
#include "Font.hxx"
|
||||||
#include "Debugger.hxx"
|
#include "Debugger.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
#include "FBSurface.hxx"
|
#include "FBSurface.hxx"
|
||||||
#include "DataGridWidget.hxx"
|
#include "DataGridWidget.hxx"
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
#include "Dialog.hxx"
|
#include "Dialog.hxx"
|
||||||
#include "Settings.hxx"
|
#include "Settings.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "TabWidget.hxx"
|
#include "TabWidget.hxx"
|
||||||
#include "TiaInfoWidget.hxx"
|
#include "TiaInfoWidget.hxx"
|
||||||
#include "TiaOutputWidget.hxx"
|
#include "TiaOutputWidget.hxx"
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
#include "DiStella.hxx"
|
#include "DiStella.hxx"
|
||||||
#include "PackedBitArray.hxx"
|
#include "PackedBitArray.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "FBSurface.hxx"
|
#include "FBSurface.hxx"
|
||||||
#include "Font.hxx"
|
#include "Font.hxx"
|
||||||
#include "ScrollBarWidget.hxx"
|
#include "ScrollBarWidget.hxx"
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
#include "ToggleWidget.hxx"
|
#include "ToggleWidget.hxx"
|
||||||
|
|
||||||
|
|
|
@ -1008,11 +1008,11 @@ void Console::attachDebugger(Debugger& dbg)
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void Console::stateChanged(EventHandler::State state)
|
void Console::stateChanged(EventHandlerState state)
|
||||||
{
|
{
|
||||||
// For now, only the CompuMate cares about state changes
|
// For now, only the CompuMate cares about state changes
|
||||||
if(myCMHandler)
|
if(myCMHandler)
|
||||||
myCMHandler->enableKeyHandling(state == EventHandler::S_EMULATE);
|
myCMHandler->enableKeyHandling(state == EventHandlerState::EMULATION);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -34,6 +34,7 @@ class Debugger;
|
||||||
#include "TIATypes.hxx"
|
#include "TIATypes.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
#include "Serializable.hxx"
|
#include "Serializable.hxx"
|
||||||
|
#include "EventHandlerConstants.hxx"
|
||||||
#include "NTSCFilter.hxx"
|
#include "NTSCFilter.hxx"
|
||||||
#include "frame-manager/AbstractFrameManager.hxx"
|
#include "frame-manager/AbstractFrameManager.hxx"
|
||||||
|
|
||||||
|
@ -184,7 +185,7 @@ class Console : public Serializable
|
||||||
/**
|
/**
|
||||||
Informs the Console of a change in EventHandler state.
|
Informs the Console of a change in EventHandler state.
|
||||||
*/
|
*/
|
||||||
void stateChanged(EventHandler::State state);
|
void stateChanged(EventHandlerState state);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "TIASurface.hxx"
|
#include "TIASurface.hxx"
|
||||||
#include "FSNode.hxx"
|
#include "FSNode.hxx"
|
||||||
#include "Launcher.hxx"
|
#include "Launcher.hxx"
|
||||||
|
#include "TimeMachine.hxx"
|
||||||
#include "Menu.hxx"
|
#include "Menu.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "Joystick.hxx"
|
#include "Joystick.hxx"
|
||||||
|
@ -60,7 +61,7 @@
|
||||||
EventHandler::EventHandler(OSystem& osystem)
|
EventHandler::EventHandler(OSystem& osystem)
|
||||||
: myOSystem(osystem),
|
: myOSystem(osystem),
|
||||||
myOverlay(nullptr),
|
myOverlay(nullptr),
|
||||||
myState(S_NONE),
|
myState(EventHandlerState::NONE),
|
||||||
myAllowAllDirectionsFlag(false),
|
myAllowAllDirectionsFlag(false),
|
||||||
myFryingFlag(false),
|
myFryingFlag(false),
|
||||||
myUseCtrlKeyFlag(true),
|
myUseCtrlKeyFlag(true),
|
||||||
|
@ -124,7 +125,7 @@ void EventHandler::initialize()
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void EventHandler::reset(State state)
|
void EventHandler::reset(EventHandlerState state)
|
||||||
{
|
{
|
||||||
setEventState(state);
|
setEventState(state);
|
||||||
myOSystem.state().reset();
|
myOSystem.state().reset();
|
||||||
|
@ -213,7 +214,7 @@ void EventHandler::poll(uInt64 time)
|
||||||
|
|
||||||
// Update controllers and console switches, and in general all other things
|
// Update controllers and console switches, and in general all other things
|
||||||
// related to emulation
|
// related to emulation
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
{
|
{
|
||||||
myOSystem.console().riot().update();
|
myOSystem.console().riot().update();
|
||||||
|
|
||||||
|
@ -294,31 +295,31 @@ void EventHandler::handleKeyEvent(StellaKey key, StellaMod mod, bool state)
|
||||||
myOSystem.frameBuffer().toggleFullscreen();
|
myOSystem.frameBuffer().toggleFullscreen();
|
||||||
}
|
}
|
||||||
// state rewinding must work in pause mode too
|
// state rewinding must work in pause mode too
|
||||||
else if(myState == S_EMULATE || myState == S_PAUSE)
|
else if(myState == EventHandlerState::EMULATION || myState == EventHandlerState::PAUSE)
|
||||||
{
|
{
|
||||||
switch(key)
|
switch(key)
|
||||||
{
|
{
|
||||||
case KBDK_LEFT: // Alt-left(-shift) rewinds 1(10) states
|
case KBDK_LEFT: // Alt-left(-shift) rewinds 1(10) states
|
||||||
myOSystem.frameBuffer().setPauseDelay();
|
myOSystem.frameBuffer().setPauseDelay();
|
||||||
setEventState(S_PAUSE);
|
setEventState(EventHandlerState::PAUSE);
|
||||||
myOSystem.state().rewindState((kbdShift(mod) && state) ? 10 : 1);
|
myOSystem.state().rewindState((kbdShift(mod) && state) ? 10 : 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KBDK_RIGHT: // Alt-right(-shift) unwinds 1(10) states
|
case KBDK_RIGHT: // Alt-right(-shift) unwinds 1(10) states
|
||||||
myOSystem.frameBuffer().setPauseDelay();
|
myOSystem.frameBuffer().setPauseDelay();
|
||||||
setEventState(S_PAUSE);
|
setEventState(EventHandlerState::PAUSE);
|
||||||
myOSystem.state().unwindState((kbdShift(mod) && state) ? 10 : 1);
|
myOSystem.state().unwindState((kbdShift(mod) && state) ? 10 : 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KBDK_DOWN: // Alt-down rewinds to start of list
|
case KBDK_DOWN: // Alt-down rewinds to start of list
|
||||||
myOSystem.frameBuffer().setPauseDelay();
|
myOSystem.frameBuffer().setPauseDelay();
|
||||||
setEventState(S_PAUSE);
|
setEventState(EventHandlerState::PAUSE);
|
||||||
myOSystem.state().rewindState(1000);
|
myOSystem.state().rewindState(1000);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KBDK_UP: // Alt-up rewinds to end of list
|
case KBDK_UP: // Alt-up rewinds to end of list
|
||||||
myOSystem.frameBuffer().setPauseDelay();
|
myOSystem.frameBuffer().setPauseDelay();
|
||||||
setEventState(S_PAUSE);
|
setEventState(EventHandlerState::PAUSE);
|
||||||
myOSystem.state().unwindState(1000);
|
myOSystem.state().unwindState(1000);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -328,7 +329,7 @@ void EventHandler::handleKeyEvent(StellaKey key, StellaMod mod, bool state)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// These only work when in emulation mode
|
// These only work when in emulation mode
|
||||||
if(!handled && myState == S_EMULATE)
|
if(!handled && myState == EventHandlerState::EMULATION)
|
||||||
{
|
{
|
||||||
handled = true;
|
handled = true;
|
||||||
switch(key)
|
switch(key)
|
||||||
|
@ -538,7 +539,7 @@ void EventHandler::handleKeyEvent(StellaKey key, StellaMod mod, bool state)
|
||||||
handleEvent(Event::Quit, 1);
|
handleEvent(Event::Quit, 1);
|
||||||
}
|
}
|
||||||
// These only work when in emulation mode
|
// These only work when in emulation mode
|
||||||
else if(myState == S_EMULATE)
|
else if(myState == EventHandlerState::EMULATION)
|
||||||
{
|
{
|
||||||
switch(key)
|
switch(key)
|
||||||
{
|
{
|
||||||
|
@ -622,11 +623,11 @@ void EventHandler::handleKeyEvent(StellaKey key, StellaMod mod, bool state)
|
||||||
// Otherwise, let the event handler deal with it
|
// Otherwise, let the event handler deal with it
|
||||||
switch(myState)
|
switch(myState)
|
||||||
{
|
{
|
||||||
case S_EMULATE:
|
case EventHandlerState::EMULATION:
|
||||||
handleEvent(myKeyTable[key][kEmulationMode], state);
|
handleEvent(myKeyTable[key][kEmulationMode], state);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case S_PAUSE:
|
case EventHandlerState::PAUSE:
|
||||||
switch(myKeyTable[key][kEmulationMode])
|
switch(myKeyTable[key][kEmulationMode])
|
||||||
{
|
{
|
||||||
case Event::TakeSnapshot:
|
case Event::TakeSnapshot:
|
||||||
|
@ -650,7 +651,7 @@ void EventHandler::handleKeyEvent(StellaKey key, StellaMod mod, bool state)
|
||||||
void EventHandler::handleMouseMotionEvent(int x, int y, int xrel, int yrel, int button)
|
void EventHandler::handleMouseMotionEvent(int x, int y, int xrel, int yrel, int button)
|
||||||
{
|
{
|
||||||
// Determine which mode we're in, then send the event to the appropriate place
|
// Determine which mode we're in, then send the event to the appropriate place
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
{
|
{
|
||||||
if(!mySkipMouseMotion)
|
if(!mySkipMouseMotion)
|
||||||
{
|
{
|
||||||
|
@ -667,7 +668,7 @@ void EventHandler::handleMouseMotionEvent(int x, int y, int xrel, int yrel, int
|
||||||
void EventHandler::handleMouseButtonEvent(MouseButton b, int x, int y)
|
void EventHandler::handleMouseButtonEvent(MouseButton b, int x, int y)
|
||||||
{
|
{
|
||||||
// Determine which mode we're in, then send the event to the appropriate place
|
// Determine which mode we're in, then send the event to the appropriate place
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
{
|
{
|
||||||
switch(b)
|
switch(b)
|
||||||
{
|
{
|
||||||
|
@ -706,7 +707,7 @@ void EventHandler::handleJoyEvent(int stick, int button, uInt8 state)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Determine which mode we're in, then send the event to the appropriate place
|
// Determine which mode we're in, then send the event to the appropriate place
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
handleEvent(joy->btnTable[button][kEmulationMode], state);
|
handleEvent(joy->btnTable[button][kEmulationMode], state);
|
||||||
else if(myOverlay)
|
else if(myOverlay)
|
||||||
myOverlay->handleJoyEvent(stick, button, state);
|
myOverlay->handleJoyEvent(stick, button, state);
|
||||||
|
@ -726,7 +727,7 @@ void EventHandler::handleJoyEvent(int stick, int button, uInt8 state)
|
||||||
// The 'type-4' here refers to the fact that 'StellaJoystick::JT_2600DAPTOR_LEFT'
|
// The 'type-4' here refers to the fact that 'StellaJoystick::JT_2600DAPTOR_LEFT'
|
||||||
// and 'StellaJoystick::JT_2600DAPTOR_RIGHT' are at index 4 and 5 in the JoyType
|
// and 'StellaJoystick::JT_2600DAPTOR_RIGHT' are at index 4 and 5 in the JoyType
|
||||||
// enum; subtracting four gives us Controller 0 and 1
|
// enum; subtracting four gives us Controller 0 and 1
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
{
|
{
|
||||||
switch(myOSystem.console().leftController().type())
|
switch(myOSystem.console().leftController().type())
|
||||||
{
|
{
|
||||||
|
@ -761,7 +762,7 @@ void EventHandler::handleJoyAxisEvent(int stick, int axis, int value)
|
||||||
switch(joy->type)
|
switch(joy->type)
|
||||||
{
|
{
|
||||||
case StellaJoystick::JT_REGULAR:
|
case StellaJoystick::JT_REGULAR:
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
{
|
{
|
||||||
// Every axis event has two associated values, negative and positive
|
// Every axis event has two associated values, negative and positive
|
||||||
Event::Type eventAxisNeg = joy->axisTable[axis][0][kEmulationMode];
|
Event::Type eventAxisNeg = joy->axisTable[axis][0][kEmulationMode];
|
||||||
|
@ -867,7 +868,7 @@ void EventHandler::handleJoyHatEvent(int stick, int hat, int value)
|
||||||
// Preprocess all hat events, converting to Stella JoyHat type
|
// Preprocess all hat events, converting to Stella JoyHat type
|
||||||
// Generate multiple equivalent hat events representing combined direction
|
// Generate multiple equivalent hat events representing combined direction
|
||||||
// when we get a diagonal hat event
|
// when we get a diagonal hat event
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
{
|
{
|
||||||
handleEvent(joy->hatTable[hat][int(JoyHat::UP)][kEmulationMode],
|
handleEvent(joy->hatTable[hat][int(JoyHat::UP)][kEmulationMode],
|
||||||
value & EVENT_HATUP_M);
|
value & EVENT_HATUP_M);
|
||||||
|
@ -913,7 +914,7 @@ void EventHandler::handleSystemEvent(SystemEvent e, int, int)
|
||||||
break;
|
break;
|
||||||
#if 0
|
#if 0
|
||||||
case EVENT_WINDOW_MINIMIZED:
|
case EVENT_WINDOW_MINIMIZED:
|
||||||
if(myState == S_EMULATE) enterMenuMode(S_MENU);
|
if(myState == EventHandlerState::EMULATION) enterMenuMode(EventHandlerState::OPTIONSMENU);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
default: // handle other events as testing requires
|
default: // handle other events as testing requires
|
||||||
|
@ -1001,8 +1002,8 @@ void EventHandler::handleEvent(Event::Type event, int state)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case Event::LauncherMode:
|
case Event::LauncherMode:
|
||||||
if((myState == S_EMULATE || myState == S_CMDMENU ||
|
if((myState == EventHandlerState::EMULATION || myState == EventHandlerState::CMDMENU ||
|
||||||
myState == S_DEBUGGER) && state)
|
myState == EventHandlerState::DEBUGGER) && state)
|
||||||
{
|
{
|
||||||
// Go back to the launcher, or immediately quit
|
// Go back to the launcher, or immediately quit
|
||||||
if(myOSystem.settings().getBool("exitlauncher") ||
|
if(myOSystem.settings().getBool("exitlauncher") ||
|
||||||
|
@ -1218,34 +1219,34 @@ bool EventHandler::eventStateChange(Event::Type type)
|
||||||
switch(type)
|
switch(type)
|
||||||
{
|
{
|
||||||
case Event::PauseMode:
|
case Event::PauseMode:
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
setEventState(S_PAUSE);
|
setEventState(EventHandlerState::PAUSE);
|
||||||
else if(myState == S_PAUSE)
|
else if(myState == EventHandlerState::PAUSE)
|
||||||
setEventState(S_EMULATE);
|
setEventState(EventHandlerState::EMULATION);
|
||||||
else
|
else
|
||||||
handled = false;
|
handled = false;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Event::MenuMode:
|
case Event::MenuMode:
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
enterMenuMode(S_MENU);
|
enterMenuMode(EventHandlerState::OPTIONSMENU);
|
||||||
else
|
else
|
||||||
handled = false;
|
handled = false;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Event::CmdMenuMode:
|
case Event::CmdMenuMode:
|
||||||
if(myState == S_EMULATE)
|
if(myState == EventHandlerState::EMULATION)
|
||||||
enterMenuMode(S_CMDMENU);
|
enterMenuMode(EventHandlerState::CMDMENU);
|
||||||
else if(myState == S_CMDMENU)
|
else if(myState == EventHandlerState::CMDMENU)
|
||||||
leaveMenuMode();
|
leaveMenuMode();
|
||||||
else
|
else
|
||||||
handled = false;
|
handled = false;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Event::DebuggerMode:
|
case Event::DebuggerMode:
|
||||||
if(myState == S_EMULATE || myState == S_PAUSE)
|
if(myState == EventHandlerState::EMULATION || myState == EventHandlerState::PAUSE)
|
||||||
enterDebugMode();
|
enterDebugMode();
|
||||||
else if(myState == S_DEBUGGER)
|
else if(myState == EventHandlerState::DEBUGGER)
|
||||||
leaveDebugMode();
|
leaveDebugMode();
|
||||||
else
|
else
|
||||||
handled = false;
|
handled = false;
|
||||||
|
@ -2068,7 +2069,7 @@ void EventHandler::setContinuousSnapshots(uInt32 interval)
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void EventHandler::enterMenuMode(State state)
|
void EventHandler::enterMenuMode(EventHandlerState state)
|
||||||
{
|
{
|
||||||
setEventState(state);
|
setEventState(state);
|
||||||
myOverlay->reStack();
|
myOverlay->reStack();
|
||||||
|
@ -2078,7 +2079,7 @@ void EventHandler::enterMenuMode(State state)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void EventHandler::leaveMenuMode()
|
void EventHandler::leaveMenuMode()
|
||||||
{
|
{
|
||||||
setEventState(S_EMULATE);
|
setEventState(EventHandlerState::EMULATION);
|
||||||
myOSystem.sound().mute(false);
|
myOSystem.sound().mute(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2086,7 +2087,7 @@ void EventHandler::leaveMenuMode()
|
||||||
bool EventHandler::enterDebugMode()
|
bool EventHandler::enterDebugMode()
|
||||||
{
|
{
|
||||||
#ifdef DEBUGGER_SUPPORT
|
#ifdef DEBUGGER_SUPPORT
|
||||||
if(myState == S_DEBUGGER || !myOSystem.hasConsole())
|
if(myState == EventHandlerState::DEBUGGER || !myOSystem.hasConsole())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// Make sure debugger starts in a consistent state
|
// Make sure debugger starts in a consistent state
|
||||||
|
@ -2094,13 +2095,13 @@ bool EventHandler::enterDebugMode()
|
||||||
// mode, since it takes care of locking the debugger state, which will
|
// mode, since it takes care of locking the debugger state, which will
|
||||||
// probably be modified below
|
// probably be modified below
|
||||||
myOSystem.debugger().setStartState();
|
myOSystem.debugger().setStartState();
|
||||||
setEventState(S_DEBUGGER);
|
setEventState(EventHandlerState::DEBUGGER);
|
||||||
|
|
||||||
FBInitStatus fbstatus = myOSystem.createFrameBuffer();
|
FBInitStatus fbstatus = myOSystem.createFrameBuffer();
|
||||||
if(fbstatus != FBInitStatus::Success)
|
if(fbstatus != FBInitStatus::Success)
|
||||||
{
|
{
|
||||||
myOSystem.debugger().setQuitState();
|
myOSystem.debugger().setQuitState();
|
||||||
setEventState(S_EMULATE);
|
setEventState(EventHandlerState::EMULATION);
|
||||||
if(fbstatus == FBInitStatus::FailTooLarge)
|
if(fbstatus == FBInitStatus::FailTooLarge)
|
||||||
myOSystem.frameBuffer().showMessage("Debugger window too large for screen",
|
myOSystem.frameBuffer().showMessage("Debugger window too large for screen",
|
||||||
MessagePosition::BottomCenter, true);
|
MessagePosition::BottomCenter, true);
|
||||||
|
@ -2121,20 +2122,20 @@ void EventHandler::leaveDebugMode()
|
||||||
{
|
{
|
||||||
#ifdef DEBUGGER_SUPPORT
|
#ifdef DEBUGGER_SUPPORT
|
||||||
// paranoia: this should never happen:
|
// paranoia: this should never happen:
|
||||||
if(myState != S_DEBUGGER)
|
if(myState != EventHandlerState::DEBUGGER)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Make sure debugger quits in a consistent state
|
// Make sure debugger quits in a consistent state
|
||||||
myOSystem.debugger().setQuitState();
|
myOSystem.debugger().setQuitState();
|
||||||
|
|
||||||
setEventState(S_EMULATE);
|
setEventState(EventHandlerState::EMULATION);
|
||||||
myOSystem.createFrameBuffer();
|
myOSystem.createFrameBuffer();
|
||||||
myOSystem.sound().mute(false);
|
myOSystem.sound().mute(false);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void EventHandler::setEventState(State state)
|
void EventHandler::setEventState(EventHandlerState state)
|
||||||
{
|
{
|
||||||
myState = state;
|
myState = state;
|
||||||
|
|
||||||
|
@ -2146,7 +2147,7 @@ void EventHandler::setEventState(State state)
|
||||||
// keyboard acts as one large joystick with many (single) buttons
|
// keyboard acts as one large joystick with many (single) buttons
|
||||||
switch(myState)
|
switch(myState)
|
||||||
{
|
{
|
||||||
case S_EMULATE:
|
case EventHandlerState::EMULATION:
|
||||||
myOverlay = nullptr;
|
myOverlay = nullptr;
|
||||||
myOSystem.sound().mute(false);
|
myOSystem.sound().mute(false);
|
||||||
enableTextEvents(false);
|
enableTextEvents(false);
|
||||||
|
@ -2154,36 +2155,41 @@ void EventHandler::setEventState(State state)
|
||||||
myUseCtrlKeyFlag = false;
|
myUseCtrlKeyFlag = false;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case S_PAUSE:
|
case EventHandlerState::PAUSE:
|
||||||
myOverlay = nullptr;
|
myOverlay = nullptr;
|
||||||
myOSystem.sound().mute(true);
|
myOSystem.sound().mute(true);
|
||||||
enableTextEvents(false);
|
enableTextEvents(false);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case S_MENU:
|
case EventHandlerState::OPTIONSMENU:
|
||||||
myOverlay = &myOSystem.menu();
|
myOverlay = &myOSystem.menu();
|
||||||
enableTextEvents(true);
|
enableTextEvents(true);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case S_CMDMENU:
|
case EventHandlerState::CMDMENU:
|
||||||
myOverlay = &myOSystem.commandMenu();
|
myOverlay = &myOSystem.commandMenu();
|
||||||
enableTextEvents(true);
|
enableTextEvents(true);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case S_LAUNCHER:
|
case EventHandlerState::TIMEMACHINE:
|
||||||
|
myOverlay = &myOSystem.timeMachine();
|
||||||
|
enableTextEvents(true);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case EventHandlerState::LAUNCHER:
|
||||||
myOverlay = &myOSystem.launcher();
|
myOverlay = &myOSystem.launcher();
|
||||||
enableTextEvents(true);
|
enableTextEvents(true);
|
||||||
myEvent.clear();
|
myEvent.clear();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#ifdef DEBUGGER_SUPPORT
|
#ifdef DEBUGGER_SUPPORT
|
||||||
case S_DEBUGGER:
|
case EventHandlerState::DEBUGGER:
|
||||||
myOverlay = &myOSystem.debugger();
|
myOverlay = &myOSystem.debugger();
|
||||||
enableTextEvents(true);
|
enableTextEvents(true);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
default:
|
case EventHandlerState::NONE:
|
||||||
myOverlay = nullptr;
|
myOverlay = nullptr;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,17 +56,6 @@ class EventHandler
|
||||||
EventHandler(OSystem& osystem);
|
EventHandler(OSystem& osystem);
|
||||||
virtual ~EventHandler();
|
virtual ~EventHandler();
|
||||||
|
|
||||||
// Enumeration representing the different states of operation
|
|
||||||
enum State {
|
|
||||||
S_NONE,
|
|
||||||
S_EMULATE,
|
|
||||||
S_PAUSE,
|
|
||||||
S_LAUNCHER,
|
|
||||||
S_MENU,
|
|
||||||
S_CMDMENU,
|
|
||||||
S_DEBUGGER
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Returns the event object associated with this handler class.
|
Returns the event object associated with this handler class.
|
||||||
|
|
||||||
|
@ -109,16 +98,16 @@ class EventHandler
|
||||||
/**
|
/**
|
||||||
Returns the current state of the EventHandler
|
Returns the current state of the EventHandler
|
||||||
|
|
||||||
@return The State type
|
@return The EventHandlerState type
|
||||||
*/
|
*/
|
||||||
State state() const { return myState; }
|
EventHandlerState state() const { return myState; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Resets the state machine of the EventHandler to the defaults
|
Resets the state machine of the EventHandler to the defaults
|
||||||
|
|
||||||
@param state The current state to set
|
@param state The current state to set
|
||||||
*/
|
*/
|
||||||
void reset(State state);
|
void reset(EventHandlerState state);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method indicates that the system should terminate.
|
This method indicates that the system should terminate.
|
||||||
|
@ -131,7 +120,7 @@ class EventHandler
|
||||||
|
|
||||||
@param enable Whether to use the mouse to emulate controllers
|
@param enable Whether to use the mouse to emulate controllers
|
||||||
Currently, this will be one of the following values:
|
Currently, this will be one of the following values:
|
||||||
'always', 'analog', 'never'
|
'always', 'analog', 'never'
|
||||||
*/
|
*/
|
||||||
void setMouseControllerMode(const string& enable);
|
void setMouseControllerMode(const string& enable);
|
||||||
|
|
||||||
|
@ -163,7 +152,7 @@ class EventHandler
|
||||||
return (mod & KBDM_SHIFT);
|
return (mod & KBDM_SHIFT);
|
||||||
}
|
}
|
||||||
|
|
||||||
void enterMenuMode(State state);
|
void enterMenuMode(EventHandlerState state);
|
||||||
void leaveMenuMode();
|
void leaveMenuMode();
|
||||||
bool enterDebugMode();
|
bool enterDebugMode();
|
||||||
void leaveDebugMode();
|
void leaveDebugMode();
|
||||||
|
@ -519,7 +508,7 @@ class EventHandler
|
||||||
*/
|
*/
|
||||||
bool eventIsAnalog(Event::Type event) const;
|
bool eventIsAnalog(Event::Type event) const;
|
||||||
|
|
||||||
void setEventState(State state);
|
void setEventState(EventHandlerState state);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Structure used for action menu items
|
// Structure used for action menu items
|
||||||
|
@ -547,7 +536,7 @@ class EventHandler
|
||||||
Event::Type myComboTable[kComboSize][kEventsPerCombo];
|
Event::Type myComboTable[kComboSize][kEventsPerCombo];
|
||||||
|
|
||||||
// Indicates the current state of the system (ie, which mode is current)
|
// Indicates the current state of the system (ie, which mode is current)
|
||||||
State myState;
|
EventHandlerState myState;
|
||||||
|
|
||||||
// Indicates whether the joystick emulates 'impossible' directions
|
// Indicates whether the joystick emulates 'impossible' directions
|
||||||
bool myAllowAllDirectionsFlag;
|
bool myAllowAllDirectionsFlag;
|
||||||
|
|
|
@ -18,6 +18,18 @@
|
||||||
#ifndef EVENTHANDLER_CONSTANTS_HXX
|
#ifndef EVENTHANDLER_CONSTANTS_HXX
|
||||||
#define EVENTHANDLER_CONSTANTS_HXX
|
#define EVENTHANDLER_CONSTANTS_HXX
|
||||||
|
|
||||||
|
// Enumeration representing the different states of operation
|
||||||
|
enum class EventHandlerState {
|
||||||
|
NONE,
|
||||||
|
EMULATION,
|
||||||
|
TIMEMACHINE,
|
||||||
|
PAUSE,
|
||||||
|
LAUNCHER,
|
||||||
|
OPTIONSMENU,
|
||||||
|
CMDMENU,
|
||||||
|
DEBUGGER
|
||||||
|
};
|
||||||
|
|
||||||
enum class MouseButton {
|
enum class MouseButton {
|
||||||
LBUTTONDOWN,
|
LBUTTONDOWN,
|
||||||
LBUTTONUP,
|
LBUTTONUP,
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
|
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
|
||||||
#include "CommandMenu.hxx"
|
|
||||||
#include "Console.hxx"
|
#include "Console.hxx"
|
||||||
#include "EventHandler.hxx"
|
#include "EventHandler.hxx"
|
||||||
#include "Event.hxx"
|
#include "Event.hxx"
|
||||||
|
@ -28,6 +27,8 @@
|
||||||
#include "ConsoleFont.hxx"
|
#include "ConsoleFont.hxx"
|
||||||
#include "Launcher.hxx"
|
#include "Launcher.hxx"
|
||||||
#include "Menu.hxx"
|
#include "Menu.hxx"
|
||||||
|
#include "CommandMenu.hxx"
|
||||||
|
#include "TimeMachine.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "Settings.hxx"
|
#include "Settings.hxx"
|
||||||
#include "TIA.hxx"
|
#include "TIA.hxx"
|
||||||
|
@ -205,8 +206,8 @@ FBInitStatus FrameBuffer::createDisplay(const string& title,
|
||||||
myScreenSize = mode.screen;
|
myScreenSize = mode.screen;
|
||||||
|
|
||||||
// Inform TIA surface about new mode
|
// Inform TIA surface about new mode
|
||||||
if(myOSystem.eventHandler().state() != EventHandler::S_LAUNCHER &&
|
if(myOSystem.eventHandler().state() != EventHandlerState::LAUNCHER &&
|
||||||
myOSystem.eventHandler().state() != EventHandler::S_DEBUGGER)
|
myOSystem.eventHandler().state() != EventHandlerState::DEBUGGER)
|
||||||
myTIASurface->initialize(myOSystem.console(), mode);
|
myTIASurface->initialize(myOSystem.console(), mode);
|
||||||
|
|
||||||
// Did we get the requested fullscreen state?
|
// Did we get the requested fullscreen state?
|
||||||
|
@ -262,14 +263,14 @@ void FrameBuffer::update()
|
||||||
invalidate();
|
invalidate();
|
||||||
switch(myOSystem.eventHandler().state())
|
switch(myOSystem.eventHandler().state())
|
||||||
{
|
{
|
||||||
case EventHandler::S_EMULATE:
|
case EventHandlerState::EMULATION:
|
||||||
{
|
{
|
||||||
// Run the console for one frame
|
// Run the console for one frame
|
||||||
// Note that the debugger can cause a breakpoint to occur, which changes
|
// Note that the debugger can cause a breakpoint to occur, which changes
|
||||||
// the EventHandler state 'behind our back' - we need to check for that
|
// the EventHandler state 'behind our back' - we need to check for that
|
||||||
myOSystem.console().tia().update();
|
myOSystem.console().tia().update();
|
||||||
#ifdef DEBUGGER_SUPPORT
|
#ifdef DEBUGGER_SUPPORT
|
||||||
if(myOSystem.eventHandler().state() != EventHandler::S_EMULATE) break;
|
if(myOSystem.eventHandler().state() != EventHandlerState::EMULATION) break;
|
||||||
#endif
|
#endif
|
||||||
if(myOSystem.eventHandler().frying())
|
if(myOSystem.eventHandler().frying())
|
||||||
myOSystem.console().fry();
|
myOSystem.console().fry();
|
||||||
|
@ -295,10 +296,10 @@ void FrameBuffer::update()
|
||||||
myStatsMsg.surface->render();
|
myStatsMsg.surface->render();
|
||||||
}
|
}
|
||||||
myPausedCount = 0;
|
myPausedCount = 0;
|
||||||
break; // S_EMULATE
|
break; // EventHandlerState::EMULATION
|
||||||
}
|
}
|
||||||
|
|
||||||
case EventHandler::S_PAUSE:
|
case EventHandlerState::PAUSE:
|
||||||
{
|
{
|
||||||
myTIASurface->render();
|
myTIASurface->render();
|
||||||
|
|
||||||
|
@ -308,38 +309,45 @@ void FrameBuffer::update()
|
||||||
myPausedCount = uInt32(7 * myOSystem.frameRate());
|
myPausedCount = uInt32(7 * myOSystem.frameRate());
|
||||||
showMessage("Paused", MessagePosition::MiddleCenter);
|
showMessage("Paused", MessagePosition::MiddleCenter);
|
||||||
}
|
}
|
||||||
break; // S_PAUSE
|
break; // EventHandlerState::PAUSE
|
||||||
}
|
}
|
||||||
|
|
||||||
case EventHandler::S_MENU:
|
case EventHandlerState::OPTIONSMENU:
|
||||||
{
|
{
|
||||||
myTIASurface->render();
|
myTIASurface->render();
|
||||||
myOSystem.menu().draw(true);
|
myOSystem.menu().draw(true);
|
||||||
break; // S_MENU
|
break; // EventHandlerState::OPTIONSMENU
|
||||||
}
|
}
|
||||||
|
|
||||||
case EventHandler::S_CMDMENU:
|
case EventHandlerState::CMDMENU:
|
||||||
{
|
{
|
||||||
myTIASurface->render();
|
myTIASurface->render();
|
||||||
myOSystem.commandMenu().draw(true);
|
myOSystem.commandMenu().draw(true);
|
||||||
break; // S_CMDMENU
|
break; // EventHandlerState::CMDMENU
|
||||||
}
|
}
|
||||||
|
|
||||||
case EventHandler::S_LAUNCHER:
|
case EventHandlerState::TIMEMACHINE:
|
||||||
|
{
|
||||||
|
myTIASurface->render();
|
||||||
|
myOSystem.timeMachine().draw(true);
|
||||||
|
break; // EventHandlerState::TIMEMACHINE
|
||||||
|
}
|
||||||
|
|
||||||
|
case EventHandlerState::LAUNCHER:
|
||||||
{
|
{
|
||||||
myOSystem.launcher().draw(true);
|
myOSystem.launcher().draw(true);
|
||||||
break; // S_LAUNCHER
|
break; // EventHandlerState::LAUNCHER
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef DEBUGGER_SUPPORT
|
#ifdef DEBUGGER_SUPPORT
|
||||||
case EventHandler::S_DEBUGGER:
|
case EventHandlerState::DEBUGGER:
|
||||||
{
|
{
|
||||||
myOSystem.debugger().draw(true);
|
myOSystem.debugger().draw(true);
|
||||||
break; // S_DEBUGGER
|
break; // EventHandlerState::DEBUGGER
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
default:
|
case EventHandlerState::NONE:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -528,7 +536,7 @@ void FrameBuffer::setPalette(const uInt32* raw_palette)
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBuffer::stateChanged(EventHandler::State state)
|
void FrameBuffer::stateChanged(EventHandlerState state)
|
||||||
{
|
{
|
||||||
// Make sure any onscreen messages are removed
|
// Make sure any onscreen messages are removed
|
||||||
myMsg.enabled = false;
|
myMsg.enabled = false;
|
||||||
|
@ -545,8 +553,8 @@ void FrameBuffer::setFullscreen(bool enable)
|
||||||
myScreenSize = mode.screen;
|
myScreenSize = mode.screen;
|
||||||
|
|
||||||
// Inform TIA surface about new mode
|
// Inform TIA surface about new mode
|
||||||
if(myOSystem.eventHandler().state() != EventHandler::S_LAUNCHER &&
|
if(myOSystem.eventHandler().state() != EventHandlerState::LAUNCHER &&
|
||||||
myOSystem.eventHandler().state() != EventHandler::S_DEBUGGER)
|
myOSystem.eventHandler().state() != EventHandlerState::DEBUGGER)
|
||||||
myTIASurface->initialize(myOSystem.console(), mode);
|
myTIASurface->initialize(myOSystem.console(), mode);
|
||||||
|
|
||||||
// Did we get the requested fullscreen state?
|
// Did we get the requested fullscreen state?
|
||||||
|
@ -566,9 +574,9 @@ void FrameBuffer::toggleFullscreen()
|
||||||
bool FrameBuffer::changeWindowedVidMode(int direction)
|
bool FrameBuffer::changeWindowedVidMode(int direction)
|
||||||
{
|
{
|
||||||
#ifdef WINDOWED_SUPPORT
|
#ifdef WINDOWED_SUPPORT
|
||||||
EventHandler::State state = myOSystem.eventHandler().state();
|
EventHandlerState state = myOSystem.eventHandler().state();
|
||||||
bool tiaMode = (state != EventHandler::S_DEBUGGER &&
|
bool tiaMode = (state != EventHandlerState::DEBUGGER &&
|
||||||
state != EventHandler::S_LAUNCHER);
|
state != EventHandlerState::LAUNCHER);
|
||||||
|
|
||||||
// Ignore any attempts to change video size while in invalid modes
|
// Ignore any attempts to change video size while in invalid modes
|
||||||
if(!tiaMode || fullScreen())
|
if(!tiaMode || fullScreen())
|
||||||
|
@ -605,7 +613,7 @@ void FrameBuffer::setCursorState()
|
||||||
// Always grab mouse in emulation (if enabled) and emulating a controller
|
// Always grab mouse in emulation (if enabled) and emulating a controller
|
||||||
// that always uses the mouse
|
// that always uses the mouse
|
||||||
bool emulation =
|
bool emulation =
|
||||||
myOSystem.eventHandler().state() == EventHandler::S_EMULATE;
|
myOSystem.eventHandler().state() == EventHandlerState::EMULATION;
|
||||||
bool analog = myOSystem.hasConsole() ?
|
bool analog = myOSystem.hasConsole() ?
|
||||||
(myOSystem.eventHandler().controllerIsAnalog(Controller::Left) ||
|
(myOSystem.eventHandler().controllerIsAnalog(Controller::Left) ||
|
||||||
myOSystem.eventHandler().controllerIsAnalog(Controller::Right)) : false;
|
myOSystem.eventHandler().controllerIsAnalog(Controller::Right)) : false;
|
||||||
|
@ -669,9 +677,9 @@ void FrameBuffer::setAvailableVidModes(uInt32 baseWidth, uInt32 baseHeight)
|
||||||
|
|
||||||
// Check if zooming is allowed for this state (currently only allowed
|
// Check if zooming is allowed for this state (currently only allowed
|
||||||
// for TIA screens)
|
// for TIA screens)
|
||||||
EventHandler::State state = myOSystem.eventHandler().state();
|
EventHandlerState state = myOSystem.eventHandler().state();
|
||||||
bool tiaMode = (state != EventHandler::S_DEBUGGER &&
|
bool tiaMode = (state != EventHandlerState::DEBUGGER &&
|
||||||
state != EventHandler::S_LAUNCHER);
|
state != EventHandlerState::LAUNCHER);
|
||||||
|
|
||||||
// TIA mode allows zooming at integral factors in windowed modes,
|
// TIA mode allows zooming at integral factors in windowed modes,
|
||||||
// and also non-integral factors in fullscreen mode
|
// and also non-integral factors in fullscreen mode
|
||||||
|
@ -730,7 +738,7 @@ void FrameBuffer::setAvailableVidModes(uInt32 baseWidth, uInt32 baseHeight)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
const VideoMode& FrameBuffer::getSavedVidMode(bool fullscreen)
|
const VideoMode& FrameBuffer::getSavedVidMode(bool fullscreen)
|
||||||
{
|
{
|
||||||
EventHandler::State state = myOSystem.eventHandler().state();
|
EventHandlerState state = myOSystem.eventHandler().state();
|
||||||
|
|
||||||
if(fullscreen)
|
if(fullscreen)
|
||||||
{
|
{
|
||||||
|
@ -748,7 +756,7 @@ const VideoMode& FrameBuffer::getSavedVidMode(bool fullscreen)
|
||||||
// Now select the best resolution depending on the state
|
// Now select the best resolution depending on the state
|
||||||
// UI modes (launcher and debugger) have only one supported resolution
|
// UI modes (launcher and debugger) have only one supported resolution
|
||||||
// so the 'current' one is the only valid one
|
// so the 'current' one is the only valid one
|
||||||
if(state == EventHandler::S_DEBUGGER || state == EventHandler::S_LAUNCHER)
|
if(state == EventHandlerState::DEBUGGER || state == EventHandlerState::LAUNCHER)
|
||||||
myCurrentModeList->setZoom(1);
|
myCurrentModeList->setZoom(1);
|
||||||
else
|
else
|
||||||
myCurrentModeList->setZoom(myZoomMode);
|
myCurrentModeList->setZoom(myZoomMode);
|
||||||
|
|
|
@ -30,11 +30,11 @@ namespace GUI {
|
||||||
class Font;
|
class Font;
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "EventHandler.hxx"
|
|
||||||
#include "Rect.hxx"
|
#include "Rect.hxx"
|
||||||
#include "Variant.hxx"
|
#include "Variant.hxx"
|
||||||
#include "TIAConstants.hxx"
|
#include "TIAConstants.hxx"
|
||||||
#include "FrameBufferConstants.hxx"
|
#include "FrameBufferConstants.hxx"
|
||||||
|
#include "EventHandlerConstants.hxx"
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
|
||||||
// Contains all relevant info for the dimensions of a video screen
|
// Contains all relevant info for the dimensions of a video screen
|
||||||
|
@ -261,7 +261,7 @@ class FrameBuffer
|
||||||
/**
|
/**
|
||||||
Informs the Framebuffer of a change in EventHandler state.
|
Informs the Framebuffer of a change in EventHandler state.
|
||||||
*/
|
*/
|
||||||
void stateChanged(EventHandler::State state);
|
void stateChanged(EventHandlerState state);
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// The following methods are system-specific and can/must be
|
// The following methods are system-specific and can/must be
|
||||||
|
|
|
@ -47,7 +47,7 @@
|
||||||
#include "Menu.hxx"
|
#include "Menu.hxx"
|
||||||
#include "CommandMenu.hxx"
|
#include "CommandMenu.hxx"
|
||||||
#include "Launcher.hxx"
|
#include "Launcher.hxx"
|
||||||
#include "Rewinder.hxx"
|
#include "TimeMachine.hxx"
|
||||||
#include "PNGLibrary.hxx"
|
#include "PNGLibrary.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
#include "Console.hxx"
|
#include "Console.hxx"
|
||||||
|
@ -140,8 +140,8 @@ bool OSystem::create()
|
||||||
// Create menu and launcher GUI objects
|
// Create menu and launcher GUI objects
|
||||||
myMenu = make_unique<Menu>(*this);
|
myMenu = make_unique<Menu>(*this);
|
||||||
myCommandMenu = make_unique<CommandMenu>(*this);
|
myCommandMenu = make_unique<CommandMenu>(*this);
|
||||||
|
myTimeMachine = make_unique<TimeMachine>(*this);
|
||||||
myLauncher = make_unique<Launcher>(*this);
|
myLauncher = make_unique<Launcher>(*this);
|
||||||
myRewinder = make_unique<Rewinder>(*this);
|
|
||||||
myStateManager = make_unique<StateManager>(*this);
|
myStateManager = make_unique<StateManager>(*this);
|
||||||
|
|
||||||
// Create the sound object; the sound subsystem isn't actually
|
// Create the sound object; the sound subsystem isn't actually
|
||||||
|
@ -250,27 +250,28 @@ FBInitStatus OSystem::createFrameBuffer()
|
||||||
FBInitStatus fbstatus = FBInitStatus::FailComplete;
|
FBInitStatus fbstatus = FBInitStatus::FailComplete;
|
||||||
switch(myEventHandler->state())
|
switch(myEventHandler->state())
|
||||||
{
|
{
|
||||||
case EventHandler::S_EMULATE:
|
case EventHandlerState::EMULATION:
|
||||||
case EventHandler::S_PAUSE:
|
case EventHandlerState::PAUSE:
|
||||||
case EventHandler::S_MENU:
|
case EventHandlerState::OPTIONSMENU:
|
||||||
case EventHandler::S_CMDMENU:
|
case EventHandlerState::CMDMENU:
|
||||||
|
case EventHandlerState::TIMEMACHINE:
|
||||||
if((fbstatus = myConsole->initializeVideo()) != FBInitStatus::Success)
|
if((fbstatus = myConsole->initializeVideo()) != FBInitStatus::Success)
|
||||||
return fbstatus;
|
return fbstatus;
|
||||||
break; // S_EMULATE, S_PAUSE, S_MENU, S_CMDMENU
|
break;
|
||||||
|
|
||||||
case EventHandler::S_LAUNCHER:
|
case EventHandlerState::LAUNCHER:
|
||||||
if((fbstatus = myLauncher->initializeVideo()) != FBInitStatus::Success)
|
if((fbstatus = myLauncher->initializeVideo()) != FBInitStatus::Success)
|
||||||
return fbstatus;
|
return fbstatus;
|
||||||
break; // S_LAUNCHER
|
break;
|
||||||
|
|
||||||
#ifdef DEBUGGER_SUPPORT
|
#ifdef DEBUGGER_SUPPORT
|
||||||
case EventHandler::S_DEBUGGER:
|
case EventHandlerState::DEBUGGER:
|
||||||
if((fbstatus = myDebugger->initializeVideo()) != FBInitStatus::Success)
|
if((fbstatus = myDebugger->initializeVideo()) != FBInitStatus::Success)
|
||||||
return fbstatus;
|
return fbstatus;
|
||||||
break; // S_DEBUGGER
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
default: // Should never happen
|
case EventHandlerState::NONE: // Should never happen
|
||||||
logMessage("ERROR: Unknown emulation state in createFrameBuffer()", 0);
|
logMessage("ERROR: Unknown emulation state in createFrameBuffer()", 0);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -333,12 +334,12 @@ string OSystem::createConsole(const FilesystemNode& rom, const string& md5sum,
|
||||||
#ifdef CHEATCODE_SUPPORT
|
#ifdef CHEATCODE_SUPPORT
|
||||||
myCheatManager->loadCheats(myRomMD5);
|
myCheatManager->loadCheats(myRomMD5);
|
||||||
#endif
|
#endif
|
||||||
myEventHandler->reset(EventHandler::S_EMULATE);
|
myEventHandler->reset(EventHandlerState::EMULATION);
|
||||||
myEventHandler->setMouseControllerMode(mySettings->getString("usemouse"));
|
myEventHandler->setMouseControllerMode(mySettings->getString("usemouse"));
|
||||||
if(createFrameBuffer() != FBInitStatus::Success) // Takes care of initializeVideo()
|
if(createFrameBuffer() != FBInitStatus::Success) // Takes care of initializeVideo()
|
||||||
{
|
{
|
||||||
logMessage("ERROR: Couldn't create framebuffer for console", 0);
|
logMessage("ERROR: Couldn't create framebuffer for console", 0);
|
||||||
myEventHandler->reset(EventHandler::S_LAUNCHER);
|
myEventHandler->reset(EventHandlerState::LAUNCHER);
|
||||||
return "ERROR: Couldn't create framebuffer for console";
|
return "ERROR: Couldn't create framebuffer for console";
|
||||||
}
|
}
|
||||||
myConsole->initializeAudio();
|
myConsole->initializeAudio();
|
||||||
|
@ -379,7 +380,7 @@ bool OSystem::reloadConsole()
|
||||||
bool OSystem::hasConsole() const
|
bool OSystem::hasConsole() const
|
||||||
{
|
{
|
||||||
return myConsole != nullptr &&
|
return myConsole != nullptr &&
|
||||||
myEventHandler->state() != EventHandler::S_LAUNCHER;
|
myEventHandler->state() != EventHandlerState::LAUNCHER;
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -393,7 +394,7 @@ bool OSystem::createLauncher(const string& startdir)
|
||||||
mySettings->setValue("tmpromdir", startdir);
|
mySettings->setValue("tmpromdir", startdir);
|
||||||
bool status = false;
|
bool status = false;
|
||||||
|
|
||||||
myEventHandler->reset(EventHandler::S_LAUNCHER);
|
myEventHandler->reset(EventHandlerState::LAUNCHER);
|
||||||
if(createFrameBuffer() == FBInitStatus::Success)
|
if(createFrameBuffer() == FBInitStatus::Success)
|
||||||
{
|
{
|
||||||
myLauncher->reStack();
|
myLauncher->reStack();
|
||||||
|
|
|
@ -26,8 +26,9 @@ class Console;
|
||||||
class Debugger;
|
class Debugger;
|
||||||
class Launcher;
|
class Launcher;
|
||||||
class Menu;
|
class Menu;
|
||||||
class Rewinder;
|
class TimeMachine;
|
||||||
class FrameBuffer;
|
class FrameBuffer;
|
||||||
|
class EventHandler;
|
||||||
class PNGLibrary;
|
class PNGLibrary;
|
||||||
class Properties;
|
class Properties;
|
||||||
class PropertiesSet;
|
class PropertiesSet;
|
||||||
|
@ -38,9 +39,9 @@ class Sound;
|
||||||
class StateManager;
|
class StateManager;
|
||||||
class VideoDialog;
|
class VideoDialog;
|
||||||
|
|
||||||
#include "EventHandler.hxx"
|
|
||||||
#include "FSNode.hxx"
|
#include "FSNode.hxx"
|
||||||
#include "FrameBufferConstants.hxx"
|
#include "FrameBufferConstants.hxx"
|
||||||
|
#include "EventHandlerConstants.hxx"
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
|
||||||
struct TimingInfo {
|
struct TimingInfo {
|
||||||
|
@ -154,11 +155,11 @@ class OSystem
|
||||||
Launcher& launcher() const { return *myLauncher; }
|
Launcher& launcher() const { return *myLauncher; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Get the state rewinder of the system.
|
Get the time machine of the system (manages state files).
|
||||||
|
|
||||||
@return The rewinder object
|
@return The time machine object
|
||||||
*/
|
*/
|
||||||
Rewinder& rewinder() const { return *myRewinder; }
|
TimeMachine& timeMachine() const { return *myTimeMachine; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Get the state manager of the system.
|
Get the state manager of the system.
|
||||||
|
@ -410,7 +411,7 @@ class OSystem
|
||||||
/**
|
/**
|
||||||
Informs the OSystem of a change in EventHandler state.
|
Informs the OSystem of a change in EventHandler state.
|
||||||
*/
|
*/
|
||||||
virtual void stateChanged(EventHandler::State state) { }
|
virtual void stateChanged(EventHandlerState state) { }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Returns the default save and load paths for various files
|
Returns the default save and load paths for various files
|
||||||
|
@ -469,8 +470,8 @@ class OSystem
|
||||||
unique_ptr<Launcher> myLauncher;
|
unique_ptr<Launcher> myLauncher;
|
||||||
bool myLauncherUsed;
|
bool myLauncherUsed;
|
||||||
|
|
||||||
// Pointer to the Rewinder object
|
// Pointer to the TimeMachine object
|
||||||
unique_ptr<Rewinder> myRewinder;
|
unique_ptr<TimeMachine> myTimeMachine;
|
||||||
|
|
||||||
#ifdef DEBUGGER_SUPPORT
|
#ifdef DEBUGGER_SUPPORT
|
||||||
// Pointer to the Debugger object
|
// Pointer to the Debugger object
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
#include "FBSurface.hxx"
|
#include "FBSurface.hxx"
|
||||||
#include "Font.hxx"
|
#include "Font.hxx"
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
#include "FBSurface.hxx"
|
#include "FBSurface.hxx"
|
||||||
#include "Font.hxx"
|
#include "Font.hxx"
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include "Dialog.hxx"
|
#include "Dialog.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "FBSurface.hxx"
|
#include "FBSurface.hxx"
|
||||||
#include "Font.hxx"
|
#include "Font.hxx"
|
||||||
#include "EditableWidget.hxx"
|
#include "EditableWidget.hxx"
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "Console.hxx"
|
#include "Console.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "Joystick.hxx"
|
#include "Joystick.hxx"
|
||||||
#include "Paddles.hxx"
|
#include "Paddles.hxx"
|
||||||
#include "PointingDevice.hxx"
|
#include "PointingDevice.hxx"
|
||||||
|
@ -348,7 +349,7 @@ void InputDialog::saveConfig()
|
||||||
const string& cursor = myCursorState->getSelectedTag().toString();
|
const string& cursor = myCursorState->getSelectedTag().toString();
|
||||||
instance().settings().setValue("cursor", cursor);
|
instance().settings().setValue("cursor", cursor);
|
||||||
instance().settings().setValue("grabmouse", myGrabMouse->getState());
|
instance().settings().setValue("grabmouse", myGrabMouse->getState());
|
||||||
instance().frameBuffer().enableGrabMouse(myGrabMouse->getState());
|
instance().frameBuffer().enableGrabMouse(myGrabMouse->getState());
|
||||||
|
|
||||||
// Enable/disable control key-combos
|
// Enable/disable control key-combos
|
||||||
instance().settings().setValue("ctrlcombo", myCtrlCombo->getState());
|
instance().settings().setValue("ctrlcombo", myCtrlCombo->getState());
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
#include "Font.hxx"
|
#include "Font.hxx"
|
||||||
#include "EditTextWidget.hxx"
|
#include "EditTextWidget.hxx"
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
#include "MessageBox.hxx"
|
#include "MessageBox.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "Props.hxx"
|
#include "Props.hxx"
|
||||||
#include "PropsSet.hxx"
|
#include "PropsSet.hxx"
|
||||||
#include "RomInfoWidget.hxx"
|
#include "RomInfoWidget.hxx"
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#include "ScrollBarWidget.hxx"
|
#include "ScrollBarWidget.hxx"
|
||||||
#include "Dialog.hxx"
|
#include "Dialog.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "ListWidget.hxx"
|
#include "ListWidget.hxx"
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
|
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "Dialog.hxx"
|
#include "Dialog.hxx"
|
||||||
#include "DialogContainer.hxx"
|
#include "DialogContainer.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
|
@ -164,10 +165,10 @@ void OptionsDialog::loadConfig()
|
||||||
// in launcher mode
|
// in launcher mode
|
||||||
switch(instance().eventHandler().state())
|
switch(instance().eventHandler().state())
|
||||||
{
|
{
|
||||||
case EventHandler::S_EMULATE:
|
case EventHandlerState::EMULATION:
|
||||||
myGameInfoButton->setFlags(WIDGET_ENABLED);
|
myGameInfoButton->setFlags(WIDGET_ENABLED);
|
||||||
break;
|
break;
|
||||||
case EventHandler::S_LAUNCHER:
|
case EventHandlerState::LAUNCHER:
|
||||||
if(instance().launcher().selectedRomMD5() != "")
|
if(instance().launcher().selectedRomMD5() != "")
|
||||||
myGameInfoButton->setFlags(WIDGET_ENABLED);
|
myGameInfoButton->setFlags(WIDGET_ENABLED);
|
||||||
else
|
else
|
||||||
|
|
|
@ -22,6 +22,7 @@ class GUIObject;
|
||||||
class ContextMenu;
|
class ContextMenu;
|
||||||
|
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
#include "Variant.hxx"
|
||||||
#include "Command.hxx"
|
#include "Command.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
|
#include "EventHandler.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
#include "Dialog.hxx"
|
#include "Dialog.hxx"
|
||||||
#include "FBSurface.hxx"
|
#include "FBSurface.hxx"
|
||||||
|
@ -26,7 +27,6 @@
|
||||||
#include "Rect.hxx"
|
#include "Rect.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
#include "TIAConstants.hxx"
|
#include "TIAConstants.hxx"
|
||||||
|
|
||||||
#include "RomInfoWidget.hxx"
|
#include "RomInfoWidget.hxx"
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -59,7 +59,7 @@ void RomInfoWidget::setProperties(const Properties& props)
|
||||||
myProperties = props;
|
myProperties = props;
|
||||||
|
|
||||||
// Decide whether the information should be shown immediately
|
// Decide whether the information should be shown immediately
|
||||||
if(instance().eventHandler().state() == EventHandler::S_LAUNCHER)
|
if(instance().eventHandler().state() == EventHandlerState::LAUNCHER)
|
||||||
parseProperties();
|
parseProperties();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,7 +71,7 @@ void RomInfoWidget::clearProperties()
|
||||||
mySurface->setVisible(mySurfaceIsValid);
|
mySurface->setVisible(mySurfaceIsValid);
|
||||||
|
|
||||||
// Decide whether the information should be shown immediately
|
// Decide whether the information should be shown immediately
|
||||||
if(instance().eventHandler().state() == EventHandler::S_LAUNCHER)
|
if(instance().eventHandler().state() == EventHandlerState::LAUNCHER)
|
||||||
setDirty();
|
setDirty();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,13 +17,13 @@
|
||||||
|
|
||||||
#include "Dialog.hxx"
|
#include "Dialog.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
#include "RewindDialog.hxx"
|
#include "TimeMachineDialog.hxx"
|
||||||
#include "Rewinder.hxx"
|
#include "TimeMachine.hxx"
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
Rewinder::Rewinder(OSystem& osystem)
|
TimeMachine::TimeMachine(OSystem& osystem)
|
||||||
: DialogContainer(osystem)
|
: DialogContainer(osystem)
|
||||||
{
|
{
|
||||||
myBaseDialog = new RewindDialog(myOSystem, *this,
|
myBaseDialog = new TimeMachineDialog(myOSystem, *this,
|
||||||
FrameBuffer::kFBMinW, FrameBuffer::kFBMinH);
|
FrameBuffer::kFBMinW, FrameBuffer::kFBMinH);
|
||||||
}
|
}
|
|
@ -15,31 +15,31 @@
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef REWINDER_HXX
|
#ifndef TIME_MACHINE_HXX
|
||||||
#define REWINDER_HXX
|
#define TIME_MACHINE_HXX
|
||||||
|
|
||||||
class OSystem;
|
class OSystem;
|
||||||
|
|
||||||
#include "DialogContainer.hxx"
|
#include "DialogContainer.hxx"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
The base dialog for all rewind-related UI items in Stella.
|
The base dialog for all time machine related UI items in Stella.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
*/
|
*/
|
||||||
class Rewinder : public DialogContainer
|
class TimeMachine : public DialogContainer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Rewinder(OSystem& osystem);
|
TimeMachine(OSystem& osystem);
|
||||||
virtual ~Rewinder() = default;
|
virtual ~TimeMachine() = default;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Following constructors and assignment operators not supported
|
// Following constructors and assignment operators not supported
|
||||||
Rewinder() = delete;
|
TimeMachine() = delete;
|
||||||
Rewinder(const Rewinder&) = delete;
|
TimeMachine(const TimeMachine&) = delete;
|
||||||
Rewinder(Rewinder&&) = delete;
|
TimeMachine(TimeMachine&&) = delete;
|
||||||
Rewinder& operator=(const Rewinder&) = delete;
|
TimeMachine& operator=(const TimeMachine&) = delete;
|
||||||
Rewinder& operator=(Rewinder&&) = delete;
|
TimeMachine& operator=(TimeMachine&&) = delete;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -21,11 +21,11 @@
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
#include "RewindDialog.hxx"
|
#include "TimeMachineDialog.hxx"
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
RewindDialog::RewindDialog(OSystem& osystem, DialogContainer& parent,
|
TimeMachineDialog::TimeMachineDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
int max_w, int max_h)
|
int max_w, int max_h)
|
||||||
: Dialog(osystem, parent)
|
: Dialog(osystem, parent)
|
||||||
{
|
{
|
||||||
const GUI::Font& font = instance().frameBuffer().font();
|
const GUI::Font& font = instance().frameBuffer().font();
|
|
@ -15,8 +15,8 @@
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef REWIND_DIALOG_HXX
|
#ifndef TIME_MACHINE_DIALOG_HXX
|
||||||
#define REWIND_DIALOG_HXX
|
#define TIME_MACHINE_DIALOG_HXX
|
||||||
|
|
||||||
class CommandSender;
|
class CommandSender;
|
||||||
class DialogContainer;
|
class DialogContainer;
|
||||||
|
@ -24,19 +24,19 @@ class OSystem;
|
||||||
|
|
||||||
#include "Dialog.hxx"
|
#include "Dialog.hxx"
|
||||||
|
|
||||||
class RewindDialog : public Dialog
|
class TimeMachineDialog : public Dialog
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
RewindDialog(OSystem& osystem, DialogContainer& parent, int max_w, int max_h);
|
TimeMachineDialog(OSystem& osystem, DialogContainer& parent, int max_w, int max_h);
|
||||||
virtual ~RewindDialog() = default;
|
virtual ~TimeMachineDialog() = default;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Following constructors and assignment operators not supported
|
// Following constructors and assignment operators not supported
|
||||||
RewindDialog() = delete;
|
TimeMachineDialog() = delete;
|
||||||
RewindDialog(const RewindDialog&) = delete;
|
TimeMachineDialog(const TimeMachineDialog&) = delete;
|
||||||
RewindDialog(RewindDialog&&) = delete;
|
TimeMachineDialog(TimeMachineDialog&&) = delete;
|
||||||
RewindDialog& operator=(const RewindDialog&) = delete;
|
TimeMachineDialog& operator=(const TimeMachineDialog&) = delete;
|
||||||
RewindDialog& operator=(RewindDialog&&) = delete;
|
TimeMachineDialog& operator=(TimeMachineDialog&&) = delete;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -4,20 +4,20 @@ MODULE_OBJS := \
|
||||||
src/gui/AboutDialog.o \
|
src/gui/AboutDialog.o \
|
||||||
src/gui/AudioDialog.o \
|
src/gui/AudioDialog.o \
|
||||||
src/gui/BrowserDialog.o \
|
src/gui/BrowserDialog.o \
|
||||||
|
src/gui/CheckListWidget.o \
|
||||||
src/gui/ColorWidget.o \
|
src/gui/ColorWidget.o \
|
||||||
src/gui/ComboDialog.o \
|
src/gui/ComboDialog.o \
|
||||||
src/gui/CommandDialog.o \
|
src/gui/CommandDialog.o \
|
||||||
src/gui/CommandMenu.o \
|
src/gui/CommandMenu.o \
|
||||||
|
src/gui/ConfigPathDialog.o \
|
||||||
src/gui/ContextMenu.o \
|
src/gui/ContextMenu.o \
|
||||||
src/gui/DialogContainer.o \
|
|
||||||
src/gui/DeveloperDialog.o \
|
src/gui/DeveloperDialog.o \
|
||||||
|
src/gui/DialogContainer.o \
|
||||||
src/gui/Dialog.o \
|
src/gui/Dialog.o \
|
||||||
src/gui/EditableWidget.o \
|
src/gui/EditableWidget.o \
|
||||||
src/gui/EditTextWidget.o \
|
src/gui/EditTextWidget.o \
|
||||||
src/gui/EventMappingWidget.o \
|
src/gui/EventMappingWidget.o \
|
||||||
src/gui/FileListWidget.o \
|
src/gui/FileListWidget.o \
|
||||||
src/gui/ConfigPathDialog.o \
|
|
||||||
src/gui/SnapshotDialog.o \
|
|
||||||
src/gui/Font.o \
|
src/gui/Font.o \
|
||||||
src/gui/GameInfoDialog.o \
|
src/gui/GameInfoDialog.o \
|
||||||
src/gui/GameList.o \
|
src/gui/GameList.o \
|
||||||
|
@ -26,25 +26,25 @@ MODULE_OBJS := \
|
||||||
src/gui/InputDialog.o \
|
src/gui/InputDialog.o \
|
||||||
src/gui/InputTextDialog.o \
|
src/gui/InputTextDialog.o \
|
||||||
src/gui/JoystickDialog.o \
|
src/gui/JoystickDialog.o \
|
||||||
src/gui/Launcher.o \
|
|
||||||
src/gui/LauncherDialog.o \
|
src/gui/LauncherDialog.o \
|
||||||
src/gui/LauncherFilterDialog.o \
|
src/gui/LauncherFilterDialog.o \
|
||||||
src/gui/LoggerDialog.o \
|
src/gui/Launcher.o \
|
||||||
src/gui/ListWidget.o \
|
src/gui/ListWidget.o \
|
||||||
|
src/gui/LoggerDialog.o \
|
||||||
src/gui/Menu.o \
|
src/gui/Menu.o \
|
||||||
src/gui/MessageBox.o \
|
src/gui/MessageBox.o \
|
||||||
src/gui/OptionsDialog.o \
|
src/gui/OptionsDialog.o \
|
||||||
src/gui/PopUpWidget.o \
|
src/gui/PopUpWidget.o \
|
||||||
src/gui/ProgressDialog.o \
|
src/gui/ProgressDialog.o \
|
||||||
src/gui/RadioButtonWidget.o \
|
src/gui/RadioButtonWidget.o \
|
||||||
src/gui/Rewinder.o \
|
|
||||||
src/gui/RewindDialog.o \
|
|
||||||
src/gui/RomAuditDialog.o \
|
src/gui/RomAuditDialog.o \
|
||||||
src/gui/RomInfoWidget.o \
|
src/gui/RomInfoWidget.o \
|
||||||
src/gui/ScrollBarWidget.o \
|
src/gui/ScrollBarWidget.o \
|
||||||
src/gui/CheckListWidget.o \
|
src/gui/SnapshotDialog.o \
|
||||||
src/gui/StringListWidget.o \
|
src/gui/StringListWidget.o \
|
||||||
src/gui/TabWidget.o \
|
src/gui/TabWidget.o \
|
||||||
|
src/gui/TimeMachineDialog.o \
|
||||||
|
src/gui/TimeMachine.o \
|
||||||
src/gui/UIDialog.o \
|
src/gui/UIDialog.o \
|
||||||
src/gui/VideoDialog.o \
|
src/gui/VideoDialog.o \
|
||||||
src/gui/Widget.o
|
src/gui/Widget.o
|
||||||
|
|
Loading…
Reference in New Issue