changeset 759:143a9729fec8

Extend seq to support -f (format string) and -s (string separator) as requested by LSB
author Elie De Brauwer <eliedebrauwer@gmail.com>
date Sun, 16 Dec 2012 17:58:25 +0100
parents 54d248b907ed
children 41b067739bd0
files scripts/test/seq.test toys/lsb/seq.c
diffstat 2 files changed, 24 insertions(+), 4 deletions(-) [+]
line wrap: on
line diff
--- a/scripts/test/seq.test	Sat Dec 22 11:50:11 2012 +0100
+++ b/scripts/test/seq.test	Sun Dec 16 17:58:25 2012 +0100
@@ -22,4 +22,7 @@
 testing "seq count by .3" "seq 3 .3 4" "3\n3.3\n3.6\n3.9\n" "" ""
 testing "seq count by -.9" "seq .7 -.9 -2.2" "0.7\n-0.2\n-1.1\n-2\n" "" ""
 testing "seq count by zero" "seq 4 0 8 | head -n 10" "" "" ""
+testing "seq separator -" "seq -s - 1 3" "1-2-3\n" "" ""
+testing "seq format string" 'seq -f %+01g -10 5 10' "-10\n-5\n+0\n+5\n+10\n" "" ""
+testing "seq separator and format string" "seq -f \%03g -s \; 5 -1 0" "005;004;003;002;001;000\n" "" ""
 
--- a/toys/lsb/seq.c	Sat Dec 22 11:50:11 2012 +0100
+++ b/toys/lsb/seq.c	Sun Dec 16 17:58:25 2012 +0100
@@ -4,26 +4,36 @@
  *
  * http://refspecs.linuxfoundation.org/LSB_4.1.0/LSB-Core-generic/LSB-Core-generic/seq.html
 
-USE_SEQ(NEWTOY(seq, "<1>3?", TOYFLAG_USR|TOYFLAG_BIN))
+USE_SEQ(NEWTOY(seq, "<1>3?f:s:", TOYFLAG_USR|TOYFLAG_BIN))
 
 config SEQ
   bool "seq"
   depends on TOYBOX_FLOAT
   default y
   help
-    usage: seq [first] [increment] last
+    usage: seq [-f fmt_str] [-s sep_str] [first] [increment] last
 
     Count from first to last, by increment. Omitted arguments default
     to 1. Two arguments are used as first and last. Arguments can be
     negative or floating point.
+    -f	Use fmt_str as a floating point format string
+    -s	Use sep_str as separator, default is a newline character
 */
 
+#define FOR_seq
 #include "toys.h"
 
+GLOBALS(
+  char * sep;
+  char * fmt;
+)
+
 void seq_main(void)
 {
   double first, increment, last, dd;
-
+  char * sep_str = "\n";
+  char * fmt_str = "%g";
+  int output = 0;
   // Parse command line arguments, with appropriate defaults.
   // Note that any non-numeric arguments are treated as zero.
   first = increment = 1;
@@ -33,11 +43,18 @@
     default: last = atof(toys.optargs[toys.optc-1]);
   }
 
+  if (toys.optflags & FLAG_f) fmt_str = TT.fmt;
+  if (toys.optflags & FLAG_s) sep_str = TT.sep;
+
   // Yes, we're looping on a double.  Yes rounding errors can accumulate if
   // you use a non-integer increment.  Deal with it.
   for (dd=first; (increment>0 && dd<=last) || (increment<0 && dd>=last);
     dd+=increment)
   {
-    printf("%g\n", dd);
+    if (dd != first) printf("%s", sep_str);
+    printf(fmt_str, dd);
+    output = 1;
   }
+
+  if (output) printf("\n");
 }