Allow 'gzip -d' and 'bzip2 -d' without gunzip or bunzip2
[oweals/busybox.git] / coreutils / cat.c
index d828b86ec3dcf147205b48b2686297773a51c24a..65978887e149bc939c2184b61efb7e67480cffb0 100644 (file)
@@ -4,30 +4,53 @@
  *
  * Copyright (C) 2003  Manuel Novoa III  <mjn3@codepoet.org>
  *
- * Licensed under GPLv2, see file License in this tarball for details.
+ * Licensed under GPLv2, see file LICENSE in this source tree.
  */
+//config:config CAT
+//config:      bool "cat"
+//config:      default y
+//config:      help
+//config:        cat is used to concatenate files and print them to the standard
+//config:        output. Enable this option if you wish to enable the 'cat' utility.
+
+//applet:IF_CAT(APPLET_NOFORK(cat, cat, BB_DIR_BIN, BB_SUID_DROP, cat))
+
+//kbuild:lib-$(CONFIG_CAT)     += cat.o
 
 /* BB_AUDIT SUSv3 compliant */
 /* http://www.opengroup.org/onlinepubs/007904975/utilities/cat.html */
 
-#include "busybox.h"
+//usage:#define cat_trivial_usage
+//usage:       "[FILE]..."
+//usage:#define cat_full_usage "\n\n"
+//usage:       "Concatenate FILEs and print them to stdout"
+//usage:
+//usage:#define cat_example_usage
+//usage:       "$ cat /proc/uptime\n"
+//usage:       "110716.72 17.67"
+
+#include "libbb.h"
+
+/* This is a NOFORK applet. Be very careful! */
+
 
 int bb_cat(char **argv)
 {
-       static char *const argv_dash[] = { "-", NULL };
-       FILE *f;
+       int fd;
        int retval = EXIT_SUCCESS;
 
-       if (!*argv) argv = (char**) &argv_dash;
+       if (!*argv)
+               argv = (char**) &bb_argv_dash;
 
        do {
-               f = fopen_or_warn_stdin(*argv);
-               if (f) {
-                       off_t r = bb_copyfd_eof(fileno(f), STDOUT_FILENO);
-                       fclose_if_not_stdin(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);
@@ -35,9 +58,10 @@ int bb_cat(char **argv)
        return retval;
 }
 
-int cat_main(int argc, char **argv)
+int cat_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
+int cat_main(int argc UNUSED_PARAM, char **argv)
 {
-       getopt32(argc, argv, "u");
+       getopt32(argv, "u");
        argv += optind;
        return bb_cat(argv);
 }