Blame SOURCES/coreutils-i18n-fix2-expand-unexpand.patch

8d0e4d
diff --git a/src/expand.c b/src/expand.c
8d0e4d
index 380e020..310b349 100644
8d0e4d
--- a/src/expand.c
8d0e4d
+++ b/src/expand.c
8d0e4d
@@ -129,15 +129,19 @@ expand (void)
8d0e4d
 
8d0e4d
       do
8d0e4d
         {
8d0e4d
-          do {
8d0e4d
+          while (true) {
8d0e4d
             mbf_getc (c, mbf);
8d0e4d
-            if (mb_iseof (c))
8d0e4d
+            if ((mb_iseof (c)) && (fp = next_file (fp)))
8d0e4d
               {
8d0e4d
-                mbf_init (mbf, fp = next_file (fp));
8d0e4d
+                mbf_init (mbf, fp);
8d0e4d
                 continue;
8d0e4d
               }
8d0e4d
+            else
8d0e4d
+              {
8d0e4d
+                break;
8d0e4d
+              }
8d0e4d
             }
8d0e4d
-          while (false);
8d0e4d
+
8d0e4d
 
8d0e4d
           if (convert)
8d0e4d
             {
8d0e4d
diff --git a/src/unexpand.c b/src/unexpand.c
8d0e4d
index 3bbbd66..863a90a 100644
8d0e4d
--- a/src/unexpand.c
8d0e4d
+++ b/src/unexpand.c
8d0e4d
@@ -164,15 +164,19 @@ unexpand (void)
8d0e4d
 
8d0e4d
       do
8d0e4d
         {
8d0e4d
-          do {
8d0e4d
+          while (true) {
8d0e4d
             mbf_getc (c, mbf);
8d0e4d
-            if (mb_iseof (c))
8d0e4d
+            if ((mb_iseof (c)) && (fp = next_file (fp)))
8d0e4d
               {
8d0e4d
-                mbf_init (mbf, fp = next_file (fp));
8d0e4d
+                mbf_init (mbf, fp);
8d0e4d
                 continue;
8d0e4d
               }
8d0e4d
+            else
8d0e4d
+              {
8d0e4d
+                break;
8d0e4d
+              }
8d0e4d
             }
8d0e4d
-          while (false);
8d0e4d
+
8d0e4d
 
8d0e4d
           if (convert)
8d0e4d
             {
8d0e4d
diff --git a/tests/expand/mb.sh b/tests/expand/mb.sh
8d0e4d
index 7971e18..031be7a 100755
8d0e4d
--- a/tests/expand/mb.sh
8d0e4d
+++ b/tests/expand/mb.sh
8d0e4d
@@ -44,6 +44,20 @@ EOF
8d0e4d
 expand < in > out || fail=1
8d0e4d
 compare exp out > /dev/null 2>&1 || fail=1
8d0e4d
 
8d0e4d
+#multiple files as an input
8d0e4d
+cat <<\EOF >> exp || framework_failure_
8d0e4d
+1234567812345678123456781
8d0e4d
+.       .       .       .
8d0e4d
+a       b       c       d
8d0e4d
+.       .       .       .
8d0e4d
+ä       ö       ü       ß
8d0e4d
+.       .       .       .
8d0e4d
+   äöü  .    öüä.       ä xx
8d0e4d
+EOF
8d0e4d
+
8d0e4d
+expand ./in ./in > out || fail=1
8d0e4d
+compare exp out > /dev/null 2>&1 || fail=1
8d0e4d
+
8d0e4d
 #test characters with display widths != 1
8d0e4d
 env printf '12345678
8d0e4d
 e\t|ascii(1)
8d0e4d
diff --git a/tests/unexpand/mb.sh b/tests/unexpand/mb.sh
8d0e4d
index 60d4c1a..8d75652 100755
8d0e4d
--- a/tests/unexpand/mb.sh
8d0e4d
+++ b/tests/unexpand/mb.sh
8d0e4d
@@ -44,6 +44,22 @@ EOF
8d0e4d
 unexpand -a < in > out || fail=1
8d0e4d
 compare exp out > /dev/null 2>&1 || fail=1
8d0e4d
 
8d0e4d
+
8d0e4d
+#multiple files as an input
8d0e4d
+cat >> exp <<\EOF
8d0e4d
+1234567812345678123456781
8d0e4d
+.	.	.	.
8d0e4d
+a	b	c	d
8d0e4d
+.	.	.	.
8d0e4d
+ä	ö	ü	ß
8d0e4d
+.	.	.	.
8d0e4d
+   äöü	.    öüä.	ä xx
8d0e4d
+EOF
8d0e4d
+
8d0e4d
+
8d0e4d
+unexpand -a ./in ./in > out || fail=1
8d0e4d
+compare exp out > /dev/null 2>&1 || fail=1
8d0e4d
+
8d0e4d
 #test characters with a display width larger than 1
8d0e4d
 
8d0e4d
 env printf '12345678