annotate old/simple_pack/base64_de.cpp @ 638:250c7353ddaf draft

hmmmm
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Thu, 19 Nov 2009 18:18:20 +0900
parents 3bc98f6d31ff
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
53
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
1 #include <iostream>
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
2 #include <fstream>
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
3 using namespace std;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
4
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
5 class tagTT
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
6 {
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
7 public:
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
8 unsigned char buf;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
9 char *cont;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
10 int nlen;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
11 };
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
12
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
13
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
14 unsigned char CtoNum(int c)
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
15 {
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
16 if (c >= 'A' && c <= 'Z') return c-'A';
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
17 if (c >= 'a' && c <= 'z') return (c - 'a')+26;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
18 if (c >= '0' && c <= '9') return (c - '0')+52;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
19 if (c == '+') return 62;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
20 if (c == '/') return 63;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
21 return 0;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
22 }
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
23
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
24
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
25 int GetNumB64(tagTT &pWork)
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
26 {
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
27 char wr;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
28 unsigned char w;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
29 unsigned char r;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
30
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
31 wr = *pWork.cont;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
32 pWork.cont++;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
33 if (wr=='\0' || wr=='=')
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
34 return -1;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
35
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
36 while(wr=='\n' || wr=='\t')
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
37 {
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
38 wr = *pWork.cont;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
39 pWork.cont++;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
40 }
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
41
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
42 w = CtoNum(wr);
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
43 if (pWork.nlen == 0)
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
44 {
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
45 unsigned char w2;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
46
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
47 wr = *pWork.cont;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
48 pWork.cont++;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
49 if (wr!='\0' && wr!='=')
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
50 w2 = CtoNum(wr);
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
51 else
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
52 w2 = 0;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
53
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
54 pWork.buf = w << 2;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
55 w = w2;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
56 pWork.nlen = 6;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
57 }
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
58
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
59 pWork.nlen -= 2;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
60
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
61 r = pWork.buf | (w >> pWork.nlen);
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
62
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
63 pWork.buf = (w << (8 - pWork.nlen));
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
64 return r;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
65 }
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
66
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
67
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
68 //int decode(char *cont, char *file_name)
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
69 int decode(char *cont, FILE *outfile)
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
70 {
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
71 int rw;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
72 tagTT work;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
73
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
74 //ofstream outfile(file_name);
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
75
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
76 work.buf = 0;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
77 work.nlen = 0;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
78 work.cont = cont;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
79
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
80 rw = GetNumB64(work);
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
81 while ( rw != -1 )
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
82 {
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
83 //outfile << (char)rw;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
84 putc(rw, outfile);
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
85 rw = GetNumB64(work);
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
86 }
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
87
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
88 //outfile.close();
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
89
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
90 return 0;
0c8ae614d421 Initial revision
chiaki
parents:
diff changeset
91 }