X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=coreutils%2Fcat.c;h=0024eb8d5e11262dd3061952043cf42a131765ed;hb=8d680b51148b9cbe7dd3afd37022f3390dd999ef;hp=10eb29c4d65437d14d8fc6421936cbf2b92c7f0d;hpb=7039a66b58706457c7423de60556e04545432943;p=oweals%2Fbusybox.git diff --git a/coreutils/cat.c b/coreutils/cat.c index 10eb29c4d..0024eb8d5 100644 --- a/coreutils/cat.c +++ b/coreutils/cat.c @@ -10,32 +10,39 @@ /* BB_AUDIT SUSv3 compliant */ /* http://www.opengroup.org/onlinepubs/007904975/utilities/cat.html */ -#include "busybox.h" -#include +#include "libbb.h" -int cat_main(int argc, char **argv) +/* This is a NOFORK applet. Be very careful! */ + + +int bb_cat(char **argv) { - FILE *f; + int fd; int retval = EXIT_SUCCESS; - getopt32(argc, argv, "u"); - - argv += optind; - if (!*argv) { - *--argv = "-"; - } + if (!*argv) + argv = (char**) &bb_argv_dash; do { - f = bb_wfopen_input(*argv); - if (f) { - off_t r = bb_copyfd_eof(fileno(f), STDOUT_FILENO); - bb_fclose_nonstdin(f); - if (r >= 0) { + fd = open_or_warn_stdin(*argv); + if (fd >= 0) { + /* This is not a xfunc - never exits */ + off_t r = bb_copyfd_eof(fd, STDOUT_FILENO); + if (fd != STDIN_FILENO) + close(fd); + if (r >= 0) continue; - } } retval = EXIT_FAILURE; } while (*++argv); return retval; } + +int cat_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; +int cat_main(int argc UNUSED_PARAM, char **argv) +{ + getopt32(argv, "u"); + argv += optind; + return bb_cat(argv); +}