From 9e9863230f9f95a7eb298ce15d060bcefbe8b25f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Th=C3=A9o=20Monnom?= Date: Mon, 30 Sep 2024 23:57:58 -0700 Subject: [PATCH] fix wait_for_playout finishing too early (#270) --- livekit-rtc/livekit/rtc/audio_source.py | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/livekit-rtc/livekit/rtc/audio_source.py b/livekit-rtc/livekit/rtc/audio_source.py index bb287c7f..2c32d61b 100644 --- a/livekit-rtc/livekit/rtc/audio_source.py +++ b/livekit-rtc/livekit/rtc/audio_source.py @@ -67,7 +67,8 @@ def __init__( self._info = resp.new_audio_source.source self._ffi_handle = FfiHandle(self._info.handle.id) - self._last_capture = self._q_size = 0.0 + self._last_capture = 0.0 + self._q_size = 0.0 self._join_handle: asyncio.TimerHandle | None = None self._join_fut: asyncio.Future[None] = self._loop.create_future() @@ -128,11 +129,7 @@ async def capture_frame(self, frame: AudioFrame) -> None: if self._join_fut.done(): self._join_fut = self._loop.create_future() - # remove 50ms to account for processing time - # (e.g. using wait_for_playout for very small chunks) - self._join_handle = self._loop.call_later( - self._q_size - 0.05, self._release_waiter - ) + self._join_handle = self._loop.call_later(self._q_size, self._release_waiter) req = proto_ffi.FfiRequest() req.capture_audio_frame.source_handle = self._ffi_handle.handle