SDL: Allow vbam to run on systems without an audio device. Thanks to jcranmer for the patch.

git-svn-id: https://svn.code.sf.net/p/vbam/code/trunk@980 a31d4220-a93d-0410-bf67-fe4944624d44
This commit is contained in:
bgk 2011-02-20 09:25:07 +00:00
parent e87b5c4829
commit d9285a2bab
3 changed files with 19 additions and 3 deletions

2
debian/control vendored
View File

@ -2,7 +2,7 @@ Source: vbam
Section: otherosfs Section: otherosfs
Priority: optional Priority: optional
Maintainer: Fernando Tarlá Cardoso Lemos <fernandotcl@gmail.com> Maintainer: Fernando Tarlá Cardoso Lemos <fernandotcl@gmail.com>
Build-Depends: debhelper (>= 7), cmake, nasm [i386 amd64], libsdl1.2-dev, libgl-dev, libgtkmm-2.4-dev, libgtkglextmm-x11-1.2-dev, libglademm-2.4-dev, libsfml-dev Build-Depends: debhelper (>= 7), cmake, nasm [i386 amd64], libsdl1.2-dev, libgl-dev, libgtkmm-2.4-dev, libgtkglextmm-x11-1.2-dev, libsfml-dev
Standards-Version: 3.8.1 Standards-Version: 3.8.1
Homepage: http://www.vbam.com Homepage: http://www.vbam.com

View File

@ -24,7 +24,8 @@ extern bool speedup;
const float SoundSDL::_delay = 0.1f; const float SoundSDL::_delay = 0.1f;
SoundSDL::SoundSDL(): SoundSDL::SoundSDL():
_rbuf(0) _rbuf(0),
_initialized(false)
{ {
} }
@ -36,7 +37,7 @@ void SoundSDL::soundCallback(void *data, u8 *stream, int len)
void SoundSDL::read(u16 * stream, int length) void SoundSDL::read(u16 * stream, int length)
{ {
if (length <= 0 || !emulating) if (!_initialized || length <= 0 || !emulating)
return; return;
SDL_mutexP(_mutex); SDL_mutexP(_mutex);
@ -49,6 +50,9 @@ void SoundSDL::read(u16 * stream, int length)
void SoundSDL::write(u16 * finalWave, int length) void SoundSDL::write(u16 * finalWave, int length)
{ {
if (!_initialized)
return;
if (SDL_GetAudioStatus() != SDL_AUDIO_PLAYING) if (SDL_GetAudioStatus() != SDL_AUDIO_PLAYING)
SDL_PauseAudio(0); SDL_PauseAudio(0);
@ -104,12 +108,16 @@ bool SoundSDL::init(long sampleRate)
_cond = SDL_CreateCond(); _cond = SDL_CreateCond();
_mutex = SDL_CreateMutex(); _mutex = SDL_CreateMutex();
_initialized = true;
return true; return true;
} }
SoundSDL::~SoundSDL() SoundSDL::~SoundSDL()
{ {
if (!_initialized)
return;
SDL_mutexP(_mutex); SDL_mutexP(_mutex);
int iSave = emulating; int iSave = emulating;
emulating = 0; emulating = 0;
@ -129,11 +137,17 @@ SoundSDL::~SoundSDL()
void SoundSDL::pause() void SoundSDL::pause()
{ {
if (!_initialized)
return;
SDL_PauseAudio(1); SDL_PauseAudio(1);
} }
void SoundSDL::resume() void SoundSDL::resume()
{ {
if (!_initialized)
return;
SDL_PauseAudio(0); SDL_PauseAudio(0);
} }

View File

@ -41,6 +41,8 @@ private:
SDL_cond * _cond; SDL_cond * _cond;
SDL_mutex * _mutex; SDL_mutex * _mutex;
bool _initialized;
// Defines what delay in seconds we keep in the sound buffer // Defines what delay in seconds we keep in the sound buffer
static const float _delay; static const float _delay;