mirror of https://github.com/stella-emu/stella.git
Added ability to use either the X11 or SDL sound code. As of now,
the X11 sound code is more mature. Changed all occurrences of ::close() to ::closeDevice(). git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@138 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
e4f94c55c9
commit
af8b8c82f7
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: mainSDL.cxx,v 1.35 2002-11-11 02:56:27 stephena Exp $
|
// $Id: mainSDL.cxx,v 1.36 2002-11-11 22:09:07 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
|
@ -39,7 +39,12 @@
|
||||||
#include "System.hxx"
|
#include "System.hxx"
|
||||||
#include "RectList.hxx"
|
#include "RectList.hxx"
|
||||||
#include "Settings.hxx"
|
#include "Settings.hxx"
|
||||||
|
|
||||||
|
#ifdef USE_OSS_SOUND
|
||||||
|
#include "SoundX11.hxx"
|
||||||
|
#else
|
||||||
#include "SoundSDL.hxx"
|
#include "SoundSDL.hxx"
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_PNG
|
#ifdef HAVE_PNG
|
||||||
#include "Snapshot.hxx"
|
#include "Snapshot.hxx"
|
||||||
|
@ -1659,7 +1664,12 @@ int main(int argc, char* argv[])
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a sound object for playing audio
|
// Create a sound object for playing audio
|
||||||
|
#ifdef USE_OSS_SOUND
|
||||||
|
SoundX11 sound;
|
||||||
|
#else
|
||||||
SoundSDL sound;
|
SoundSDL sound;
|
||||||
|
#endif
|
||||||
|
|
||||||
sound.setSoundVolume(settings->theDesiredVolume);
|
sound.setSoundVolume(settings->theDesiredVolume);
|
||||||
|
|
||||||
// Get just the filename of the file containing the ROM image
|
// Get just the filename of the file containing the ROM image
|
||||||
|
@ -1682,14 +1692,14 @@ int main(int argc, char* argv[])
|
||||||
if(!setupDisplay())
|
if(!setupDisplay())
|
||||||
{
|
{
|
||||||
cerr << "ERROR: Couldn't set up display.\n";
|
cerr << "ERROR: Couldn't set up display.\n";
|
||||||
sound.close();
|
sound.closeDevice();
|
||||||
cleanup();
|
cleanup();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if(!setupJoystick())
|
if(!setupJoystick())
|
||||||
{
|
{
|
||||||
cerr << "ERROR: Couldn't set up joysticks.\n";
|
cerr << "ERROR: Couldn't set up joysticks.\n";
|
||||||
sound.close();
|
sound.closeDevice();
|
||||||
cleanup();
|
cleanup();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -1702,8 +1712,7 @@ int main(int argc, char* argv[])
|
||||||
{
|
{
|
||||||
// Set up accurate timing stuff
|
// Set up accurate timing stuff
|
||||||
uInt32 startTime, delta;
|
uInt32 startTime, delta;
|
||||||
uInt32 timePerFrame =
|
uInt32 timePerFrame = (uInt32)(1000000.0 / (double)settings->theDesiredFrameRate);
|
||||||
(uInt32)(1000000.0 / (double)settings->theDesiredFrameRate);
|
|
||||||
|
|
||||||
// Set the base for the timers
|
// Set the base for the timers
|
||||||
frameTime = 0;
|
frameTime = 0;
|
||||||
|
@ -1718,6 +1727,7 @@ int main(int argc, char* argv[])
|
||||||
}
|
}
|
||||||
|
|
||||||
// Call handleEvents here to see if user pressed pause
|
// Call handleEvents here to see if user pressed pause
|
||||||
|
startTime = getTicks();
|
||||||
handleEvents();
|
handleEvents();
|
||||||
if(thePauseIndicator)
|
if(thePauseIndicator)
|
||||||
{
|
{
|
||||||
|
@ -1726,11 +1736,9 @@ int main(int argc, char* argv[])
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
startTime = getTicks();
|
|
||||||
theConsole->mediaSource().update();
|
theConsole->mediaSource().update();
|
||||||
updateDisplay(theConsole->mediaSource());
|
updateDisplay(theConsole->mediaSource());
|
||||||
sound.updateSound(theConsole->mediaSource());
|
sound.updateSound(theConsole->mediaSource());
|
||||||
handleEvents();
|
|
||||||
|
|
||||||
// Now, waste time if we need to so that we are at the desired frame rate
|
// Now, waste time if we need to so that we are at the desired frame rate
|
||||||
for(;;)
|
for(;;)
|
||||||
|
@ -1765,16 +1773,13 @@ int main(int argc, char* argv[])
|
||||||
}
|
}
|
||||||
|
|
||||||
startTime = getTicks();
|
startTime = getTicks();
|
||||||
|
handleEvents();
|
||||||
if(!thePauseIndicator)
|
if(!thePauseIndicator)
|
||||||
{
|
{
|
||||||
theConsole->mediaSource().update();
|
theConsole->mediaSource().update();
|
||||||
}
|
|
||||||
updateDisplay(theConsole->mediaSource());
|
|
||||||
if(!thePauseIndicator)
|
|
||||||
{
|
|
||||||
sound.updateSound(theConsole->mediaSource());
|
sound.updateSound(theConsole->mediaSource());
|
||||||
}
|
}
|
||||||
handleEvents();
|
updateDisplay(theConsole->mediaSource());
|
||||||
|
|
||||||
currentTime = getTicks();
|
currentTime = getTicks();
|
||||||
virtualTime += timePerFrame;
|
virtualTime += timePerFrame;
|
||||||
|
@ -1805,7 +1810,7 @@ int main(int argc, char* argv[])
|
||||||
}
|
}
|
||||||
|
|
||||||
// Cleanup time ...
|
// Cleanup time ...
|
||||||
sound.close();
|
sound.closeDevice();
|
||||||
cleanup();
|
cleanup();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue