output/fifo: implement output_plugin method delay()

This commit is contained in:
Max Kellermann 2011-12-13 21:12:48 +01:00
parent e01df06cd7
commit b66d7f7e0b

View File

@ -259,6 +259,16 @@ fifo_output_cancel(struct audio_output *ao)
}
}
static unsigned
fifo_output_delay(struct audio_output *ao)
{
struct fifo_data *fd = (struct fifo_data *)ao;
return fd->timer->started
? timer_delay(fd->timer)
: 0;
}
static size_t
fifo_output_play(struct audio_output *ao, const void *chunk, size_t size,
GError **error)
@ -268,9 +278,6 @@ fifo_output_play(struct audio_output *ao, const void *chunk, size_t size,
if (!fd->timer->started)
timer_start(fd->timer);
else
timer_sync(fd->timer);
timer_add(fd->timer, size);
while (true) {
@ -302,6 +309,7 @@ const struct audio_output_plugin fifo_output_plugin = {
.finish = fifo_output_finish,
.open = fifo_output_open,
.close = fifo_output_close,
.delay = fifo_output_delay,
.play = fifo_output_play,
.cancel = fifo_output_cancel,
};