aboutsummaryrefslogtreecommitdiff
path: root/backend/session
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2020-11-06 09:57:03 +0100
committerSimon Ser <contact@emersion.fr>2020-11-19 22:47:49 +0100
commit63df2bcbe656b394b0bd152ab69147194dd74815 (patch)
treea1fa4407cdf9ac9ed39e01012346d39d720ff9d2 /backend/session
parentfb3bea80144ea25fb21de8a3eeb0c9249f4cbfd6 (diff)
backend/session: don't return FD on failure in open_file
When wlr_session_open_file fails, don't return the FD, otherwise the caller will think the call succeeded.
Diffstat (limited to 'backend/session')
-rw-r--r--backend/session/session.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/backend/session/session.c b/backend/session/session.c
index d8e9509d..e3e108af 100644
--- a/backend/session/session.c
+++ b/backend/session/session.c
@@ -6,6 +6,7 @@
#include <string.h>
#include <sys/stat.h>
#include <sys/types.h>
+#include <unistd.h>
#include <wayland-server-core.h>
#include <wlr/backend/session.h>
#include <wlr/backend/session/interface.h>
@@ -195,7 +196,8 @@ int wlr_session_open_file(struct wlr_session *session, const char *path) {
error:
free(dev);
- return fd;
+ close(fd);
+ return -1;
}
static struct wlr_device *find_device(struct wlr_session *session, int fd) {