aboutsummaryrefslogtreecommitdiff
path: root/coreutils/uuencode.c
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2006-09-03 15:49:40 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2006-09-03 15:49:40 +0000
commit21afc7dc291f1cb11feec7a9766bf3542545f581 (patch)
tree5cf8056965bf44d78ef9937fe1f529fa2915e772 /coreutils/uuencode.c
parent22dca23d52c836e40c79cb4042b867fdc06f6ca3 (diff)
downloadbusybox-w32-21afc7dc291f1cb11feec7a9766bf3542545f581.tar.gz
busybox-w32-21afc7dc291f1cb11feec7a9766bf3542545f581.tar.bz2
busybox-w32-21afc7dc291f1cb11feec7a9766bf3542545f581.zip
uuencode: common implementation for wget and uuencode (closing bug 694)
Diffstat (limited to 'coreutils/uuencode.c')
-rw-r--r--coreutils/uuencode.c66
1 files changed, 6 insertions, 60 deletions
diff --git a/coreutils/uuencode.c b/coreutils/uuencode.c
index 1449d9aeb..1a8882fc7 100644
--- a/coreutils/uuencode.c
+++ b/coreutils/uuencode.c
@@ -10,60 +10,6 @@
10 10
11#include "busybox.h" 11#include "busybox.h"
12 12
13/* Conversion table. for base 64 */
14static const char tbl_base64[65] = {
15 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H',
16 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P',
17 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X',
18 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f',
19 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
20 'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
21 'w', 'x', 'y', 'z', '0', '1', '2', '3',
22 '4', '5', '6', '7', '8', '9', '+', '/',
23 '=' /* termination character */
24};
25
26static const char tbl_std[65] = {
27 '`', '!', '"', '#', '$', '%', '&', '\'',
28 '(', ')', '*', '+', ',', '-', '.', '/',
29 '0', '1', '2', '3', '4', '5', '6', '7',
30 '8', '9', ':', ';', '<', '=', '>', '?',
31 '@', 'A', 'B', 'C', 'D', 'E', 'F', 'G',
32 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O',
33 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',
34 'X', 'Y', 'Z', '[', '\\', ']', '^', '_',
35 '`' /* termination character */
36};
37
38/*
39 * Encode the string S of length LENGTH to base64 format and place it
40 * to STORE. STORE will be 0-terminated, and must point to a writable
41 * buffer of at least 1+BASE64_LENGTH(length) bytes.
42 * where BASE64_LENGTH(len) = (4 * ((LENGTH + 2) / 3))
43 */
44static void uuencode (const unsigned char *s, char *store, const int length, const char *tbl)
45{
46 int i;
47 char *p = store;
48
49 /* Transform the 3x8 bits to 4x6 bits, as required by base64. */
50 for (i = 0; i < length; i += 3) {
51 *p++ = tbl[s[0] >> 2];
52 *p++ = tbl[((s[0] & 3) << 4) + (s[1] >> 4)];
53 *p++ = tbl[((s[1] & 0xf) << 2) + (s[2] >> 6)];
54 *p++ = tbl[s[2] & 0x3f];
55 s += 3;
56 }
57 /* Pad the result if necessary... */
58 if (i == length + 1) {
59 *(p - 1) = tbl[64];
60 }
61 else if (i == length + 2) {
62 *(p - 1) = *(p - 2) = tbl[64];
63 }
64 /* ...and zero-terminate it. */
65 *p = '\0';
66}
67 13
68#define SRC_BUF_SIZE 45 // This *MUST* be a multiple of 3 14#define SRC_BUF_SIZE 45 // This *MUST* be a multiple of 3
69#define DST_BUF_SIZE 4 * ((SRC_BUF_SIZE + 2) / 3) 15#define DST_BUF_SIZE 4 * ((SRC_BUF_SIZE + 2) / 3)
@@ -80,9 +26,9 @@ int uuencode_main(int argc, char **argv)
80 RESERVE_CONFIG_BUFFER(src_buf, SRC_BUF_SIZE + 1); 26 RESERVE_CONFIG_BUFFER(src_buf, SRC_BUF_SIZE + 1);
81 RESERVE_CONFIG_BUFFER(dst_buf, DST_BUF_SIZE + 1); 27 RESERVE_CONFIG_BUFFER(dst_buf, DST_BUF_SIZE + 1);
82 28
83 tbl = tbl_std; 29 tbl = bb_uuenc_tbl_std;
84 if (bb_getopt_ulflags(argc, argv, "m") & 1) { 30 if (bb_getopt_ulflags(argc, argv, "m") & 1) {
85 tbl = tbl_base64; 31 tbl = bb_uuenc_tbl_base64;
86 } 32 }
87 33
88 switch (argc - optind) { 34 switch (argc - optind) {
@@ -101,7 +47,7 @@ int uuencode_main(int argc, char **argv)
101 bb_show_usage(); 47 bb_show_usage();
102 } 48 }
103 49
104 bb_printf("begin%s %o %s", tbl == tbl_std ? "" : "-base64", mode, argv[argc - 1]); 50 bb_printf("begin%s %o %s", tbl == bb_uuenc_tbl_std ? "" : "-base64", mode, argv[argc - 1]);
105 51
106 while ((size = fread(src_buf, 1, src_buf_size, src_stream)) > 0) { 52 while ((size = fread(src_buf, 1, src_buf_size, src_stream)) > 0) {
107 if (size != src_buf_size) { 53 if (size != src_buf_size) {
@@ -111,17 +57,17 @@ int uuencode_main(int argc, char **argv)
111 memset(&src_buf[size], 0, src_buf_size - size); 57 memset(&src_buf[size], 0, src_buf_size - size);
112 } 58 }
113 /* Encode the buffer we just read in */ 59 /* Encode the buffer we just read in */
114 uuencode((unsigned char*)src_buf, dst_buf, size, tbl); 60 bb_uuencode((unsigned char*)src_buf, dst_buf, size, tbl);
115 61
116 putchar('\n'); 62 putchar('\n');
117 if (tbl == tbl_std) { 63 if (tbl == bb_uuenc_tbl_std) {
118 putchar(tbl[size]); 64 putchar(tbl[size]);
119 } 65 }
120 if (fwrite(dst_buf, 1, write_size, stdout) != write_size) { 66 if (fwrite(dst_buf, 1, write_size, stdout) != write_size) {
121 bb_perror_msg_and_die(bb_msg_write_error); 67 bb_perror_msg_and_die(bb_msg_write_error);
122 } 68 }
123 } 69 }
124 bb_printf(tbl == tbl_std ? "\n`\nend\n" : "\n====\n"); 70 bb_printf(tbl == bb_uuenc_tbl_std ? "\n`\nend\n" : "\n====\n");
125 71
126 xferror(src_stream, "source"); /* TODO - Fix this! */ 72 xferror(src_stream, "source"); /* TODO - Fix this! */
127 73