annotate TaskManager/Test/simple_render/base64_de.cpp @ 146:a98dbb81db5c draft

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