ao: support all libao error codes

The function audioOutputAo_error() did not implement all possible
libao error codes.  Support the rest of them, and fall back to
strerror().
This commit is contained in:
Max Kellermann 2008-11-25 16:17:48 +01:00
parent ffc604498e
commit 423276a384

View File

@ -42,15 +42,36 @@ static AoData *newAoData(void)
return ret; return ret;
} }
static void audioOutputAo_error(void) static void audioOutputAo_error(const char *msg)
{ {
if (errno == AO_ENOTLIVE) { const char *error;
g_warning("not a live ao device\n");
} else if (errno == AO_EOPENDEVICE) { switch (errno) {
g_warning("not able to open audio device\n"); case AO_ENODRIVER:
} else if (errno == AO_EBADOPTION) { error = "No such libao driver";
g_warning("bad driver option\n"); break;
case AO_ENOTLIVE:
error = "This driver is not a libao live device";
break;
case AO_EBADOPTION:
error = "Invalid libao option";
break;
case AO_EOPENDEVICE:
error = "Cannot open the libao device";
break;
case AO_EFAIL:
error = "Generic libao failure";
break;
default:
error = strerror(errno);
} }
g_warning("%s: %s\n", msg, error);
} }
static void *audioOutputAo_initDriver(struct audio_output *ao, static void *audioOutputAo_initDriver(struct audio_output *ao,
@ -224,8 +245,7 @@ audioOutputAo_play(void *data, const char *playChunk, size_t size)
? size : (size_t)ad->writeSize; ? size : (size_t)ad->writeSize;
if (ao_play_deconst(ad->device, playChunk, chunk_size) == 0) { if (ao_play_deconst(ad->device, playChunk, chunk_size) == 0) {
audioOutputAo_error(); audioOutputAo_error("Closing libao device due to play error");
g_warning("closing audio device due to write error\n");
return false; return false;
} }