Commit 6dc14523 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

open: O_CLOEXEC is ignored by older kernel, fix & simplify

parent 6ec51c91
...@@ -99,6 +99,10 @@ int utf8_open (const char *filename, int flags, ...) ...@@ -99,6 +99,10 @@ int utf8_open (const char *filename, int flags, ...)
mode = va_arg (ap, unsigned int); mode = va_arg (ap, unsigned int);
va_end (ap); va_end (ap);
#ifdef O_CLOEXEC
flags |= O_CLOEXEC;
#endif
#ifdef UNDER_CE #ifdef UNDER_CE
/*_open translates to wchar internally on WinCE*/ /*_open translates to wchar internally on WinCE*/
return _open (filename, flags, mode); return _open (filename, flags, mode);
...@@ -119,22 +123,11 @@ int utf8_open (const char *filename, int flags, ...) ...@@ -119,22 +123,11 @@ int utf8_open (const char *filename, int flags, ...)
return -1; return -1;
} }
int fd; int fd = open (local_name, flags | O_CLOEXEC, mode);
#ifdef O_CLOEXEC
fd = open (local_name, flags | O_CLOEXEC, mode);
if (fd == -1 && errno == EINVAL)
#endif
{
fd = open (local_name, flags, mode);
#ifdef HAVE_FCNTL #ifdef HAVE_FCNTL
if (fd != -1) if (fd != -1)
{ fcntl (fd, F_SETFD, FD_CLOEXEC);
int flags = fcntl (fd, F_GETFD);
fcntl (fd, F_SETFD, FD_CLOEXEC | ((flags != -1) ? flags : 0));
}
#endif #endif
}
LocaleFree (local_name); LocaleFree (local_name);
return fd; return fd;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment