output/winmm: show detailed error messages

This commit is contained in:
Max Kellermann 2014-12-17 19:43:14 +01:00
parent 43f3cdcd24
commit 25f89afbfb

View File

@ -56,6 +56,18 @@ struct WinmmOutput {
static constexpr Domain winmm_output_domain("winmm_output"); static constexpr Domain winmm_output_domain("winmm_output");
static void
SetWaveOutError(Error &error, MMRESULT result, const char *prefix)
{
char buffer[256];
if (waveOutGetErrorTextA(result, buffer,
ARRAY_SIZE(buffer)) == MMSYSERR_NOERROR)
error.Format(winmm_output_domain, int(result),
"%s: %s", prefix, buffer);
else
error.Set(winmm_output_domain, int(result), prefix);
}
HWAVEOUT HWAVEOUT
winmm_output_get_handle(WinmmOutput &output) winmm_output_get_handle(WinmmOutput &output)
{ {
@ -179,7 +191,7 @@ winmm_output_open(AudioOutput *ao, AudioFormat &audio_format,
(DWORD_PTR)wo->event, 0, CALLBACK_EVENT); (DWORD_PTR)wo->event, 0, CALLBACK_EVENT);
if (result != MMSYSERR_NOERROR) { if (result != MMSYSERR_NOERROR) {
CloseHandle(wo->event); CloseHandle(wo->event);
error.Set(winmm_output_domain, "waveOutOpen() failed"); SetWaveOutError(error, result, "waveOutOpen() failed");
return false; return false;
} }
@ -225,8 +237,8 @@ winmm_set_buffer(WinmmOutput *wo, WinmmBuffer *buffer,
MMRESULT result = waveOutPrepareHeader(wo->handle, &buffer->hdr, MMRESULT result = waveOutPrepareHeader(wo->handle, &buffer->hdr,
sizeof(buffer->hdr)); sizeof(buffer->hdr));
if (result != MMSYSERR_NOERROR) { if (result != MMSYSERR_NOERROR) {
error.Set(winmm_output_domain, result, SetWaveOutError(error, result,
"waveOutPrepareHeader() failed"); "waveOutPrepareHeader() failed");
return false; return false;
} }
@ -251,8 +263,8 @@ winmm_drain_buffer(WinmmOutput *wo, WinmmBuffer *buffer,
if (result == MMSYSERR_NOERROR) if (result == MMSYSERR_NOERROR)
return true; return true;
else if (result != WAVERR_STILLPLAYING) { else if (result != WAVERR_STILLPLAYING) {
error.Set(winmm_output_domain, result, SetWaveOutError(error, result,
"waveOutUnprepareHeader() failed"); "waveOutUnprepareHeader() failed");
return false; return false;
} }
@ -278,8 +290,7 @@ winmm_output_play(AudioOutput *ao, const void *chunk, size_t size, Error &error)
if (result != MMSYSERR_NOERROR) { if (result != MMSYSERR_NOERROR) {
waveOutUnprepareHeader(wo->handle, &buffer->hdr, waveOutUnprepareHeader(wo->handle, &buffer->hdr,
sizeof(buffer->hdr)); sizeof(buffer->hdr));
error.Set(winmm_output_domain, result, SetWaveOutError(error, result, "waveOutWrite() failed");
"waveOutWrite() failed");
return 0; return 0;
} }