Jakub Martisko ffecc6
diff -up ./src/expand.c.orig ./src/expand.c
Jakub Martisko ffecc6
--- ./src/expand.c.orig	2016-06-01 12:42:49.330373488 +0200
Jakub Martisko ffecc6
+++ ./src/expand.c	2016-06-07 14:35:16.011142041 +0200
Jakub Martisko ffecc6
@@ -173,15 +173,19 @@ expand (void)
Jakub Martisko ffecc6
 
Jakub Martisko ffecc6
       do
Jakub Martisko ffecc6
         {
Jakub Martisko ffecc6
-          do {
Jakub Martisko ffecc6
+          while (true) {
Jakub Martisko ffecc6
             mbf_getc (c, mbf);
Jakub Martisko ffecc6
-            if (mb_iseof (c))
Jakub Martisko ffecc6
+            if ((mb_iseof (c)) && (fp = next_file (fp)))
Jakub Martisko ffecc6
               {
Jakub Martisko ffecc6
-                mbf_init (mbf, fp = next_file (fp));
Jakub Martisko ffecc6
+                mbf_init (mbf, fp);
Jakub Martisko ffecc6
                 continue;
Jakub Martisko ffecc6
               }
Jakub Martisko ffecc6
+            else
Jakub Martisko ffecc6
+              {
Jakub Martisko ffecc6
+                break;
Jakub Martisko ffecc6
+              }
Jakub Martisko ffecc6
             }
Jakub Martisko ffecc6
-          while (false);
Jakub Martisko ffecc6
+          
Jakub Martisko ffecc6
 
Jakub Martisko ffecc6
           if (convert)
Jakub Martisko ffecc6
             {
Jakub Martisko ffecc6
diff -up ./src/unexpand.c.orig ./src/unexpand.c
Jakub Martisko ffecc6
--- ./src/unexpand.c.orig	2016-06-07 14:26:57.380746446 +0200
Jakub Martisko ffecc6
+++ ./src/unexpand.c	2016-06-07 14:34:54.059256698 +0200
Jakub Martisko ffecc6
@@ -220,15 +220,19 @@ unexpand (void)
Jakub Martisko ffecc6
 
Jakub Martisko ffecc6
       do
Jakub Martisko ffecc6
         {
Jakub Martisko ffecc6
-          do {
Jakub Martisko ffecc6
+          while (true) {
Jakub Martisko ffecc6
             mbf_getc (c, mbf);
Jakub Martisko ffecc6
-            if (mb_iseof (c))
Jakub Martisko ffecc6
+            if ((mb_iseof (c)) && (fp = next_file (fp)))
Jakub Martisko ffecc6
               {
Jakub Martisko ffecc6
-                mbf_init (mbf, fp = next_file (fp));
Jakub Martisko ffecc6
+                mbf_init (mbf, fp);
Jakub Martisko ffecc6
                 continue;
Jakub Martisko ffecc6
               }
Jakub Martisko ffecc6
+            else
Jakub Martisko ffecc6
+              {
Jakub Martisko ffecc6
+                break;
Jakub Martisko ffecc6
+              }
Jakub Martisko ffecc6
             }
Jakub Martisko ffecc6
-          while (false);
Jakub Martisko ffecc6
+          
Jakub Martisko ffecc6
 
Jakub Martisko ffecc6
           if (convert)
Jakub Martisko ffecc6
             {
Jakub Martisko ffecc6
diff -up ./tests/expand/mb.sh.orig ./tests/expand/mb.sh
Jakub Martisko ffecc6
--- ./tests/expand/mb.sh.orig	2016-05-11 14:13:53.095289000 +0200
Jakub Martisko ffecc6
+++ ./tests/expand/mb.sh	2016-06-07 14:38:48.259033445 +0200
Jakub Martisko ffecc6
@@ -44,6 +44,20 @@ EOF
Jakub Martisko ffecc6
 expand < in > out || fail=1
Jakub Martisko ffecc6
 compare exp out > /dev/null 2>&1 || fail=1
Jakub Martisko ffecc6
 
Jakub Martisko ffecc6
+#multiple files as an input
Jakub Martisko ffecc6
+cat <<\EOF >> exp || framework_failure_
Jakub Martisko ffecc6
+1234567812345678123456781
Jakub Martisko ffecc6
+.       .       .       .
Jakub Martisko ffecc6
+a       b       c       d
Jakub Martisko ffecc6
+.       .       .       .
Jakub Martisko ffecc6
+ä       ö       ü       ß
Jakub Martisko ffecc6
+.       .       .       .
Jakub Martisko ffecc6
+   äöü  .    öüä.       ä xx
Jakub Martisko ffecc6
+EOF
Jakub Martisko ffecc6
+
Jakub Martisko ffecc6
+expand ./in ./in > out || fail=1
Jakub Martisko ffecc6
+compare exp out > /dev/null 2>&1 || fail=1
Jakub Martisko ffecc6
+
Jakub Martisko ffecc6
 #test characters with display widths != 1
Jakub Martisko ffecc6
 env printf '12345678
Jakub Martisko ffecc6
 e\t|ascii(1)
Jakub Martisko ffecc6
diff -up ./tests/unexpand/mb.sh.orig ./tests/unexpand/mb.sh
Jakub Martisko ffecc6
--- ./tests/unexpand/mb.sh.orig	2016-06-07 14:41:44.210106466 +0200
Jakub Martisko ffecc6
+++ ./tests/unexpand/mb.sh	2016-06-07 14:52:28.848639772 +0200
Jakub Martisko ffecc6
@@ -44,6 +44,22 @@ EOF
Jakub Martisko ffecc6
 unexpand -a < in > out || fail=1
Jakub Martisko ffecc6
 compare exp out > /dev/null 2>&1 || fail=1
Jakub Martisko ffecc6
 
Jakub Martisko ffecc6
+
Jakub Martisko ffecc6
+#multiple files as an input
Jakub Martisko ffecc6
+cat >> exp <<\EOF
Jakub Martisko ffecc6
+1234567812345678123456781
Jakub Martisko ffecc6
+.	.	.	.
Jakub Martisko ffecc6
+a	b	c	d
Jakub Martisko ffecc6
+.	.	.	.
Jakub Martisko ffecc6
+ä	ö	ü	ß
Jakub Martisko ffecc6
+.	.	.	.
Jakub Martisko ffecc6
+   äöü	.    öüä.	ä xx
Jakub Martisko ffecc6
+EOF
Jakub Martisko ffecc6
+
Jakub Martisko ffecc6
+
Jakub Martisko ffecc6
+unexpand -a ./in ./in > out || fail=1
Jakub Martisko ffecc6
+compare exp out > /dev/null 2>&1 || fail=1
Jakub Martisko ffecc6
+
Jakub Martisko ffecc6
 #test characters with a display width larger than 1
Jakub Martisko ffecc6
 
Jakub Martisko ffecc6
 env printf '12345678