mkfifo.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /* vi: set sw=4 ts=4: */
  2. /*
  3. * mkfifo implementation for busybox
  4. *
  5. * Copyright (C) 2003 Manuel Novoa III <mjn3@codepoet.org>
  6. *
  7. * Licensed under GPLv2 or later, see file LICENSE in this source tree.
  8. */
  9. //config:config MKFIFO
  10. //config: bool "mkfifo"
  11. //config: default y
  12. //config: help
  13. //config: mkfifo is used to create FIFOs (named pipes).
  14. //config: The 'mknod' program can also create FIFOs.
  15. //applet:IF_MKFIFO(APPLET_NOEXEC(mkfifo, mkfifo, BB_DIR_USR_BIN, BB_SUID_DROP, mkfifo))
  16. //kbuild:lib-$(CONFIG_MKFIFO) += mkfifo.o
  17. /* BB_AUDIT SUSv3 compliant */
  18. /* http://www.opengroup.org/onlinepubs/007904975/utilities/mkfifo.html */
  19. //usage:#define mkfifo_trivial_usage
  20. //usage: "[-m MODE] " IF_SELINUX("[-Z] ") "NAME"
  21. //usage:#define mkfifo_full_usage "\n\n"
  22. //usage: "Create named pipe\n"
  23. //usage: "\n -m MODE Mode (default a=rw)"
  24. //usage: IF_SELINUX(
  25. //usage: "\n -Z Set security context"
  26. //usage: )
  27. #include "libbb.h"
  28. #include "libcoreutils/coreutils.h"
  29. /* This is a NOEXEC applet. Be very careful! */
  30. int mkfifo_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
  31. int mkfifo_main(int argc UNUSED_PARAM, char **argv)
  32. {
  33. mode_t mode;
  34. int retval = EXIT_SUCCESS;
  35. mode = getopt_mk_fifo_nod(argv);
  36. argv += optind;
  37. if (!*argv) {
  38. bb_show_usage();
  39. }
  40. do {
  41. if (mkfifo(*argv, mode) < 0) {
  42. bb_simple_perror_msg(*argv); /* Avoid multibyte problems. */
  43. retval = EXIT_FAILURE;
  44. }
  45. } while (*++argv);
  46. return retval;
  47. }