mirror of https://github.com/stella-emu/stella.git
Cleaned up the SDL event gathering loop. It now almost exclusively
makes use of switch/case statements instead of the slower if/elseif structure. Hopefully this will fix event problems some users were experiencing. The Control or Alt button can actually now be used in event remapping. Due to the old event handling, the Control key could be assigned to an event but would never actually be usable. Removed the option to remap the exit event (for now), since I haven't figured out a way to remap it *back* to 'Escape' if that mapping is ever removed. Added beginning of support for Stella to automatically determine the correct framerate based on ROM format type. The final version of this will probably wait until Stella 1.5. git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@329 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
e060f52112
commit
0f0625d9fe
|
@ -13,12 +13,13 @@
|
|||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
//
|
||||
// $Id: mainSDL.cxx,v 1.13 2004-07-21 00:15:08 stephena Exp $
|
||||
// $Id: mainSDL.cxx,v 1.14 2004-07-28 23:54:38 stephena Exp $
|
||||
//============================================================================
|
||||
|
||||
#include <fstream>
|
||||
#include <iostream>
|
||||
#include <string>
|
||||
#include <sstream>
|
||||
#include <algorithm>
|
||||
#include <cstdlib>
|
||||
|
||||
|
@ -57,15 +58,14 @@
|
|||
#error Unsupported platform!
|
||||
#endif
|
||||
|
||||
static void cleanup();
|
||||
static bool setupJoystick();
|
||||
static void handleEvents();
|
||||
static uInt32 getTicks();
|
||||
static void setupProperties(PropertiesSet& set);
|
||||
static void Cleanup();
|
||||
static bool SetupJoystick();
|
||||
static void HandleEvents();
|
||||
static uInt32 GetTicks();
|
||||
static void SetupProperties(PropertiesSet& set);
|
||||
static void ShowInfo(const string& msg);
|
||||
|
||||
#ifdef JOYSTICK_SUPPORT
|
||||
// static uInt32 thePaddleNumber;
|
||||
|
||||
// Lookup table for joystick numbers and events
|
||||
StellaEvent::JoyStick joyList[StellaEvent::LastJSTICK] = {
|
||||
StellaEvent::JSTICK_0, StellaEvent::JSTICK_1, StellaEvent::JSTICK_2,
|
||||
|
@ -103,6 +103,18 @@ static void setupProperties(PropertiesSet& set);
|
|||
};
|
||||
#endif
|
||||
|
||||
// Lookup table for paddle resistance events
|
||||
static Event::Type Paddle_Resistance[4] = {
|
||||
Event::PaddleZeroResistance, Event::PaddleOneResistance,
|
||||
Event::PaddleTwoResistance, Event::PaddleThreeResistance
|
||||
};
|
||||
|
||||
// Lookup table for paddle button events
|
||||
static Event::Type Paddle_Button[4] = {
|
||||
Event::PaddleZeroFire, Event::PaddleOneFire,
|
||||
Event::PaddleTwoFire, Event::PaddleThreeFire
|
||||
};
|
||||
|
||||
// Pointer to the console object or the null pointer
|
||||
static Console* theConsole = (Console*) NULL;
|
||||
|
||||
|
@ -253,11 +265,22 @@ static KeyList keyList[] = {
|
|||
{ SDLK_PAGEDOWN, StellaEvent::KCODE_PAGEDOWN }
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
Prints given message based on 'theShowInfoFlag'
|
||||
*/
|
||||
static void ShowInfo(const string& msg)
|
||||
{
|
||||
if(theShowInfoFlag)
|
||||
cout << msg << endl;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
Returns number of ticks in microseconds
|
||||
*/
|
||||
#ifdef HAVE_GETTIMEOFDAY
|
||||
inline uInt32 getTicks()
|
||||
inline uInt32 GetTicks()
|
||||
{
|
||||
timeval now;
|
||||
gettimeofday(&now, 0);
|
||||
|
@ -265,7 +288,7 @@ inline uInt32 getTicks()
|
|||
return (uInt32) (now.tv_sec * 1000000 + now.tv_usec);
|
||||
}
|
||||
#else
|
||||
inline uInt32 getTicks()
|
||||
inline uInt32 GetTicks()
|
||||
{
|
||||
return (uInt32) SDL_GetTicks() * 1000;
|
||||
}
|
||||
|
@ -276,9 +299,11 @@ inline uInt32 getTicks()
|
|||
This routine should be called once setupDisplay is called
|
||||
to create the joystick stuff.
|
||||
*/
|
||||
bool setupJoystick()
|
||||
bool SetupJoystick()
|
||||
{
|
||||
#ifdef JOYSTICK_SUPPORT
|
||||
ostringstream message;
|
||||
|
||||
// Keep track of how many Stelladaptors we've found
|
||||
uInt8 saCount = 0;
|
||||
|
||||
|
@ -292,9 +317,7 @@ bool setupJoystick()
|
|||
// Initialize the joystick subsystem
|
||||
if((SDL_InitSubSystem(SDL_INIT_JOYSTICK) == -1) || (SDL_NumJoysticks() <= 0))
|
||||
{
|
||||
if(theShowInfoFlag)
|
||||
cout << "No joysticks present, use the keyboard.\n";
|
||||
|
||||
ShowInfo("No joysticks present, use the keyboard.");
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -303,6 +326,8 @@ bool setupJoystick()
|
|||
SDL_NumJoysticks() : StellaEvent::LastJSTICK;
|
||||
for(uInt32 i = 0; i < limit; i++)
|
||||
{
|
||||
message.str("");
|
||||
|
||||
string name = SDL_JoystickName(i);
|
||||
theJoysticks[i].stick = SDL_JoystickOpen(i);
|
||||
|
||||
|
@ -330,18 +355,17 @@ bool setupJoystick()
|
|||
theJoysticks[i].type = JT_STELLADAPTOR_2;
|
||||
}
|
||||
|
||||
if(theShowInfoFlag)
|
||||
cout << "Joystick " << i << ": " << name << endl;
|
||||
message << "Joystick " << i << ": " << name;
|
||||
ShowInfo(message.str());
|
||||
}
|
||||
else
|
||||
{
|
||||
theJoysticks[i].type = JT_REGULAR;
|
||||
if(theShowInfoFlag)
|
||||
{
|
||||
cout << "Joystick " << i << ": " << SDL_JoystickName(i)
|
||||
|
||||
message << "Joystick " << i << ": " << SDL_JoystickName(i)
|
||||
<< " with " << SDL_JoystickNumButtons(theJoysticks[i].stick)
|
||||
<< " buttons.\n";
|
||||
}
|
||||
<< " buttons.";
|
||||
ShowInfo(message.str());
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
@ -353,65 +377,74 @@ bool setupJoystick()
|
|||
/**
|
||||
This routine should be called regularly to handle events
|
||||
*/
|
||||
void handleEvents()
|
||||
void HandleEvents()
|
||||
{
|
||||
SDL_Event event;
|
||||
Uint8 type;
|
||||
SDLKey key;
|
||||
SDLMod mod;
|
||||
|
||||
// Check for an event
|
||||
while(SDL_PollEvent(&event))
|
||||
{
|
||||
// keyboard events
|
||||
if(event.type == SDL_KEYDOWN)
|
||||
switch(event.type)
|
||||
{
|
||||
key = event.key.keysym.sym;
|
||||
mod = event.key.keysym.mod;
|
||||
type = event.type;
|
||||
// keyboard events
|
||||
case SDL_KEYUP:
|
||||
case SDL_KEYDOWN:
|
||||
{
|
||||
SDLKey key = event.key.keysym.sym;
|
||||
SDLMod mod = event.key.keysym.mod;
|
||||
uInt32 state = event.key.type == SDL_KEYDOWN ? 1 : 0;
|
||||
|
||||
// An attempt to speed up event processing
|
||||
// All SDL-specific event actions are accessed by either
|
||||
// Control or Alt keys. So we quickly check for those.
|
||||
if(mod & KMOD_ALT)
|
||||
if(mod & KMOD_ALT && state)
|
||||
{
|
||||
if(key == SDLK_EQUALS)
|
||||
switch(int(key))
|
||||
{
|
||||
case SDLK_EQUALS:
|
||||
theDisplay->resize(1);
|
||||
else if(key == SDLK_MINUS)
|
||||
break;
|
||||
|
||||
case SDLK_MINUS:
|
||||
theDisplay->resize(-1);
|
||||
else if(key == SDLK_RETURN)
|
||||
break;
|
||||
|
||||
case SDLK_RETURN:
|
||||
theDisplay->toggleFullscreen();
|
||||
break;
|
||||
#ifdef DISPLAY_OPENGL
|
||||
else if(key == SDLK_f && theUseOpenGLFlag)
|
||||
case SDLK_f:
|
||||
if(theUseOpenGLFlag)
|
||||
((FrameBufferGL*)theDisplay)->toggleFilter();
|
||||
#endif
|
||||
#ifdef DEVELOPER_SUPPORT
|
||||
else if(key == SDLK_END) // Alt-End increases XStart
|
||||
{
|
||||
case SDLK_END: // Alt-End increases XStart
|
||||
theConsole->changeXStart(1);
|
||||
theDisplay->resize(0);
|
||||
}
|
||||
else if(key == SDLK_HOME) // Alt-Home decreases XStart
|
||||
{
|
||||
break;
|
||||
|
||||
case SDLK_HOME: // Alt-Home decreases XStart
|
||||
theConsole->changeXStart(0);
|
||||
theDisplay->resize(0);
|
||||
}
|
||||
else if(key == SDLK_PAGEUP) // Alt-PageUp increases YStart
|
||||
{
|
||||
break;
|
||||
|
||||
case SDLK_PAGEUP: // Alt-PageUp increases YStart
|
||||
theConsole->changeYStart(1);
|
||||
theDisplay->resize(0);
|
||||
}
|
||||
else if(key == SDLK_PAGEDOWN) // Alt-PageDown decreases YStart
|
||||
{
|
||||
break;
|
||||
|
||||
case SDLK_PAGEDOWN: // Alt-PageDown decreases YStart
|
||||
theConsole->changeYStart(0);
|
||||
theDisplay->resize(0);
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
else if(mod & KMOD_CTRL)
|
||||
else if(mod & KMOD_CTRL && state)
|
||||
{
|
||||
if(key == SDLK_g)
|
||||
switch(int(key))
|
||||
{
|
||||
case SDLK_g:
|
||||
// don't change grabmouse in fullscreen mode
|
||||
if(!theDisplay->fullScreen())
|
||||
{
|
||||
|
@ -419,9 +452,9 @@ void handleEvents()
|
|||
theSettings->setBool("grabmouse", theGrabMouseIndicator);
|
||||
theDisplay->grabMouse(theGrabMouseIndicator);
|
||||
}
|
||||
}
|
||||
else if(key == SDLK_h)
|
||||
{
|
||||
break;
|
||||
|
||||
case SDLK_h:
|
||||
// don't change hidecursor in fullscreen mode
|
||||
if(!theDisplay->fullScreen())
|
||||
{
|
||||
|
@ -429,91 +462,73 @@ void handleEvents()
|
|||
theSettings->setBool("hidecursor", theHideCursorIndicator);
|
||||
theDisplay->showCursor(!theHideCursorIndicator);
|
||||
}
|
||||
}
|
||||
else if(key == SDLK_f) // Ctrl-f toggles NTSC/PAL mode
|
||||
{
|
||||
break;
|
||||
|
||||
case SDLK_f: // Ctrl-f toggles NTSC/PAL mode
|
||||
theConsole->toggleFormat();
|
||||
theDisplay->setupPalette();
|
||||
}
|
||||
else if(key == SDLK_p) // Ctrl-p toggles different palettes
|
||||
{
|
||||
break;
|
||||
|
||||
case SDLK_p: // Ctrl-p toggles different palettes
|
||||
theConsole->togglePalette();
|
||||
theDisplay->setupPalette();
|
||||
}
|
||||
break;
|
||||
|
||||
#ifdef DEVELOPER_SUPPORT
|
||||
else if(key == SDLK_END) // Ctrl-End increases Width
|
||||
{
|
||||
case SDLK_END: // Ctrl-End increases Width
|
||||
theConsole->changeWidth(1);
|
||||
theDisplay->resize(0);
|
||||
}
|
||||
else if(key == SDLK_HOME) // Ctrl-Home decreases Width
|
||||
{
|
||||
break;
|
||||
|
||||
case SDLK_HOME: // Ctrl-Home decreases Width
|
||||
theConsole->changeWidth(0);
|
||||
theDisplay->resize(0);
|
||||
}
|
||||
else if(key == SDLK_PAGEUP) // Ctrl-PageUp increases Height
|
||||
{
|
||||
break;
|
||||
|
||||
case SDLK_PAGEUP: // Ctrl-PageUp increases Height
|
||||
theConsole->changeHeight(1);
|
||||
theDisplay->resize(0);
|
||||
}
|
||||
else if(key == SDLK_PAGEDOWN) // Ctrl-PageDown decreases Height
|
||||
{
|
||||
break;
|
||||
|
||||
case SDLK_PAGEDOWN: // Ctrl-PageDown decreases Height
|
||||
theConsole->changeHeight(0);
|
||||
theDisplay->resize(0);
|
||||
}
|
||||
break;
|
||||
#endif
|
||||
else if(key == SDLK_s) // Ctrl-s saves properties to a file
|
||||
{
|
||||
if(theConsole->settings().getBool("mergeprops")) // Attempt to merge with propertiesSet
|
||||
{
|
||||
case SDLK_s: // Ctrl-s saves properties to a file
|
||||
// Attempt to merge with propertiesSet
|
||||
if(theConsole->settings().getBool("mergeprops"))
|
||||
theConsole->saveProperties(theSettings->userPropertiesFilename(), true);
|
||||
}
|
||||
else // Save to file in home directory
|
||||
{
|
||||
string newPropertiesFile = theConsole->settings().baseDir() + "/" + \
|
||||
theConsole->properties().get("Cartridge.Name") + ".pro";
|
||||
theConsole->saveProperties(newPropertiesFile);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
else // check all the other keys
|
||||
{
|
||||
for(unsigned int i = 0; i < sizeof(keyList) / sizeof(KeyList); ++i)
|
||||
{
|
||||
if(keyList[i].scanCode == key)
|
||||
theConsole->eventHandler().sendKeyEvent(keyList[i].keyCode, 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if(event.type == SDL_KEYUP)
|
||||
{
|
||||
key = event.key.keysym.sym;
|
||||
type = event.type;
|
||||
|
||||
for(unsigned int i = 0; i < sizeof(keyList) / sizeof(KeyList); ++i)
|
||||
{
|
||||
// check all the other keys
|
||||
for(uInt32 i = 0; i < sizeof(keyList) / sizeof(KeyList); ++i)
|
||||
if(keyList[i].scanCode == key)
|
||||
theConsole->eventHandler().sendKeyEvent(keyList[i].keyCode, 0);
|
||||
theConsole->eventHandler().sendKeyEvent(keyList[i].keyCode, state);
|
||||
|
||||
break; // SDL_KEYUP, SDL_KEYDOWN
|
||||
}
|
||||
}
|
||||
else if(event.type == SDL_MOUSEMOTION)
|
||||
|
||||
case SDL_MOUSEMOTION:
|
||||
{
|
||||
Int32 resistance;
|
||||
uInt32 zoom = theDisplay->zoomLevel();
|
||||
Int32 width = theDisplay->width() * zoom;
|
||||
Event::Type type = Event::NoType;
|
||||
|
||||
// Grabmouse and hidecursor introduce some lag into the mouse movement,
|
||||
// so we need to fudge the numbers a bit
|
||||
if(theGrabMouseIndicator && theHideCursorIndicator)
|
||||
{
|
||||
mouseX = (int)((float)mouseX + (float)event.motion.xrel
|
||||
* 1.5 * (float) zoom);
|
||||
}
|
||||
else
|
||||
{
|
||||
mouseX = mouseX + event.motion.xrel * zoom;
|
||||
}
|
||||
|
||||
// Check to make sure mouseX is within the game window
|
||||
if(mouseX < 0)
|
||||
|
@ -521,58 +536,47 @@ void handleEvents()
|
|||
else if(mouseX > width)
|
||||
mouseX = width;
|
||||
|
||||
resistance = (Int32)(1000000.0 * (width - mouseX) / width);
|
||||
Int32 resistance = (Int32)(1000000.0 * (width - mouseX) / width);
|
||||
|
||||
// Now, set the event of the correct paddle to the calculated resistance
|
||||
if(thePaddleMode == 0)
|
||||
type = Event::PaddleZeroResistance;
|
||||
else if(thePaddleMode == 1)
|
||||
type = Event::PaddleOneResistance;
|
||||
else if(thePaddleMode == 2)
|
||||
type = Event::PaddleTwoResistance;
|
||||
else if(thePaddleMode == 3)
|
||||
type = Event::PaddleThreeResistance;
|
||||
theConsole->eventHandler().sendEvent(Paddle_Resistance[thePaddleMode], resistance);
|
||||
|
||||
theConsole->eventHandler().sendEvent(type, resistance);
|
||||
break; // SDL_MOUSEMOTION
|
||||
}
|
||||
else if(event.type == SDL_MOUSEBUTTONDOWN || event.type == SDL_MOUSEBUTTONUP)
|
||||
|
||||
case SDL_MOUSEBUTTONUP:
|
||||
case SDL_MOUSEBUTTONDOWN:
|
||||
{
|
||||
Event::Type type = Event::LastType;
|
||||
Int32 value;
|
||||
Int32 value = event.button.type == SDL_MOUSEBUTTONDOWN ? 1 : 0;
|
||||
|
||||
if(event.type == SDL_MOUSEBUTTONDOWN)
|
||||
value = 1;
|
||||
else
|
||||
value = 0;
|
||||
theConsole->eventHandler().sendEvent(Paddle_Button[thePaddleMode], value);
|
||||
|
||||
if(thePaddleMode == 0)
|
||||
type = Event::PaddleZeroFire;
|
||||
else if(thePaddleMode == 1)
|
||||
type = Event::PaddleOneFire;
|
||||
else if(thePaddleMode == 2)
|
||||
type = Event::PaddleTwoFire;
|
||||
else if(thePaddleMode == 3)
|
||||
type = Event::PaddleThreeFire;
|
||||
|
||||
theConsole->eventHandler().sendEvent(type, value);
|
||||
break; // SDL_MOUSEBUTTONUP, SDL_MOUSEBUTTONDOWN
|
||||
}
|
||||
else if(event.type == SDL_ACTIVEEVENT)
|
||||
|
||||
case SDL_ACTIVEEVENT:
|
||||
{
|
||||
if((event.active.state & SDL_APPACTIVE) && (event.active.gain == 0))
|
||||
{
|
||||
if(!theConsole->eventHandler().doPause())
|
||||
{
|
||||
theConsole->eventHandler().sendEvent(Event::Pause, 1);
|
||||
}
|
||||
|
||||
break; // SDL_ACTIVEEVENT
|
||||
}
|
||||
}
|
||||
else if(event.type == SDL_QUIT)
|
||||
|
||||
case SDL_QUIT:
|
||||
{
|
||||
theConsole->eventHandler().sendEvent(Event::Quit, 1);
|
||||
|
||||
break; // SDL_QUIT
|
||||
}
|
||||
else if(event.type == SDL_VIDEOEXPOSE)
|
||||
|
||||
case SDL_VIDEOEXPOSE:
|
||||
{
|
||||
theDisplay->refresh();
|
||||
|
||||
break; // SDL_VIDEOEXPOSE
|
||||
}
|
||||
}
|
||||
|
||||
#ifdef JOYSTICK_SUPPORT
|
||||
|
@ -600,9 +604,10 @@ void handleEvents()
|
|||
break;
|
||||
|
||||
case JT_REGULAR:
|
||||
|
||||
if((event.type == SDL_JOYBUTTONDOWN) || (event.type == SDL_JOYBUTTONUP))
|
||||
switch(event.type)
|
||||
{
|
||||
case SDL_JOYBUTTONUP:
|
||||
case SDL_JOYBUTTONDOWN:
|
||||
if(event.jbutton.button >= StellaEvent::LastJCODE)
|
||||
return;
|
||||
|
||||
|
@ -610,9 +615,9 @@ void handleEvents()
|
|||
state = event.jbutton.state == SDL_PRESSED ? 1 : 0;
|
||||
|
||||
theConsole->eventHandler().sendJoyEvent(stick, code, state);
|
||||
}
|
||||
else if(event.type == SDL_JOYAXISMOTION)
|
||||
{
|
||||
break;
|
||||
|
||||
case SDL_JOYAXISMOTION:
|
||||
axis = event.jaxis.axis;
|
||||
value = event.jaxis.value;
|
||||
|
||||
|
@ -630,14 +635,16 @@ void handleEvents()
|
|||
theConsole->eventHandler().sendJoyEvent(stick, StellaEvent::JAXIS_DOWN,
|
||||
(value > 16384) ? 1 : 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
break; // Regular joystick
|
||||
|
||||
case JT_STELLADAPTOR_1:
|
||||
case JT_STELLADAPTOR_2:
|
||||
|
||||
if((event.type == SDL_JOYBUTTONDOWN) || (event.type == SDL_JOYBUTTONUP))
|
||||
switch(event.type)
|
||||
{
|
||||
case SDL_JOYBUTTONUP:
|
||||
case SDL_JOYBUTTONDOWN:
|
||||
button = event.jbutton.button;
|
||||
state = event.jbutton.state == SDL_PRESSED ? 1 : 0;
|
||||
|
||||
|
@ -664,9 +671,9 @@ void handleEvents()
|
|||
else
|
||||
theConsole->eventHandler().sendEvent(Event::PaddleThreeFire, state);
|
||||
}
|
||||
}
|
||||
else if(event.type == SDL_JOYAXISMOTION)
|
||||
{
|
||||
break;
|
||||
|
||||
case SDL_JOYAXISMOTION:
|
||||
axis = event.jaxis.axis;
|
||||
value = event.jaxis.value;
|
||||
|
||||
|
@ -692,6 +699,7 @@ void handleEvents()
|
|||
else
|
||||
theConsole->eventHandler().sendEvent(SA_DrivingValue[type-2],3);
|
||||
}
|
||||
break;
|
||||
}
|
||||
break; // Stelladaptor joystick
|
||||
|
||||
|
@ -707,7 +715,7 @@ void handleEvents()
|
|||
Setup the properties set by first checking for a user file,
|
||||
then a system-wide file.
|
||||
*/
|
||||
void setupProperties(PropertiesSet& set)
|
||||
void SetupProperties(PropertiesSet& set)
|
||||
{
|
||||
bool useMemList = false;
|
||||
string theAlternateProFile = theSettings->getString("altpro");
|
||||
|
@ -731,9 +739,9 @@ void setupProperties(PropertiesSet& set)
|
|||
|
||||
|
||||
/**
|
||||
Does general cleanup in case any operation failed (or at end of program).
|
||||
Does general Cleanup in case any operation failed (or at end of program).
|
||||
*/
|
||||
void cleanup()
|
||||
void Cleanup()
|
||||
{
|
||||
#ifdef JOYSTICK_SUPPORT
|
||||
if(SDL_WasInit(SDL_INIT_JOYSTICK) & SDL_INIT_JOYSTICK)
|
||||
|
@ -775,7 +783,7 @@ int main(int argc, char* argv[])
|
|||
#endif
|
||||
if(!theSettings)
|
||||
{
|
||||
cleanup();
|
||||
Cleanup();
|
||||
return 0;
|
||||
}
|
||||
theSettings->loadConfig();
|
||||
|
@ -783,20 +791,20 @@ int main(int argc, char* argv[])
|
|||
// Take care of commandline arguments
|
||||
if(!theSettings->loadCommandLine(argc, argv))
|
||||
{
|
||||
cleanup();
|
||||
Cleanup();
|
||||
return 0;
|
||||
}
|
||||
|
||||
// Create a properties set for us to use and set it up
|
||||
PropertiesSet propertiesSet;
|
||||
setupProperties(propertiesSet);
|
||||
SetupProperties(propertiesSet);
|
||||
|
||||
// Check to see if the 'listroms' argument was given
|
||||
// If so, list the roms and immediately exit
|
||||
if(theSettings->getBool("listrominfo"))
|
||||
{
|
||||
propertiesSet.print();
|
||||
cleanup();
|
||||
Cleanup();
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -817,7 +825,7 @@ int main(int argc, char* argv[])
|
|||
if(!in)
|
||||
{
|
||||
cerr << "ERROR: Couldn't open " << file << "..." << endl;
|
||||
cleanup();
|
||||
Cleanup();
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -831,30 +839,27 @@ int main(int argc, char* argv[])
|
|||
if(videodriver == "soft")
|
||||
{
|
||||
theDisplay = new FrameBufferSoft();
|
||||
if(theShowInfoFlag)
|
||||
cout << "Using software mode for video.\n";
|
||||
ShowInfo("Using software mode for video.");
|
||||
}
|
||||
#ifdef DISPLAY_OPENGL
|
||||
else if(videodriver == "gl")
|
||||
{
|
||||
theDisplay = new FrameBufferGL();
|
||||
theUseOpenGLFlag = true;
|
||||
if(theShowInfoFlag)
|
||||
cout << "Using OpenGL mode for video.\n";
|
||||
ShowInfo("Using OpenGL mode for video.");
|
||||
}
|
||||
#endif
|
||||
else // a driver that doesn't exist was requested, so use software mode
|
||||
{
|
||||
theDisplay = new FrameBufferSoft();
|
||||
if(theShowInfoFlag)
|
||||
cout << "Using software mode for video.\n";
|
||||
ShowInfo("Using software mode for video.");
|
||||
}
|
||||
|
||||
if(!theDisplay)
|
||||
{
|
||||
cerr << "ERROR: Couldn't set up display.\n";
|
||||
delete[] image;
|
||||
cleanup();
|
||||
Cleanup();
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -863,17 +868,15 @@ int main(int argc, char* argv[])
|
|||
{
|
||||
uInt32 fragsize = theSettings->getInt("fragsize");
|
||||
theSound = new SoundSDL(fragsize);
|
||||
if(theShowInfoFlag)
|
||||
{
|
||||
cout << "Sound enabled, using fragment size = " << fragsize;
|
||||
cout << "." << endl;
|
||||
}
|
||||
|
||||
ostringstream message;
|
||||
message << "Sound enabled, using fragment size = " << fragsize << ".";
|
||||
ShowInfo(message.str());
|
||||
}
|
||||
else // even if sound has been disabled, we still need a sound object
|
||||
{
|
||||
theSound = new Sound();
|
||||
if(theShowInfoFlag)
|
||||
cout << "Sound disabled.\n";
|
||||
ShowInfo("Sound disabled.");
|
||||
}
|
||||
theSound->setVolume(theSettings->getInt("volume"));
|
||||
|
||||
|
@ -887,12 +890,17 @@ int main(int argc, char* argv[])
|
|||
// Free the image since we don't need it any longer
|
||||
delete[] image;
|
||||
|
||||
// Print message about the framerate
|
||||
ostringstream message;
|
||||
message << "Using framerate = " << theSettings->getInt("framerate") << ".";
|
||||
ShowInfo(message.str());
|
||||
|
||||
// Setup the SDL joysticks
|
||||
// This must be done after the console is created
|
||||
if(!setupJoystick())
|
||||
if(!SetupJoystick())
|
||||
{
|
||||
cerr << "ERROR: Couldn't set up joysticks.\n";
|
||||
cleanup();
|
||||
Cleanup();
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -904,7 +912,7 @@ int main(int argc, char* argv[])
|
|||
{
|
||||
// Set up accurate timing stuff
|
||||
uInt32 startTime, delta;
|
||||
uInt32 timePerFrame = (uInt32)(1000000.0 / (double)theSettings->getInt("framerate"));
|
||||
uInt32 timePerFrame = (uInt32)(1000000.0 / (double) theSettings->getInt("framerate"));
|
||||
|
||||
// Set the base for the timers
|
||||
frameTime = 0;
|
||||
|
@ -918,20 +926,20 @@ int main(int argc, char* argv[])
|
|||
break;
|
||||
}
|
||||
|
||||
startTime = getTicks();
|
||||
handleEvents();
|
||||
startTime = GetTicks();
|
||||
HandleEvents();
|
||||
theConsole->update();
|
||||
|
||||
// Now, waste time if we need to so that we are at the desired frame rate
|
||||
for(;;)
|
||||
{
|
||||
delta = getTicks() - startTime;
|
||||
delta = GetTicks() - startTime;
|
||||
|
||||
if(delta >= timePerFrame)
|
||||
break;
|
||||
}
|
||||
|
||||
frameTime += getTicks() - startTime;
|
||||
frameTime += GetTicks() - startTime;
|
||||
++numberOfFrames;
|
||||
}
|
||||
}
|
||||
|
@ -939,10 +947,10 @@ int main(int argc, char* argv[])
|
|||
{
|
||||
// Set up less accurate timing stuff
|
||||
uInt32 startTime, virtualTime, currentTime;
|
||||
uInt32 timePerFrame = (uInt32)(1000000.0 / (double)theSettings->getInt("framerate"));
|
||||
uInt32 timePerFrame = (uInt32)(1000000.0 / (double) theSettings->getInt("framerate"));
|
||||
|
||||
// Set the base for the timers
|
||||
virtualTime = getTicks();
|
||||
virtualTime = GetTicks();
|
||||
frameTime = 0;
|
||||
|
||||
// Main game loop
|
||||
|
@ -954,18 +962,18 @@ int main(int argc, char* argv[])
|
|||
break;
|
||||
}
|
||||
|
||||
startTime = getTicks();
|
||||
handleEvents();
|
||||
startTime = GetTicks();
|
||||
HandleEvents();
|
||||
theConsole->update();
|
||||
|
||||
currentTime = getTicks();
|
||||
currentTime = GetTicks();
|
||||
virtualTime += timePerFrame;
|
||||
if(currentTime < virtualTime)
|
||||
{
|
||||
SDL_Delay((virtualTime - currentTime)/1000);
|
||||
}
|
||||
|
||||
currentTime = getTicks() - startTime;
|
||||
currentTime = GetTicks() - startTime;
|
||||
frameTime += currentTime;
|
||||
++numberOfFrames;
|
||||
}
|
||||
|
@ -987,6 +995,6 @@ int main(int argc, char* argv[])
|
|||
}
|
||||
|
||||
// Cleanup time ...
|
||||
cleanup();
|
||||
Cleanup();
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
//
|
||||
// $Id: Console.cxx,v 1.35 2004-07-22 01:54:08 stephena Exp $
|
||||
// $Id: Console.cxx,v 1.36 2004-07-28 23:54:38 stephena Exp $
|
||||
//============================================================================
|
||||
|
||||
#include <assert.h>
|
||||
|
@ -65,8 +65,6 @@ Console::Console(const uInt8* image, uInt32 size, const char* filename,
|
|||
mySystem = 0;
|
||||
myEvent = 0;
|
||||
|
||||
myFrameRate = mySettings.getInt("framerate");
|
||||
|
||||
// Create an event handler which will collect and dispatch events
|
||||
myEventHandler = new EventHandler(this);
|
||||
myEvent = myEventHandler->event();
|
||||
|
@ -162,13 +160,25 @@ Console::Console(const uInt8* image, uInt32 size, const char* filename,
|
|||
// Reset, the system to its power-on state
|
||||
mySystem->reset();
|
||||
|
||||
// Set the correct framerate based on the format of the ROM
|
||||
// This can be overridden by the '-framerate' option
|
||||
myFrameRate = 60;
|
||||
if(mySettings.getInt("framerate") > 0)
|
||||
myFrameRate = mySettings.getInt("framerate");
|
||||
// else if(myProperties.get("Display.Format") == "NTSC")
|
||||
// myFrameRate = 60;
|
||||
// else if(myProperties.get("Display.Format") == "PAL")
|
||||
// myFrameRate = 50;
|
||||
// mySettings.setInt("framerate", myFrameRate, false);
|
||||
mySettings.setInt("framerate", myFrameRate);
|
||||
|
||||
// Initialize the framebuffer interface.
|
||||
// This must be done *after* a reset, since it needs updated values.
|
||||
myFrameBuffer.initDisplay(this, myMediaSource);
|
||||
|
||||
// Initialize the sound interface.
|
||||
uInt32 framerate = (myProperties.get("Display.Format") == "PAL") ? 50 : 60;
|
||||
mySound.init(this, myMediaSource, mySystem, framerate);
|
||||
uInt32 soundFrameRate = (myProperties.get("Display.Format") == "PAL") ? 50 : 60;
|
||||
mySound.init(this, myMediaSource, mySystem, soundFrameRate);
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
//
|
||||
// $Id: EventHandler.cxx,v 1.28 2004-07-21 00:15:08 stephena Exp $
|
||||
// $Id: EventHandler.cxx,v 1.29 2004-07-28 23:54:39 stephena Exp $
|
||||
//============================================================================
|
||||
|
||||
#include <algorithm>
|
||||
|
@ -338,15 +338,13 @@ bool EventHandler::isValidList(string list, uInt32 length)
|
|||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void EventHandler::saveState()
|
||||
{
|
||||
ostringstream buf;
|
||||
|
||||
// Do a state save using the System
|
||||
string md5 = myConsole->properties().get("Cartridge.MD5");
|
||||
string filename = myConsole->settings().stateFilename(md5, myCurrentState);
|
||||
int result = myConsole->system().saveState(filename, md5);
|
||||
|
||||
// Print appropriate message
|
||||
buf.str("");
|
||||
ostringstream buf;
|
||||
if(result == 1)
|
||||
buf << "State " << myCurrentState << " saved";
|
||||
else if(result == 2)
|
||||
|
@ -375,13 +373,13 @@ void EventHandler::changeState()
|
|||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void EventHandler::loadState()
|
||||
{
|
||||
ostringstream buf;
|
||||
|
||||
// Do a state save using the System
|
||||
string md5 = myConsole->properties().get("Cartridge.MD5");
|
||||
string filename = myConsole->settings().stateFilename(md5, myCurrentState);
|
||||
int result = myConsole->system().loadState(filename, md5);
|
||||
|
||||
// Print appropriate message
|
||||
ostringstream buf;
|
||||
if(result == 1)
|
||||
buf << "State " << myCurrentState << " loaded";
|
||||
else if(result == 2)
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
//
|
||||
// $Id: FrameBuffer.cxx,v 1.11 2004-07-22 01:54:08 stephena Exp $
|
||||
// $Id: FrameBuffer.cxx,v 1.12 2004-07-28 23:54:39 stephena Exp $
|
||||
//============================================================================
|
||||
|
||||
#include <sstream>
|
||||
|
@ -696,7 +696,7 @@ FrameBuffer::MainMenuItem FrameBuffer::ourMainMenu[2] = {
|
|||
};
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
FrameBuffer::RemapMenuItem FrameBuffer::ourRemapMenu[58] = {
|
||||
FrameBuffer::RemapMenuItem FrameBuffer::ourRemapMenu[57] = {
|
||||
{ Event::ConsoleSelect, "Select", "" },
|
||||
{ Event::ConsoleReset, "Reset", "" },
|
||||
{ Event::ConsoleColor, "Color TV", "" },
|
||||
|
@ -710,7 +710,7 @@ FrameBuffer::RemapMenuItem FrameBuffer::ourRemapMenu[58] = {
|
|||
{ Event::LoadState, "Load State", "" },
|
||||
{ Event::TakeSnapshot, "Snapshot", "" },
|
||||
{ Event::Pause, "Pause", "" },
|
||||
{ Event::Quit, "Quit", "" },
|
||||
// { Event::Quit, "Quit", "" },
|
||||
|
||||
{ Event::JoystickZeroUp, "Left-Joy Up", "" },
|
||||
{ Event::JoystickZeroDown, "Left-Joy Down", "" },
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
//
|
||||
// $Id: FrameBuffer.hxx,v 1.11 2004-07-22 01:54:08 stephena Exp $
|
||||
// $Id: FrameBuffer.hxx,v 1.12 2004-07-28 23:54:39 stephena Exp $
|
||||
//============================================================================
|
||||
|
||||
#ifndef FRAMEBUFFER_HXX
|
||||
|
@ -35,7 +35,7 @@ class Console;
|
|||
can be changed.
|
||||
|
||||
@author Stephen Anthony
|
||||
@version $Id: FrameBuffer.hxx,v 1.11 2004-07-22 01:54:08 stephena Exp $
|
||||
@version $Id: FrameBuffer.hxx,v 1.12 2004-07-28 23:54:39 stephena Exp $
|
||||
*/
|
||||
class FrameBuffer
|
||||
{
|
||||
|
@ -337,7 +337,7 @@ class FrameBuffer
|
|||
static MainMenuItem ourMainMenu[2];
|
||||
|
||||
// Holds static strings for the remap menu
|
||||
static RemapMenuItem ourRemapMenu[58];
|
||||
static RemapMenuItem ourRemapMenu[57];
|
||||
|
||||
// Holds the current key mappings
|
||||
Event::Type* myKeyTable;
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
//
|
||||
// $Id: Props.cxx,v 1.7 2004-07-12 04:05:03 stephena Exp $
|
||||
// $Id: Props.cxx,v 1.8 2004-07-28 23:54:39 stephena Exp $
|
||||
//============================================================================
|
||||
|
||||
#include "Props.hxx"
|
||||
|
@ -150,12 +150,16 @@ void Properties::save(ostream& out)
|
|||
{
|
||||
// Write out each of the key and value pairs
|
||||
for(uInt32 i = 0; i < mySize; ++i)
|
||||
{
|
||||
// Try to save some space by only saving the items that differ from default
|
||||
if(myProperties[i].value != myDefaults->get(myProperties[i].key))
|
||||
{
|
||||
writeQuotedString(out, myProperties[i].key);
|
||||
out.put(' ');
|
||||
writeQuotedString(out, myProperties[i].value);
|
||||
out.put('\n');
|
||||
}
|
||||
}
|
||||
|
||||
// Put a trailing null string so we know when to stop reading
|
||||
writeQuotedString(out, "");
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
//
|
||||
// $Id: Settings.cxx,v 1.26 2004-07-12 02:26:57 stephena Exp $
|
||||
// $Id: Settings.cxx,v 1.27 2004-07-28 23:54:39 stephena Exp $
|
||||
//============================================================================
|
||||
|
||||
#include <cassert>
|
||||
|
@ -45,7 +45,7 @@ Settings::Settings()
|
|||
set("hidecursor", "false");
|
||||
set("volume", "-1");
|
||||
set("accurate", "false");
|
||||
set("framerate", "60");
|
||||
set("framerate", "-1");
|
||||
set("keymap", "");
|
||||
set("joymap", "");
|
||||
set("zoom", "1");
|
||||
|
@ -167,7 +167,7 @@ void Settings::usage()
|
|||
{
|
||||
#ifndef MAC_OSX
|
||||
cout << endl
|
||||
<< "Stella version 1.4\n\nUsage: stella [options ...] romfile" << endl
|
||||
<< "Stella version 1.4.1_cvs\n\nUsage: stella [options ...] romfile" << endl
|
||||
<< endl
|
||||
<< "Valid options are:" << endl
|
||||
<< endl
|
||||
|
@ -282,39 +282,39 @@ void Settings::set(const string& key, const string& value, bool save)
|
|||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void Settings::setInt(const string& key, const uInt32 value)
|
||||
void Settings::setInt(const string& key, const uInt32 value, bool save)
|
||||
{
|
||||
ostringstream stream;
|
||||
stream << value;
|
||||
|
||||
set(key, stream.str());
|
||||
set(key, stream.str(), save);
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void Settings::setFloat(const string& key, const float value)
|
||||
void Settings::setFloat(const string& key, const float value, bool save)
|
||||
{
|
||||
ostringstream stream;
|
||||
stream << value;
|
||||
|
||||
set(key, stream.str());
|
||||
set(key, stream.str(), save);
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void Settings::setBool(const string& key, const bool value)
|
||||
void Settings::setBool(const string& key, const bool value, bool save)
|
||||
{
|
||||
ostringstream stream;
|
||||
stream << value;
|
||||
|
||||
set(key, stream.str());
|
||||
set(key, stream.str(), save);
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void Settings::setString(const string& key, const string& value)
|
||||
void Settings::setString(const string& key, const string& value, bool save)
|
||||
{
|
||||
ostringstream stream;
|
||||
stream << value;
|
||||
|
||||
set(key, stream.str());
|
||||
set(key, stream.str(), save);
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
//
|
||||
// $Id: Settings.hxx,v 1.16 2004-07-09 00:27:39 stephena Exp $
|
||||
// $Id: Settings.hxx,v 1.17 2004-07-28 23:54:39 stephena Exp $
|
||||
//============================================================================
|
||||
|
||||
#ifndef SETTINGS_HXX
|
||||
|
@ -26,7 +26,7 @@
|
|||
This class provides an interface for accessing frontend specific settings.
|
||||
|
||||
@author Stephen Anthony
|
||||
@version $Id: Settings.hxx,v 1.16 2004-07-09 00:27:39 stephena Exp $
|
||||
@version $Id: Settings.hxx,v 1.17 2004-07-28 23:54:39 stephena Exp $
|
||||
*/
|
||||
class Settings
|
||||
{
|
||||
|
@ -107,7 +107,7 @@ class Settings
|
|||
@param value The value to assign to the setting
|
||||
@param save Whether this setting should be saved to the rc-file.
|
||||
*/
|
||||
void setInt(const string& key, const uInt32 value);
|
||||
void setInt(const string& key, const uInt32 value, bool save = true);
|
||||
|
||||
/**
|
||||
Set the value associated with key to the given value.
|
||||
|
@ -116,7 +116,7 @@ class Settings
|
|||
@param value The value to assign to the setting
|
||||
@param save Whether this setting should be saved to the rc-file.
|
||||
*/
|
||||
void setFloat(const string& key, const float value);
|
||||
void setFloat(const string& key, const float value, bool save = true);
|
||||
|
||||
/**
|
||||
Set the value associated with key to the given value.
|
||||
|
@ -125,7 +125,7 @@ class Settings
|
|||
@param value The value to assign to the setting
|
||||
@param save Whether this setting should be saved to the rc-file.
|
||||
*/
|
||||
void setBool(const string& key, const bool value);
|
||||
void setBool(const string& key, const bool value, bool save = true);
|
||||
|
||||
/**
|
||||
Set the value associated with key to the given value.
|
||||
|
@ -134,7 +134,7 @@ class Settings
|
|||
@param value The value to assign to the setting
|
||||
@param save Whether this setting should be saved to the rc-file.
|
||||
*/
|
||||
void setString(const string& key, const string& value);
|
||||
void setString(const string& key, const string& value, bool save = true);
|
||||
|
||||
public:
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
//
|
||||
// $Id: mainSDL.cxx,v 1.3 2004-07-14 06:54:17 markgrebe Exp $
|
||||
// $Id: mainSDL.cxx,v 1.4 2004-07-28 23:54:39 stephena Exp $
|
||||
//============================================================================
|
||||
|
||||
#include <fstream>
|
||||
|
@ -558,13 +558,13 @@ void handleEvents()
|
|||
{
|
||||
if (theSettings->getInt("framerate") != 10000000)
|
||||
{
|
||||
theSettings->setInt("framerate",10000000);
|
||||
theSettings->setInt("framerate",10000000, false);
|
||||
timePerFrame = 1.0 / 10000000.0;
|
||||
setSpeedLimitMenu(0);
|
||||
}
|
||||
else
|
||||
{
|
||||
theSettings->setInt("framerate",60);
|
||||
theSettings->setInt("framerate",60, false);
|
||||
timePerFrame = 1.0 / 60.0;
|
||||
setSpeedLimitMenu(1);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue