From afa01962776013e8468de562e26aab59aaf53d69 Mon Sep 17 00:00:00 2001
From: Lorenz Stechauner <lorenz.stechauner@necronda.net>
Date: Sat, 8 Jul 2023 01:05:18 +0200
Subject: [PATCH] Async: ignore ENOENT errors on remove

---
 src/async.c | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)

diff --git a/src/async.c b/src/async.c
index 61ca1ed..2f31e04 100644
--- a/src/async.c
+++ b/src/async.c
@@ -286,8 +286,8 @@ void async_thread(void) {
             if (async_exec(evt, async_e2a(events[i].events)) == 0) {
                 logger_set_prefix("");
                 if (epoll_ctl(epoll_fd, EPOLL_CTL_DEL, evt->fd, NULL) == -1) {
-                    if (errno == EBADF) {
-                        // already closed fd, do not die
+                    if (errno == EBADF || errno == ENOENT) {
+                        // already closed fd or not found, do not die
                         errno = 0;
                     } else {
                         critical("Unable to remove file descriptor from epoll instance");
@@ -316,8 +316,8 @@ void async_thread(void) {
                 evt->to_cb(evt->arg);
 
                 if (epoll_ctl(epoll_fd, EPOLL_CTL_DEL, evt->fd, NULL) == -1) {
-                    if (errno == EBADF) {
-                        // already closed fd, do not die
+                    if (errno == EBADF || errno == ENOENT) {
+                        // already closed fd or not found, do not die
                         errno = 0;
                     } else {
                         critical("Unable to remove file descriptor from epoll instance");