cloexec.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. /* cloexec.c - set or clear the close-on-exec descriptor flag
  2. Copyright (C) 2004, 2009-2022 Free Software Foundation, Inc.
  3. This file is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU Lesser General Public License as
  5. published by the Free Software Foundation; either version 2.1 of the
  6. License, or (at your option) any later version.
  7. This file is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU Lesser General Public License for more details.
  11. You should have received a copy of the GNU Lesser General Public License
  12. along with this program. If not, see <https://www.gnu.org/licenses/>. */
  13. #include <stdbool.h>
  14. /* Set the 'FD_CLOEXEC' flag of DESC if VALUE is true,
  15. or clear the flag if VALUE is false.
  16. Return 0 on success, or -1 on error with 'errno' set.
  17. Note that on MingW, this function does NOT protect DESC from being
  18. inherited into spawned children. Instead, either use dup_cloexec
  19. followed by closing the original DESC, or use interfaces such as
  20. open or pipe2 that accept flags like O_CLOEXEC to create DESC
  21. non-inheritable in the first place. */
  22. int set_cloexec_flag (int desc, bool value);
  23. /* Duplicates a file handle FD, while marking the copy to be closed
  24. prior to exec or spawn. Returns -1 and sets errno if FD could not
  25. be duplicated. */
  26. int dup_cloexec (int fd);