diff options
author | Denys Vlasenko <dvlasenk@redhat.com> | 2010-09-16 17:51:13 +0200 |
---|---|---|
committer | Denys Vlasenko <dvlasenk@redhat.com> | 2010-09-16 17:51:13 +0200 |
commit | 9fe98f701d40835db32baa12c94b661d40231ea4 (patch) | |
tree | 781c9c71519f3eb79082eac54e0cc545e16b2fd1 /coreutils/uudecode.c | |
parent | 52e460b7440ed5b85e4125a4eccf1e665d92c0ff (diff) | |
download | busybox-w32-9fe98f701d40835db32baa12c94b661d40231ea4.tar.gz busybox-w32-9fe98f701d40835db32baa12c94b661d40231ea4.tar.bz2 busybox-w32-9fe98f701d40835db32baa12c94b661d40231ea4.zip |
libbb: merge mail and uudecode's base64 decoders
function old new delta
read_base64 - 378 +378
uudecode_main 306 315 +9
parse 953 958 +5
read_stduu 250 254 +4
base64_main 217 219 +2
read_base64 358 - -358
decode_base64 371 - -371
------------------------------------------------------------------------------
(add/remove: 2/2 grow/shrink: 4/0 up/down: 398/-729) Total: -331 bytes
Signed-off-by: Denys Vlasenko <dvlasenk@redhat.com>
Diffstat (limited to 'coreutils/uudecode.c')
-rw-r--r-- | coreutils/uudecode.c | 73 |
1 files changed, 4 insertions, 69 deletions
diff --git a/coreutils/uudecode.c b/coreutils/uudecode.c index 0da9b0988..0c4311f24 100644 --- a/coreutils/uudecode.c +++ b/coreutils/uudecode.c | |||
@@ -13,7 +13,7 @@ | |||
13 | #include "libbb.h" | 13 | #include "libbb.h" |
14 | 14 | ||
15 | #if ENABLE_UUDECODE | 15 | #if ENABLE_UUDECODE |
16 | static void read_stduu(FILE *src_stream, FILE *dst_stream) | 16 | static void FAST_FUNC read_stduu(FILE *src_stream, FILE *dst_stream, int flags UNUSED_PARAM) |
17 | { | 17 | { |
18 | char *line; | 18 | char *line; |
19 | 19 | ||
@@ -75,71 +75,6 @@ static void read_stduu(FILE *src_stream, FILE *dst_stream) | |||
75 | } | 75 | } |
76 | #endif | 76 | #endif |
77 | 77 | ||
78 | static void read_base64(FILE *src_stream, FILE *dst_stream) | ||
79 | { | ||
80 | int term_count = 0; | ||
81 | |||
82 | while (1) { | ||
83 | unsigned char translated[4]; | ||
84 | int count = 0; | ||
85 | |||
86 | /* Process one group of 4 chars */ | ||
87 | while (count < 4) { | ||
88 | char *table_ptr; | ||
89 | int ch; | ||
90 | |||
91 | /* Get next _valid_ character. | ||
92 | * bb_uuenc_tbl_base64[] contains this string: | ||
93 | * 0 1 2 3 4 5 6 | ||
94 | * 012345678901234567890123456789012345678901234567890123456789012345 | ||
95 | * "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\n" | ||
96 | */ | ||
97 | do { | ||
98 | ch = fgetc(src_stream); | ||
99 | if (ch == EOF) { | ||
100 | if (ENABLE_BASE64 | ||
101 | && (!ENABLE_UUDECODE || applet_name[0] == 'b') | ||
102 | && count == 0 | ||
103 | ) { | ||
104 | return; | ||
105 | } | ||
106 | bb_error_msg_and_die("short file"); | ||
107 | } | ||
108 | table_ptr = strchr(bb_uuenc_tbl_base64, ch); | ||
109 | } while (!table_ptr); | ||
110 | |||
111 | /* Convert encoded character to decimal */ | ||
112 | ch = table_ptr - bb_uuenc_tbl_base64; | ||
113 | |||
114 | if (ch == 65 /* '\n' */) { | ||
115 | /* Terminating "====" line? */ | ||
116 | if (term_count == 4) | ||
117 | return; /* yes */ | ||
118 | term_count = 0; | ||
119 | continue; | ||
120 | } | ||
121 | /* ch is 64 is char was '=', otherwise 0..63 */ | ||
122 | translated[count] = ch & 63; /* 64 -> 0 */ | ||
123 | if (ch == 64) { | ||
124 | term_count++; | ||
125 | break; | ||
126 | } | ||
127 | count++; | ||
128 | } | ||
129 | |||
130 | /* Merge 6 bit chars to 8 bit. | ||
131 | * count can be < 4 when we decode the tail: | ||
132 | * "eQ==" -> "y", not "y NUL NUL" | ||
133 | */ | ||
134 | if (count > 1) | ||
135 | fputc(translated[0] << 2 | translated[1] >> 4, dst_stream); | ||
136 | if (count > 2) | ||
137 | fputc(translated[1] << 4 | translated[2] >> 2, dst_stream); | ||
138 | if (count > 3) | ||
139 | fputc(translated[2] << 6 | translated[3], dst_stream); | ||
140 | } /* while (1) */ | ||
141 | } | ||
142 | |||
143 | #if ENABLE_UUDECODE | 78 | #if ENABLE_UUDECODE |
144 | int uudecode_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; | 79 | int uudecode_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; |
145 | int uudecode_main(int argc UNUSED_PARAM, char **argv) | 80 | int uudecode_main(int argc UNUSED_PARAM, char **argv) |
@@ -158,7 +93,7 @@ int uudecode_main(int argc UNUSED_PARAM, char **argv) | |||
158 | 93 | ||
159 | /* Search for the start of the encoding */ | 94 | /* Search for the start of the encoding */ |
160 | while ((line = xmalloc_fgetline(src_stream)) != NULL) { | 95 | while ((line = xmalloc_fgetline(src_stream)) != NULL) { |
161 | void (*decode_fn_ptr)(FILE *src, FILE *dst); | 96 | void FAST_FUNC (*decode_fn_ptr)(FILE *src, FILE *dst, int flags); |
162 | char *line_ptr; | 97 | char *line_ptr; |
163 | FILE *dst_stream; | 98 | FILE *dst_stream; |
164 | int mode; | 99 | int mode; |
@@ -189,7 +124,7 @@ int uudecode_main(int argc UNUSED_PARAM, char **argv) | |||
189 | fchmod(fileno(dst_stream), mode & (S_IRWXU | S_IRWXG | S_IRWXO)); | 124 | fchmod(fileno(dst_stream), mode & (S_IRWXU | S_IRWXG | S_IRWXO)); |
190 | } | 125 | } |
191 | free(line); | 126 | free(line); |
192 | decode_fn_ptr(src_stream, dst_stream); | 127 | decode_fn_ptr(src_stream, dst_stream, /*flags:*/ BASE64_FLAG_UU_STOP + BASE64_FLAG_NO_STOP_CHAR); |
193 | /* fclose_if_not_stdin(src_stream); - redundant */ | 128 | /* fclose_if_not_stdin(src_stream); - redundant */ |
194 | return EXIT_SUCCESS; | 129 | return EXIT_SUCCESS; |
195 | } | 130 | } |
@@ -231,7 +166,7 @@ int base64_main(int argc UNUSED_PARAM, char **argv) | |||
231 | *--argv = (char*)"-"; | 166 | *--argv = (char*)"-"; |
232 | src_stream = xfopen_stdin(argv[0]); | 167 | src_stream = xfopen_stdin(argv[0]); |
233 | if (opts) { | 168 | if (opts) { |
234 | read_base64(src_stream, stdout); | 169 | read_base64(src_stream, stdout, /*flags:*/ (char)EOF); |
235 | } else { | 170 | } else { |
236 | enum { | 171 | enum { |
237 | SRC_BUF_SIZE = 76/4*3, /* This *MUST* be a multiple of 3 */ | 172 | SRC_BUF_SIZE = 76/4*3, /* This *MUST* be a multiple of 3 */ |