Found and fixed some strings bugs. duh.
>From 2a5b48249df851fbab0cb7af3d0f5d45bf2aee37 Mon Sep 17 00:00:00 2001
From: Ilya Kuzmich <ilya.kuzm...@gmail.com>
Date: Mon, 29 May 2017 07:05:16 +0300
Subject: [PATCH] strings tests and  bugfixes

Fixes missing newline in output if last byte of the input is string.
Fixes one-off offset bug.
Adds strings tests.

Signed-off-by: Ilya Kuzmich <ilya.kuzm...@gmail.com>
---
 tests/strings.test   | 20 ++++++++++++++++++++
 toys/posix/strings.c |  7 +++++--
 2 files changed, 25 insertions(+), 2 deletions(-)
 create mode 100644 tests/strings.test

diff --git a/tests/strings.test b/tests/strings.test
new file mode 100644
index 0000000..8becc2f
--- /dev/null
+++ b/tests/strings.test
@@ -0,0 +1,20 @@
+#!/bin/bash
+
+[ -f testing.sh ] && . testing.sh
+
+#testing "name" "command" "result" "infile" "stdin"
+
+testing "stdin" "strings" "foobar\n" "" "foobar\n"
+testing "file" "strings input" "foobar\n" "foobar\n" ""
+testing "string to the end" "strings input" "foobar\n" "foobar" ""
+testing "short strings" "strings input" "" "foo\nbar\n" ""
+testing "-n6" "strings -n6 input" "foobar\n" "foobar\nbaz\n" ""
+testing "string and nulls" "strings input" "foobar\nbazfoo\n" \
+	"\0foobar\0\0bazfoo\0foo" ""
+testing "-f" "strings -f input" "input: foobar\n" "foobar\n" ""
+testing "-o" "strings -o input | sed 's/^ *//'" "6 foobar\n" \
+	"\0\0\0\0\0\0foobar\n" ""
+testing "-o, multiple strings" "strings -n3 -o input | sed 's/^ *//'" \
+	"1 foo\n7 bar\n" "\0foo\0b\0bar\n" ""
+testing "-fo" "strings -fo input | sed 's/: */: /'" "input: 6 foobar\n" \
+	"\0\0\0\0\0\0foobar\n" ""
diff --git a/toys/posix/strings.c b/toys/posix/strings.c
index f3ce70c..d2154e7 100644
--- a/toys/posix/strings.c
+++ b/toys/posix/strings.c
@@ -38,7 +38,10 @@ static void do_strings(int fd, char *filename)
   for (;;) {
     nread = read(fd, toybuf, sizeof(toybuf));
     if (nread < 0) perror_msg_raw(filename);
-    if (nread < 1) break;
+    if (nread < 1) {
+      if (count == wlen) xputc('\n');
+      break;
+    }
     for (i = 0; i < nread; i++, offset++) {
       if (((toybuf[i] >= 32) && (toybuf[i] <= 126)) || (toybuf[i] == '\t')) {
         if (count == wlen) fputc(toybuf[i], stdout);
@@ -47,7 +50,7 @@ static void do_strings(int fd, char *filename)
           if (count == wlen) {
             if (toys.optflags & FLAG_f) printf("%s: ", filename);
             if (toys.optflags & FLAG_o)
-              printf("%7lld ",(long long)(offset - wlen));
+              printf("%7lld ",(long long)(offset + 1 - wlen));
             printf("%s", string);
           }
         }
-- 
2.7.4

_______________________________________________
Toybox mailing list
Toybox@lists.landley.net
http://lists.landley.net/listinfo.cgi/toybox-landley.net

Reply via email to