From 2070a7b87a3821b6abbc49ba65d61de33f5480ac Mon Sep 17 00:00:00 2001 From: ThibaultBee <37510686+ThibaultBee@users.noreply.github.com> Date: Mon, 2 Sep 2024 14:51:16 +0200 Subject: [PATCH] fix(ktx): do not throw an exception when epoll does not have a valid socket. --- .../github/thibaultbee/srtdroid/ktx/CoroutineSrtSocket.kt | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/srtdroid-ktx/src/main/java/io/github/thibaultbee/srtdroid/ktx/CoroutineSrtSocket.kt b/srtdroid-ktx/src/main/java/io/github/thibaultbee/srtdroid/ktx/CoroutineSrtSocket.kt index 952f8945..ab5aede7 100644 --- a/srtdroid-ktx/src/main/java/io/github/thibaultbee/srtdroid/ktx/CoroutineSrtSocket.kt +++ b/srtdroid-ktx/src/main/java/io/github/thibaultbee/srtdroid/ktx/CoroutineSrtSocket.kt @@ -8,8 +8,8 @@ import io.github.thibaultbee.srtdroid.core.enums.SockOpt import io.github.thibaultbee.srtdroid.core.enums.SockStatus import io.github.thibaultbee.srtdroid.core.interfaces.ConfigurableSrtSocket import io.github.thibaultbee.srtdroid.core.models.Epoll -import io.github.thibaultbee.srtdroid.core.models.SrtError import io.github.thibaultbee.srtdroid.core.models.MsgCtrl +import io.github.thibaultbee.srtdroid.core.models.SrtError import io.github.thibaultbee.srtdroid.core.models.SrtSocket import io.github.thibaultbee.srtdroid.core.models.SrtSocket.ServerListener import io.github.thibaultbee.srtdroid.core.models.Stats @@ -756,6 +756,7 @@ private constructor( block: () -> T ): T { val epoll = Epoll() + // flags = listOf(EpollFlag.ENABLE_EMPTY) epoll.addUSock(socket, listOf(EpollOpt.ERR, epollOpt)) try { @@ -803,7 +804,9 @@ private constructor( val epollEvents = try { epoll.uWait(POLLING_TIMEOUT_IN_MS) } catch (e: Exception) { - continuation.resumeWithException(SocketException(SrtError.lastErrorMessage)) + if (SrtError.lastError != ErrorType.EPOLLEMPTY) { + continuation.resumeWithException(SocketException(SrtError.lastErrorMessage)) + } return@suspendCancellableCoroutine } if (epollEvents.isEmpty()) {