ntpd: default to FEATURE_NTP_AUTH=y
[oweals/busybox.git] / coreutils / cat.c
index 178f96b0994f0b1cde1ee2529a38d677fc15a8c4..fb735f994092d91961bd9dc2a388e8e40fa9fe83 100644 (file)
@@ -7,25 +7,25 @@
  * Licensed under GPLv2, see file LICENSE in this source tree.
  */
 //config:config CAT
-//config:      bool "cat"
+//config:      bool "cat (5.6 kb)"
 //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.
+//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.
 //config:
 //config:config FEATURE_CATN
 //config:      bool "Enable -n and -b options"
 //config:      default y
 //config:      depends on CAT
 //config:      help
-//config:        -n numbers all output lines while -b numbers nonempty output lines.
+//config:      -n numbers all output lines while -b numbers nonempty output lines.
 //config:
 //config:config FEATURE_CATV
 //config:      bool "cat -v[etA]"
 //config:      default y
 //config:      depends on CAT
 //config:      help
-//config:        Display nonprinting characters as escape sequences
+//config:      Display nonprinting characters as escape sequences
 
 //applet:IF_CAT(APPLET(cat, BB_DIR_BIN, BB_SUID_DROP))
 
  * to achieve "cat -v" effect. The actual effect would be "users pissed off
  * by gratuitous incompatibility".
  */
-#define CATV_OPT_e (1<<0)
-#define CATV_OPT_t (1<<1)
-#define CATV_OPT_v (1<<2)
+#define CAT_OPT_e (1<<0)
+#define CAT_OPT_t (1<<1)
+#define CAT_OPT_v (1<<2)
+/* -A occupies bit (1<<3) */
+#define CAT_OPT_n ((1<<4) * ENABLE_FEATURE_CATN)
+#define CAT_OPT_b ((1<<5) * ENABLE_FEATURE_CATN)
 static int catv(unsigned opts, char **argv)
 {
        int retval = EXIT_SUCCESS;
        int fd;
+#if ENABLE_FEATURE_CATN
+       bool eol_seen = (opts & (CAT_OPT_n|CAT_OPT_b));
+       unsigned eol_char = (eol_seen ? '\n' : 0x100);
+       unsigned skip_num_on = (opts & CAT_OPT_b) ? '\n' : 0x100;
+       unsigned lineno = 0;
+#endif
 
-       BUILD_BUG_ON(CATV_OPT_e != VISIBLE_ENDLINE);
-       BUILD_BUG_ON(CATV_OPT_t != VISIBLE_SHOW_TABS);
+       BUILD_BUG_ON(CAT_OPT_e != VISIBLE_ENDLINE);
+       BUILD_BUG_ON(CAT_OPT_t != VISIBLE_SHOW_TABS);
 #if 0 /* These consts match, we can just pass "opts" to visible() */
-       if (opts & CATV_OPT_e)
+       if (opts & CAT_OPT_e)
                flags |= VISIBLE_ENDLINE;
-       if (opts & CATV_OPT_t)
+       if (opts & CAT_OPT_t)
                flags |= VISIBLE_SHOW_TABS;
 #endif
 
-       /* Read from stdin if there's nothing else to do. */
-       if (!argv[0])
-               *--argv = (char*)"-";
-
 #define read_buf bb_common_bufsiz1
        setup_common_bufsiz();
        do {
@@ -141,6 +146,11 @@ static int catv(unsigned opts, char **argv)
                        for (i = 0; i < res; i++) {
                                unsigned char c = read_buf[i];
                                char buf[sizeof("M-^c")];
+#if ENABLE_FEATURE_CATN
+                               if (eol_seen && c != skip_num_on)
+                                       printf("%6u  ", ++lineno);
+                               eol_seen = (c == eol_char);
+#endif
                                visible(c, buf, opts);
                                fputs(buf, stdout);
                        }
@@ -151,23 +161,32 @@ static int catv(unsigned opts, char **argv)
 
        fflush_stdout_and_exit(retval);
 }
+#undef CAT_OPT_n
+#undef CAT_OPT_b
 #endif
 
 int cat_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
 int cat_main(int argc UNUSED_PARAM, char **argv)
 {
-       struct number_state ns;
+#if ENABLE_FEATURE_CATV || ENABLE_FEATURE_CATN
        unsigned opts;
 
-       IF_FEATURE_CATV(opt_complementary = "Aetv"; /* -A == -vet */)
-       /* -u is ignored ("unbuffered") */
-       opts = getopt32(argv, IF_FEATURE_CATV("etvA") IF_FEATURE_CATN("nb") "u");
+       opts =
+#endif
+       getopt32(argv, IF_FEATURE_CATV("^")
+               /* -u is ignored ("unbuffered") */
+               IF_FEATURE_CATV("etvA")IF_FEATURE_CATN("nb")"u"
+               IF_FEATURE_CATV("\0" "Aetv" /* -A == -vet */)
+       );
        argv += optind;
 
+       /* Read from stdin if there's nothing else to do. */
+       if (!argv[0])
+               *--argv = (char*)"-";
+
 #if ENABLE_FEATURE_CATV
        if (opts & 7)
                return catv(opts, argv);
-//BUG: -v,-e,-t,-A ignore -nb
        opts >>= 4;
 #endif
 
@@ -175,8 +194,8 @@ int cat_main(int argc UNUSED_PARAM, char **argv)
 # define CAT_OPT_n (1<<0)
 # define CAT_OPT_b (1<<1)
        if (opts & (CAT_OPT_n|CAT_OPT_b)) { /* -n or -b */
-               if (!*argv)
-                       *--argv = (char*)"-";
+               struct number_state ns;
+
                ns.width = 6;
                ns.start = 1;
                ns.inc = 1;