uuencode: allow space instead of "`" as padding char. Closes 10046
authorDenys Vlasenko <vda.linux@googlemail.com>
Fri, 14 Jul 2017 15:24:59 +0000 (17:24 +0200)
committerDenys Vlasenko <vda.linux@googlemail.com>
Tue, 18 Jul 2017 17:20:58 +0000 (19:20 +0200)
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
coreutils/uudecode.c

index ddce2548b87b7b77dd546ef602e46c7b365e3e1d..2fe771f6991b193b944d8a5cd694698df82b7461 100644 (file)
@@ -47,10 +47,16 @@ static void FAST_FUNC read_stduu(FILE *src_stream, FILE *dst_stream, int flags U
                line = xmalloc_fgets_str_len(src_stream, "\n", &line_len);
                if (!line)
                        break;
-               /* Handle both Unix and MSDOS text, and stray trailing spaces */
+               /* Handle both Unix and MSDOS text.
+                * Note: space should not be trimmed, some encoders use it instead of "`"
+                * for padding of last incomplete 4-char block.
+                */
                str_len = line_len;
-               while (--str_len >= 0 && isspace(line[str_len]))
+               while (--str_len >= 0
+                && (line[str_len] == '\n' || line[str_len] == '\r')
+               ) {
                        line[str_len] = '\0';
+               }
 
                if (strcmp(line, "end") == 0) {
                        return; /* the only non-error exit */
@@ -65,7 +71,7 @@ static void FAST_FUNC read_stduu(FILE *src_stream, FILE *dst_stream, int flags U
 
                encoded_len = line[0] * 4 / 3;
                /* Check that line is not too short. (we tolerate
-                * overly _long_ line to accommodate possible extra '`').
+                * overly _long_ line to accommodate possible extra "`").
                 * Empty line case is also caught here. */
                if (str_len <= encoded_len) {
                        break; /* go to bb_error_msg_and_die("short file"); */