posix_spawn(): Do not fail when trying to close an fd that is not open.
As noted in Austin Group issue #370 (an interpretation has been issued), failing posix_spawn() because an fd specified with posix_spawn_file_actions_addclose() is not open is unnecessarily harsh, and there are existing implementations that do not fail posix_spawn() for this reason. Reviewed by: ed MFC after: 10 days
This commit is contained in:
parent
56599263c5
commit
562b28821e
@ -163,11 +163,8 @@ process_file_actions_entry(posix_spawn_file_actions_entry_t *fae)
|
|||||||
return (errno);
|
return (errno);
|
||||||
break;
|
break;
|
||||||
case FAE_CLOSE:
|
case FAE_CLOSE:
|
||||||
/* Perform a close() */
|
/* Perform a close(), do not fail if already closed */
|
||||||
if (_close(fae->fae_fildes) != 0) {
|
(void)_close(fae->fae_fildes);
|
||||||
if (errno == EBADF)
|
|
||||||
return (EBADF);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return (0);
|
return (0);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user