Issue #18174: Explain why is_valid_fd() uses dup() instead of fstat()

This commit is contained in:
Victor Stinner 2015-09-29 13:59:50 +02:00
parent 3f7468507a
commit 449b271799
1 changed files with 3 additions and 0 deletions

View File

@ -972,6 +972,9 @@ is_valid_fd(int fd)
if (fd < 0 || !_PyVerify_fd(fd))
return 0;
_Py_BEGIN_SUPPRESS_IPH
/* Prefer dup() over fstat(). fstat() can require input/output whereas
dup() doesn't, there is a low risk of EMFILE/ENFILE at Python
startup. */
fd2 = dup(fd);
if (fd2 >= 0)
close(fd2);