Add -s to the usage text...
[doldaconnect.git] / config / tthsum.c
1 /*
2  *  Dolda Connect - Modular multiuser Direct Connect-style client
3  *  Copyright (C) 2004 Fredrik Tolf (fredrik@dolda2000.com)
4  *  
5  *  This program is free software; you can redistribute it and/or modify
6  *  it under the terms of the GNU General Public License as published by
7  *  the Free Software Foundation; either version 2 of the License, or
8  *  (at your option) any later version.
9  *  
10  *  This program is distributed in the hope that it will be useful,
11  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  *  GNU General Public License for more details.
14  *  
15  *  You should have received a copy of the GNU General Public License
16  *  along with this program; if not, write to the Free Software
17  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
18 */
19
20 /* This frankenfile is built from bits and pieces of the daemon. The
21  * copying and pasting is very ugly, but it doesn't *really*
22  * matter. */
23
24 #include <stdlib.h>
25 #include <unistd.h>
26 #include <stdio.h>
27 #include <string.h>
28 #include <fcntl.h>
29 #include <errno.h>
30 #include <sys/stat.h>
31
32 #ifdef HAVE_CONFIG_H
33 #include <config.h>
34 #endif
35
36 struct tigerhash {
37     unsigned long long a, b, c;
38     unsigned char block[64];
39     int offset;
40     size_t len;
41 };
42
43 struct tigertreehash {
44     int blocks;
45     char block[1024];
46     int offset;
47     char stack[64][24];
48     int depth;
49 };
50
51 char buf[32768], dbuf[512];
52
53 static char *base64set = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
54 static int base64rev[] = {
55     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
56     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
57     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,
58     52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1,
59     -1,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14,
60     15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,
61     -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
62     41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1,
63     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
64     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
65     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
66     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
67     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
68     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
69     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
70     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
71 };
72 static char *base32set = "ABCDEFGHIJKLMNOPQRSTUVWXYZ234567";
73 static int base32rev[] = {
74     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
75     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
76     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
77     -1, -1, 26, 27, 28, 29, 30, 31, -1, -1, -1, -1, -1, -1, -1, -1,
78     -1,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14,
79     15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,
80     -1,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14,
81     15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,
82     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
83     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
84     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
85     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
86     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
87     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
88     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
89     -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
90 };
91
92 static unsigned long long table[];
93
94 void inittiger(struct tigerhash *th)
95 {
96     th->a = 0x0123456789abcdefULL;
97     th->b = 0xfedcba9876543210ULL;
98     th->c = 0xf096a5b4c3b2e187ULL;
99     th->offset = 0;
100     th->len = 0;
101 }
102
103 static void round(unsigned long long *a, unsigned long long *b, unsigned long long *c, unsigned long long x, int mul)
104 {
105     *c ^= x;
106     *a -= table[((*c >> 0) & 0xff) + 0x0000] ^ table[((*c >> 16) & 0xff) + 0x0100] ^ table[((*c >> 32) & 0xff) + 0x0200] ^ table[((*c >> 48) & 0xff) + 0x0300];
107     *b += table[((*c >> 8) & 0xff) + 0x0300] ^ table[((*c >> 24) & 0xff) + 0x0200] ^ table[((*c >> 40) & 0xff) + 0x0100] ^ table[((*c >> 56) & 0xff) + 0x0000];
108     *b *= mul;
109 }
110
111 static void pass(unsigned long long *a, unsigned long long *b, unsigned long long *c, unsigned long long *x, int mul)
112 {
113     round(a, b, c, x[0], mul);
114     round(b, c, a, x[1], mul);
115     round(c, a, b, x[2], mul);
116     round(a, b, c, x[3], mul);
117     round(b, c, a, x[4], mul);
118     round(c, a, b, x[5], mul);
119     round(a, b, c, x[6], mul);
120     round(b, c, a, x[7], mul);
121 }
122
123 static void key_schedule(unsigned long long *x)
124 {
125     x[0] -= x[7] ^ 0xa5a5a5a5a5a5a5a5ULL;
126     x[1] ^= x[0];
127     x[2] += x[1];
128     x[3] -= x[2] ^ ((~x[1]) << 19);
129     x[4] ^= x[3];
130     x[5] += x[4];
131     x[6] -= x[5] ^ ((~x[4]) >> 23);
132     x[7] ^= x[6];
133     x[0] += x[7];
134     x[1] -= x[0] ^ ((~x[7]) << 19);
135     x[2] ^= x[1];
136     x[3] += x[2];
137     x[4] -= x[3] ^ ((~x[2]) >> 23);
138     x[5] ^= x[4];
139     x[6] += x[5];
140     x[7] -= x[6] ^ 0x0123456789abcdefULL;
141 }
142
143 static void doblock(struct tigerhash *th)
144 {
145     int i, o;
146     unsigned long long x[8], aa, bb, cc;
147     
148     for(i = 0; i < 8; i++) {
149         x[i] = 0;
150         for(o = 0; o < 8; o++) {
151             x[i] <<= 8;
152             x[i] |= th->block[(i * 8) + 7 - o];
153         }
154     }
155     aa = th->a;
156     bb = th->b;
157     cc = th->c;
158     pass(&th->a, &th->b, &th->c, x, 5);
159     key_schedule(x);
160     pass(&th->c, &th->a, &th->b, x, 7);
161     key_schedule(x);
162     pass(&th->b, &th->c, &th->a, x, 9);
163     th->a ^= aa;
164     th->b -= bb;
165     th->c += cc;
166     th->offset = 0;
167 }
168
169 void dotiger(struct tigerhash *th, char *buf, size_t buflen)
170 {
171     int taken;
172     
173     th->len += buflen;
174     while(buflen > 0) {
175         taken = buflen;
176         if(taken > 64 - th->offset)
177             taken = 64 - th->offset;
178         memcpy(th->block + th->offset, buf, taken);
179         th->offset += taken;
180         buflen -= taken;
181         buf += taken;
182         if(th->offset == 64)
183             doblock(th);
184     }
185 }
186
187 void synctiger(struct tigerhash *th)
188 {
189     int i;
190     unsigned long long buf;
191     
192     th->block[th->offset++] = 1;
193     while(th->offset & 7)
194         th->block[th->offset++] = 0;
195     if(th->offset > 56)
196         doblock(th);
197     if(th->offset < 56)
198         memset(th->block + th->offset, 0, 56 - th->offset);
199     buf = th->len << 3;
200     for(i = 0; i < 8; i++) {
201         th->block[56 + i] = buf & 0xff;
202         buf >>= 8;
203     }
204     doblock(th);
205 }
206
207 void restiger(struct tigerhash *th, char *rbuf)
208 {
209     int i;
210     unsigned long long buf;
211     
212     buf = th->a;
213     for(i = 0; i < 8; i++) {
214         rbuf[i] = buf & 0xff;
215         buf >>= 8;
216     }
217     buf = th->b;
218     for(; i < 16; i++) {
219         rbuf[i] = buf & 0xff;
220         buf >>= 8;
221     }
222     buf = th->c;
223     for(; i < 24; i++) {
224         rbuf[i] = buf & 0xff;
225         buf >>= 8;
226     }
227 }
228
229 void inittigertree(struct tigertreehash *tth)
230 {
231     tth->blocks = 0;
232     tth->offset = 0;
233     tth->depth = 0;
234 }
235
236 static void combine(struct tigertreehash *tth)
237 {
238     struct tigerhash th;
239     
240     inittiger(&th);
241     dotiger(&th, "\001", 1);
242     tth->depth--;
243     dotiger(&th, tth->stack[tth->depth - 1], 24);
244     dotiger(&th, tth->stack[tth->depth], 24);
245     synctiger(&th);
246     restiger(&th, tth->stack[tth->depth - 1]);
247 }
248
249 void pushtigertree(struct tigertreehash *tth, char *buf)
250 {
251     int nb;
252     
253     memcpy(tth->stack[tth->depth++], buf, 24);
254     for(nb = ++tth->blocks; !(nb & 1); nb >>= 1)
255         combine(tth);
256 }
257
258 static void dotreeblock(struct tigertreehash *tth)
259 {
260     struct tigerhash th;
261     int nb;
262     
263     inittiger(&th);
264     dotiger(&th, "\0", 1);
265     dotiger(&th, tth->block, tth->offset);
266     synctiger(&th);
267     restiger(&th, tth->stack[tth->depth++]);
268     tth->offset = 0;
269     for(nb = ++tth->blocks; !(nb & 1); nb >>= 1)
270         combine(tth);
271 }
272
273 void dotigertree(struct tigertreehash *tth, char *buf, size_t buflen)
274 {
275     int taken;
276     
277     while(buflen > 0) {
278         taken = buflen;
279         if(taken > 1024 - tth->offset)
280             taken = 1024 - tth->offset;
281         memcpy(tth->block + tth->offset, buf, taken);
282         tth->offset += taken;
283         buflen -= taken;
284         buf += taken;
285         if(tth->offset == 1024)
286             dotreeblock(tth);
287     }
288 }
289
290 void synctigertree(struct tigertreehash *tth)
291 {
292     if((tth->offset > 0) || (tth->blocks == 0))
293         dotreeblock(tth);
294     while(tth->depth > 1)
295         combine(tth);
296 }
297
298 void restigertree(struct tigertreehash *tth, char *rbuf)
299 {
300     memcpy(rbuf, tth->stack[0], 24);
301 }
302
303 void hexencode(char *dest, char *data, size_t datalen)
304 {
305     char this;
306     int off;
307     int dig;
308     
309     off = 0;
310     for(; datalen > 0; datalen--, data++)
311     {
312         dig = (*data & 0xF0) >> 4;
313         if(dig > 9)
314             this = 'A' + dig - 10;
315         else
316             this = dig + '0';
317         dest[off++] = this;
318         dig = *data & 0x0F;
319         if(dig > 9)
320             this = 'A' + dig - 10;
321         else
322             this = dig + '0';
323         dest[off++] = this;
324     }
325     dest[off] = 0;
326 }
327
328 int hexdecode(char *dest, char *data, size_t *len)
329 {
330     char this;
331     int off;
332     
333     off = 0;
334     for(; *data; data++)
335     {
336         if((*data >= 'A') && (*data <= 'F'))
337         {
338             this = (this & 0x0F) | ((*data - 'A' + 10) << 4);
339         } else if((*data >= '0') && (*data <= '9')) {
340             this = (this & 0x0F) | ((*data - '0') << 4);
341         } else {
342             return(-1);
343         }
344         data++;
345         if(!*data)
346             return(-1);
347         if((*data >= 'A') && (*data <= 'F'))
348         {
349             this = (this & 0xF0) | (*data - 'A' + 10);
350         } else if((*data >= '0') && (*data <= '9')) {
351             this = (this & 0xF0) | (*data - '0');
352         } else {
353             return(-1);
354         }
355         dest[off++] = this;
356     }
357     dest[off] = 0;
358     if(len != NULL)
359         *len = off;
360     return(0);
361 }
362
363 void base64encode(char *dest, char *data, size_t datalen)
364 {
365     int off;
366     
367     if(datalen == 0) {
368         dest[0] = 0;
369         return;
370     }
371     off = 0;
372     while(datalen >= 3)
373     {
374         dest[off++] = base64set[(data[0] & 0xfc) >> 2];
375         dest[off++] = base64set[((data[0] & 0x03) << 4) | ((data[1] & 0xf0) >> 4)];
376         dest[off++] = base64set[((data[1] & 0x0f) << 2) | ((data[2] & 0xc0) >> 6)];
377         dest[off++] = base64set[data[2] & 0x3f];
378         datalen -= 3;
379         data += 3;
380     }
381     if(datalen == 1)
382     {
383         dest[off++] = base64set[(data[0] & 0xfc) >> 2];
384         dest[off++] = base64set[(data[0] & 0x03) << 4];
385         dest[off++] = '=';
386         dest[off++] = '=';
387     }
388     if(datalen == 2)
389     {
390         dest[off++] = base64set[(data[0] & 0xfc) >> 2];
391         dest[off++] = base64set[((data[0] & 0x03) << 4) | ((data[1] & 0xf0) >> 4)];
392         dest[off++] = base64set[(data[1] & 0x0f) << 2];
393         dest[off++] = '=';
394     }
395     dest[off] = 0;
396 }
397
398 int base64decode(char *dest, char *data, size_t *datalen)
399 {
400     int b, c;
401     char cur;
402     int off;
403     
404     off = 0;
405     cur = 0;
406     b = 8;
407     for(; *data > 0; data++)
408     {
409         c = (int)(unsigned char)*data;
410         if(c == '=')
411             break;
412         if(c == '\n')
413             continue;
414         if(base64rev[c] == -1)
415             return(-1);
416         b -= 6;
417         if(b <= 0)
418         {
419             cur |= base64rev[c] >> -b;
420             dest[off++] = cur;
421             b += 8;
422             cur = 0;
423         }
424         cur |= base64rev[c] << b;
425     }
426     if(datalen != NULL)
427         *datalen = off;
428     dest[off] = 0;
429     return(0);
430 }
431
432 void base32encode(char *dest, char *data, size_t datalen)
433 {
434     int off;
435     
436     if(datalen == 0) {
437         dest[0] = 0;
438         return;
439     }
440     off = 0;
441     while(datalen >= 5)
442     {
443         dest[off++] = base32set[((data[0] & 0xf8) >> 3)];
444         dest[off++] = base32set[((data[0] & 0x07) << 2) | ((data[1] & 0xc0) >> 6)];
445         dest[off++] = base32set[((data[1] & 0x3e) >> 1)];
446         dest[off++] = base32set[((data[1] & 0x01) << 4) | ((data[2] & 0xf0) >> 4)];
447         dest[off++] = base32set[((data[2] & 0x0f) << 1) | ((data[3] & 0x80) >> 7)];
448         dest[off++] = base32set[((data[3] & 0x7c) >> 2)];
449         dest[off++] = base32set[((data[3] & 0x03) << 3) | ((data[4] & 0xe0) >> 5)];
450         dest[off++] = base32set[data[4] & 0x1f];
451         datalen -= 5;
452         data += 5;
453     }
454     if(datalen == 1)
455     {
456         dest[off++] = base32set[((data[0] & 0xf8) >> 3)];
457         dest[off++] = base32set[((data[0] & 0x07) << 2)];
458         memcpy(dest + off, "======", 6);
459         off += 6;
460     }
461     if(datalen == 2)
462     {
463         dest[off++] = base32set[((data[0] & 0xf8) >> 3)];
464         dest[off++] = base32set[((data[0] & 0x07) << 2) | ((data[1] & 0xc0) >> 6)];
465         dest[off++] = base32set[((data[1] & 0x3e) >> 1)];
466         dest[off++] = base32set[((data[1] & 0x01) << 4)];
467         memcpy(dest + off, "====", 4);
468         off += 4;
469     }
470     if(datalen == 3)
471     {
472         dest[off++] = base32set[((data[0] & 0xf8) >> 3)];
473         dest[off++] = base32set[((data[0] & 0x07) << 2) | ((data[1] & 0xc0) >> 6)];
474         dest[off++] = base32set[((data[1] & 0x3e) >> 1)];
475         dest[off++] = base32set[((data[1] & 0x01) << 4) | ((data[2] & 0xf0) >> 4)];
476         dest[off++] = base32set[((data[2] & 0x0f) << 1)];
477         memcpy(dest + off, "===", 3);
478         off += 3;
479     }
480     if(datalen == 4)
481     {
482         dest[off++] = base32set[((data[0] & 0xf8) >> 3)];
483         dest[off++] = base32set[((data[0] & 0x07) << 2) | ((data[1] & 0xc0) >> 6)];
484         dest[off++] = base32set[((data[1] & 0x3e) >> 1)];
485         dest[off++] = base32set[((data[1] & 0x01) << 4) | ((data[2] & 0xf0) >> 4)];
486         dest[off++] = base32set[((data[2] & 0x0f) << 1) | ((data[3] & 0x80) >> 7)];
487         dest[off++] = base32set[((data[3] & 0x7c) >> 2)];
488         dest[off++] = base32set[((data[3] & 0x03) << 3)];
489         dest[off++] = '=';
490     }
491     dest[off] = 0;
492 }
493
494 int base32decode(char *dest, char *data, size_t *datalen)
495 {
496     int b, c;
497     char cur;
498     int off;
499     
500     off = 0;
501     cur = 0;
502     b = 8;
503     for(; *data > 0; data++)
504     {
505         c = (int)(unsigned char)*data;
506         if(c == '=')
507             break;
508         if(c == '\n')
509             continue;
510         if(base32rev[c] == -1)
511             return(-1);
512         b -= 5;
513         if(b <= 0)
514         {
515             cur |= base32rev[c] >> -b;
516             dest[off++] = cur;
517             b += 8;
518             cur = 0;
519         }
520         cur |= base32rev[c] << b;
521     }
522     if(datalen != NULL)
523         *datalen = off;
524     dest[off] = 0;
525     return(0);
526 }
527
528 int main(int argc, char **argv)
529 {
530     int i, ret;
531     int c, fd, outfd;
532     int len, len2;
533     int filter, output;
534     struct tigertreehash tth;
535     char res[24];
536     char *statefile;
537     FILE *state;
538     int progress, bytes;
539     struct stat sb;
540     
541     filter = 0;
542     output = 4;
543     outfd = 3;
544     progress = 0;
545     statefile = NULL;
546     while((c = getopt(argc, argv, "phf456F:s:")) != -1) {
547         switch(c) {
548         case '4':
549         case '5':
550         case '6':
551             output = c - '0';
552             break;
553         case 'p':
554             progress = 1;
555             break;
556         case 'f':
557             filter = 1;
558             break;
559         case 'F':
560             outfd = atoi(optarg);
561             break;
562         case 's':
563             statefile = optarg;
564             break;
565         case 'h':
566         case ':':
567         case '?':
568         default:
569             fprintf(stderr, "usage: tigersum [-h456] FILE...\n");
570             fprintf(stderr, "       tigersum [-h456] [-F OUTFD] [-s STATEFILE] -f\n");
571             exit((c == 'h')?0:1);
572         }
573     }
574     if(filter) {
575         inittigertree(&tth);
576         if(statefile != NULL)
577         {
578             if(((state = fopen(statefile, "r")) == NULL) && (errno != ENOENT)) {
579                 fprintf(stderr, "tigersum: %s: %s\n", statefile, strerror(errno));
580                 exit(1);
581             }
582             if(state != NULL) {
583                 if(fgets(buf, sizeof(buf), state) == NULL) {
584                     fprintf(stderr, "tigersum: %s: could not read entire state\n", statefile);
585                     exit(1);
586                 }
587                 tth.blocks = atoi(buf);
588                 if(fgets(buf, sizeof(buf), state) == NULL) {
589                     fprintf(stderr, "tigersum: %s: could not read entire state\n", statefile);
590                     exit(1);
591                 }
592                 tth.depth = atoi(buf);
593                 for(i = 0; i < tth.depth; i++) {
594                     if(fgets(buf, sizeof(buf), state) == NULL) {
595                         fprintf(stderr, "tigersum: %s: could not read entire state\n", statefile);
596                         exit(1);
597                     }
598                     base64decode(dbuf, buf, &ret);
599                     if(ret != 24) {
600                         fprintf(stderr, "tigersum: %s: illegal state\n", statefile);
601                         exit(1);
602                     }
603                     memcpy(tth.stack[i], dbuf, 24);
604                 }
605                 if(fgets(buf, sizeof(buf), state) == NULL) {
606                     fprintf(stderr, "tigersum: %s: could not read entire state\n", statefile);
607                     exit(1);
608                 }
609                 tth.offset = atoi(buf);
610                 if(fgets(buf, sizeof(buf), state) == NULL) {
611                     fprintf(stderr, "tigersum: %s: could not read entire state\n", statefile);
612                     exit(1);
613                 }
614                 base64decode(dbuf, buf, &ret);
615                 if(ret != tth.offset) {
616                     fprintf(stderr, "tigersum: %s: illegal state\n", statefile);
617                     exit(1);
618                 }
619                 memcpy(&tth.block, dbuf, tth.offset);
620                 fclose(state);
621             }
622         }
623         while(1) {
624             ret = read(0, buf, sizeof(buf));
625             if(ret < 0) {
626                 perror("tigersum: read");
627                 exit(1);
628             }
629             if(ret == 0)
630                 break;
631             len = ret;
632             for(len2 = 0; len2 < len; len2 += ret) {
633                 if((ret = write(1, buf, ret)) < 0) {
634                     perror("tigersum: write");
635                     exit(1);
636                 }
637             }
638             dotigertree(&tth, buf, len);
639         }
640         if(statefile != NULL) {
641             if((state = fopen(statefile, "w")) == NULL) {
642                 fprintf(stderr, "tigersum: %s: %s\n", statefile, strerror(errno));
643                 exit(1);
644             }
645             fprintf(state, "%i\n", tth.blocks);
646             fprintf(state, "%i\n", tth.depth);
647             for(i = 0; i < tth.depth; i++) {
648                 base64encode(dbuf, tth.stack[i], 24);
649                 fprintf(state, "%s\n", dbuf);
650             }
651             fprintf(state, "%i\n", tth.offset);
652             base64encode(dbuf, tth.block, tth.offset);
653             fputs(dbuf, state);
654             fputc('\n', state);
655             fclose(state);
656         }
657         synctigertree(&tth);
658         restigertree(&tth, res);
659         if(output == 4)
660             hexencode(dbuf, res, 24);
661         else if(output == 5)
662             base32encode(dbuf, res, 24);
663         else if(output == 6)
664             base64encode(dbuf, res, 24);
665         for(len = 0; len < strlen(dbuf); len += ret) {
666             if((ret = write(outfd, dbuf + len, strlen(dbuf) - len)) < 0) {
667                 perror("tigersum: output");
668                 exit(1);
669             }
670         }
671         write(outfd, "\n", 1);
672     } else {
673         for(i = optind; i < argc; i++) {
674             if(!strcmp(argv[i], "-")) {
675                 fd = 0;
676             } else {
677                 if((fd = open(argv[i], O_RDONLY)) < 0) {
678                     fprintf(stderr, "tigersum: %s: %s\n", argv[i], strerror(errno));
679                     exit(1);
680                 }
681             }
682             if(progress) {
683                 fstat(fd, &sb);
684                 if(!S_ISREG(sb.st_mode))
685                     sb.st_size = -1;
686                 bytes = 0;
687             }
688             inittigertree(&tth);
689             while(1) {
690                 ret = read(fd, buf, sizeof(buf));
691                 if(ret < 0) {
692                     perror("tigersum: read");
693                     exit(1);
694                 }
695                 if(progress) {
696                     if((bytes == 0) || ((bytes & ~0xFFFFF) != ((bytes + ret) & ~0xFFFFF))) {
697                         bytes += ret;
698                         fprintf(stderr, "\033[1G");
699                         if(argc - optind > 1)
700                             fprintf(stderr, "%s: ", argv[i]);
701                         if(sb.st_size < 0) {
702                             fprintf(stderr, "%i", bytes);
703                         } else {
704                             fprintf(stderr, "%i%%", (int)(((float)bytes / (float)sb.st_size) * 100.0));
705                         }
706                         fprintf(stderr, "\033[K");
707                         fflush(stderr);
708                     } else {
709                         bytes += ret;
710                     }
711                 }
712                 if(ret == 0)
713                     break;
714                 dotigertree(&tth, buf, ret);
715             }
716             if(progress)
717                 fprintf(stderr, "\n");
718             synctigertree(&tth);
719             restigertree(&tth, res);
720             if(output == 4)
721                 hexencode(dbuf, res, 24);
722             else if(output == 5)
723                 base32encode(dbuf, res, 24);
724             else if(output == 6)
725                 base64encode(dbuf, res, 24);
726             if(argc - optind > 1)
727                 printf("%s %s\n", dbuf, argv[i]);
728             else
729                 printf("%s\n", dbuf);
730             fflush(stdout);
731             close(fd);
732         }
733     }
734     return(0);
735 }
736
737 static unsigned long long table[1024] = {
738     0x02aab17cf7e90c5eULL,    0xac424b03e243a8ecULL,
739     0x72cd5be30dd5fcd3ULL,    0x6d019b93f6f97f3aULL,
740     0xcd9978ffd21f9193ULL,    0x7573a1c9708029e2ULL,
741     0xb164326b922a83c3ULL,    0x46883eee04915870ULL,
742     0xeaace3057103ece6ULL,    0xc54169b808a3535cULL,
743     0x4ce754918ddec47cULL,    0x0aa2f4dfdc0df40cULL,
744     0x10b76f18a74dbefaULL,    0xc6ccb6235ad1ab6aULL,
745     0x13726121572fe2ffULL,    0x1a488c6f199d921eULL,
746     0x4bc9f9f4da0007caULL,    0x26f5e6f6e85241c7ULL,
747     0x859079dbea5947b6ULL,    0x4f1885c5c99e8c92ULL,
748     0xd78e761ea96f864bULL,    0x8e36428c52b5c17dULL,
749     0x69cf6827373063c1ULL,    0xb607c93d9bb4c56eULL,
750     0x7d820e760e76b5eaULL,    0x645c9cc6f07fdc42ULL,
751     0xbf38a078243342e0ULL,    0x5f6b343c9d2e7d04ULL,
752     0xf2c28aeb600b0ec6ULL,    0x6c0ed85f7254bcacULL,
753     0x71592281a4db4fe5ULL,    0x1967fa69ce0fed9fULL,
754     0xfd5293f8b96545dbULL,    0xc879e9d7f2a7600bULL,
755     0x860248920193194eULL,    0xa4f9533b2d9cc0b3ULL,
756     0x9053836c15957613ULL,    0xdb6dcf8afc357bf1ULL,
757     0x18beea7a7a370f57ULL,    0x037117ca50b99066ULL,
758     0x6ab30a9774424a35ULL,    0xf4e92f02e325249bULL,
759     0x7739db07061ccae1ULL,    0xd8f3b49ceca42a05ULL,
760     0xbd56be3f51382f73ULL,    0x45faed5843b0bb28ULL,
761     0x1c813d5c11bf1f83ULL,    0x8af0e4b6d75fa169ULL,
762     0x33ee18a487ad9999ULL,    0x3c26e8eab1c94410ULL,
763     0xb510102bc0a822f9ULL,    0x141eef310ce6123bULL,
764     0xfc65b90059ddb154ULL,    0xe0158640c5e0e607ULL,
765     0x884e079826c3a3cfULL,    0x930d0d9523c535fdULL,
766     0x35638d754e9a2b00ULL,    0x4085fccf40469dd5ULL,
767     0xc4b17ad28be23a4cULL,    0xcab2f0fc6a3e6a2eULL,
768     0x2860971a6b943fcdULL,    0x3dde6ee212e30446ULL,
769     0x6222f32ae01765aeULL,    0x5d550bb5478308feULL,
770     0xa9efa98da0eda22aULL,    0xc351a71686c40da7ULL,
771     0x1105586d9c867c84ULL,    0xdcffee85fda22853ULL,
772     0xccfbd0262c5eef76ULL,    0xbaf294cb8990d201ULL,
773     0xe69464f52afad975ULL,    0x94b013afdf133e14ULL,
774     0x06a7d1a32823c958ULL,    0x6f95fe5130f61119ULL,
775     0xd92ab34e462c06c0ULL,    0xed7bde33887c71d2ULL,
776     0x79746d6e6518393eULL,    0x5ba419385d713329ULL,
777     0x7c1ba6b948a97564ULL,    0x31987c197bfdac67ULL,
778     0xde6c23c44b053d02ULL,    0x581c49fed002d64dULL,
779     0xdd474d6338261571ULL,    0xaa4546c3e473d062ULL,
780     0x928fce349455f860ULL,    0x48161bbacaab94d9ULL,
781     0x63912430770e6f68ULL,    0x6ec8a5e602c6641cULL,
782     0x87282515337ddd2bULL,    0x2cda6b42034b701bULL,
783     0xb03d37c181cb096dULL,    0xe108438266c71c6fULL,
784     0x2b3180c7eb51b255ULL,    0xdf92b82f96c08bbcULL,
785     0x5c68c8c0a632f3baULL,    0x5504cc861c3d0556ULL,
786     0xabbfa4e55fb26b8fULL,    0x41848b0ab3baceb4ULL,
787     0xb334a273aa445d32ULL,    0xbca696f0a85ad881ULL,
788     0x24f6ec65b528d56cULL,    0x0ce1512e90f4524aULL,
789     0x4e9dd79d5506d35aULL,    0x258905fac6ce9779ULL,
790     0x2019295b3e109b33ULL,    0xf8a9478b73a054ccULL,
791     0x2924f2f934417eb0ULL,    0x3993357d536d1bc4ULL,
792     0x38a81ac21db6ff8bULL,    0x47c4fbf17d6016bfULL,
793     0x1e0faadd7667e3f5ULL,    0x7abcff62938beb96ULL,
794     0xa78dad948fc179c9ULL,    0x8f1f98b72911e50dULL,
795     0x61e48eae27121a91ULL,    0x4d62f7ad31859808ULL,
796     0xeceba345ef5ceaebULL,    0xf5ceb25ebc9684ceULL,
797     0xf633e20cb7f76221ULL,    0xa32cdf06ab8293e4ULL,
798     0x985a202ca5ee2ca4ULL,    0xcf0b8447cc8a8fb1ULL,
799     0x9f765244979859a3ULL,    0xa8d516b1a1240017ULL,
800     0x0bd7ba3ebb5dc726ULL,    0xe54bca55b86adb39ULL,
801     0x1d7a3afd6c478063ULL,    0x519ec608e7669eddULL,
802     0x0e5715a2d149aa23ULL,    0x177d4571848ff194ULL,
803     0xeeb55f3241014c22ULL,    0x0f5e5ca13a6e2ec2ULL,
804     0x8029927b75f5c361ULL,    0xad139fabc3d6e436ULL,
805     0x0d5df1a94ccf402fULL,    0x3e8bd948bea5dfc8ULL,
806     0xa5a0d357bd3ff77eULL,    0xa2d12e251f74f645ULL,
807     0x66fd9e525e81a082ULL,    0x2e0c90ce7f687a49ULL,
808     0xc2e8bcbeba973bc5ULL,    0x000001bce509745fULL,
809     0x423777bbe6dab3d6ULL,    0xd1661c7eaef06eb5ULL,
810     0xa1781f354daacfd8ULL,    0x2d11284a2b16affcULL,
811     0xf1fc4f67fa891d1fULL,    0x73ecc25dcb920adaULL,
812     0xae610c22c2a12651ULL,    0x96e0a810d356b78aULL,
813     0x5a9a381f2fe7870fULL,    0xd5ad62ede94e5530ULL,
814     0xd225e5e8368d1427ULL,    0x65977b70c7af4631ULL,
815     0x99f889b2de39d74fULL,    0x233f30bf54e1d143ULL,
816     0x9a9675d3d9a63c97ULL,    0x5470554ff334f9a8ULL,
817     0x166acb744a4f5688ULL,    0x70c74caab2e4aeadULL,
818     0xf0d091646f294d12ULL,    0x57b82a89684031d1ULL,
819     0xefd95a5a61be0b6bULL,    0x2fbd12e969f2f29aULL,
820     0x9bd37013feff9fe8ULL,    0x3f9b0404d6085a06ULL,
821     0x4940c1f3166cfe15ULL,    0x09542c4dcdf3defbULL,
822     0xb4c5218385cd5ce3ULL,    0xc935b7dc4462a641ULL,
823     0x3417f8a68ed3b63fULL,    0xb80959295b215b40ULL,
824     0xf99cdaef3b8c8572ULL,    0x018c0614f8fcb95dULL,
825     0x1b14accd1a3acdf3ULL,    0x84d471f200bb732dULL,
826     0xc1a3110e95e8da16ULL,    0x430a7220bf1a82b8ULL,
827     0xb77e090d39df210eULL,    0x5ef4bd9f3cd05e9dULL,
828     0x9d4ff6da7e57a444ULL,    0xda1d60e183d4a5f8ULL,
829     0xb287c38417998e47ULL,    0xfe3edc121bb31886ULL,
830     0xc7fe3ccc980ccbefULL,    0xe46fb590189bfd03ULL,
831     0x3732fd469a4c57dcULL,    0x7ef700a07cf1ad65ULL,
832     0x59c64468a31d8859ULL,    0x762fb0b4d45b61f6ULL,
833     0x155baed099047718ULL,    0x68755e4c3d50baa6ULL,
834     0xe9214e7f22d8b4dfULL,    0x2addbf532eac95f4ULL,
835     0x32ae3909b4bd0109ULL,    0x834df537b08e3450ULL,
836     0xfa209da84220728dULL,    0x9e691d9b9efe23f7ULL,
837     0x0446d288c4ae8d7fULL,    0x7b4cc524e169785bULL,
838     0x21d87f0135ca1385ULL,    0xcebb400f137b8aa5ULL,
839     0x272e2b66580796beULL,    0x3612264125c2b0deULL,
840     0x057702bdad1efbb2ULL,    0xd4babb8eacf84be9ULL,
841     0x91583139641bc67bULL,    0x8bdc2de08036e024ULL,
842     0x603c8156f49f68edULL,    0xf7d236f7dbef5111ULL,
843     0x9727c4598ad21e80ULL,    0xa08a0896670a5fd7ULL,
844     0xcb4a8f4309eba9cbULL,    0x81af564b0f7036a1ULL,
845     0xc0b99aa778199abdULL,    0x959f1ec83fc8e952ULL,
846     0x8c505077794a81b9ULL,    0x3acaaf8f056338f0ULL,
847     0x07b43f50627a6778ULL,    0x4a44ab49f5eccc77ULL,
848     0x3bc3d6e4b679ee98ULL,    0x9cc0d4d1cf14108cULL,
849     0x4406c00b206bc8a0ULL,    0x82a18854c8d72d89ULL,
850     0x67e366b35c3c432cULL,    0xb923dd61102b37f2ULL,
851     0x56ab2779d884271dULL,    0xbe83e1b0ff1525afULL,
852     0xfb7c65d4217e49a9ULL,    0x6bdbe0e76d48e7d4ULL,
853     0x08df828745d9179eULL,    0x22ea6a9add53bd34ULL,
854     0xe36e141c5622200aULL,    0x7f805d1b8cb750eeULL,
855     0xafe5c7a59f58e837ULL,    0xe27f996a4fb1c23cULL,
856     0xd3867dfb0775f0d0ULL,    0xd0e673de6e88891aULL,
857     0x123aeb9eafb86c25ULL,    0x30f1d5d5c145b895ULL,
858     0xbb434a2dee7269e7ULL,    0x78cb67ecf931fa38ULL,
859     0xf33b0372323bbf9cULL,    0x52d66336fb279c74ULL,
860     0x505f33ac0afb4eaaULL,    0xe8a5cd99a2cce187ULL,
861     0x534974801e2d30bbULL,    0x8d2d5711d5876d90ULL,
862     0x1f1a412891bc038eULL,    0xd6e2e71d82e56648ULL,
863     0x74036c3a497732b7ULL,    0x89b67ed96361f5abULL,
864     0xffed95d8f1ea02a2ULL,    0xe72b3bd61464d43dULL,
865     0xa6300f170bdc4820ULL,    0xebc18760ed78a77aULL,
866     0xe6a6be5a05a12138ULL,    0xb5a122a5b4f87c98ULL,
867     0x563c6089140b6990ULL,    0x4c46cb2e391f5dd5ULL,
868     0xd932addbc9b79434ULL,    0x08ea70e42015aff5ULL,
869     0xd765a6673e478cf1ULL,    0xc4fb757eab278d99ULL,
870     0xdf11c6862d6e0692ULL,    0xddeb84f10d7f3b16ULL,
871     0x6f2ef604a665ea04ULL,    0x4a8e0f0ff0e0dfb3ULL,
872     0xa5edeef83dbcba51ULL,    0xfc4f0a2a0ea4371eULL,
873     0xe83e1da85cb38429ULL,    0xdc8ff882ba1b1ce2ULL,
874     0xcd45505e8353e80dULL,    0x18d19a00d4db0717ULL,
875     0x34a0cfeda5f38101ULL,    0x0be77e518887caf2ULL,
876     0x1e341438b3c45136ULL,    0xe05797f49089ccf9ULL,
877     0xffd23f9df2591d14ULL,    0x543dda228595c5cdULL,
878     0x661f81fd99052a33ULL,    0x8736e641db0f7b76ULL,
879     0x15227725418e5307ULL,    0xe25f7f46162eb2faULL,
880     0x48a8b2126c13d9feULL,    0xafdc541792e76eeaULL,
881     0x03d912bfc6d1898fULL,    0x31b1aafa1b83f51bULL,
882     0xf1ac2796e42ab7d9ULL,    0x40a3a7d7fcd2ebacULL,
883     0x1056136d0afbbcc5ULL,    0x7889e1dd9a6d0c85ULL,
884     0xd33525782a7974aaULL,    0xa7e25d09078ac09bULL,
885     0xbd4138b3eac6edd0ULL,    0x920abfbe71eb9e70ULL,
886     0xa2a5d0f54fc2625cULL,    0xc054e36b0b1290a3ULL,
887     0xf6dd59ff62fe932bULL,    0x3537354511a8ac7dULL,
888     0xca845e9172fadcd4ULL,    0x84f82b60329d20dcULL,
889     0x79c62ce1cd672f18ULL,    0x8b09a2add124642cULL,
890     0xd0c1e96a19d9e726ULL,    0x5a786a9b4ba9500cULL,
891     0x0e020336634c43f3ULL,    0xc17b474aeb66d822ULL,
892     0x6a731ae3ec9baac2ULL,    0x8226667ae0840258ULL,
893     0x67d4567691caeca5ULL,    0x1d94155c4875adb5ULL,
894     0x6d00fd985b813fdfULL,    0x51286efcb774cd06ULL,
895     0x5e8834471fa744afULL,    0xf72ca0aee761ae2eULL,
896     0xbe40e4cdaee8e09aULL,    0xe9970bbb5118f665ULL,
897     0x726e4beb33df1964ULL,    0x703b000729199762ULL,
898     0x4631d816f5ef30a7ULL,    0xb880b5b51504a6beULL,
899     0x641793c37ed84b6cULL,    0x7b21ed77f6e97d96ULL,
900     0x776306312ef96b73ULL,    0xae528948e86ff3f4ULL,
901     0x53dbd7f286a3f8f8ULL,    0x16cadce74cfc1063ULL,
902     0x005c19bdfa52c6ddULL,    0x68868f5d64d46ad3ULL,
903     0x3a9d512ccf1e186aULL,    0x367e62c2385660aeULL,
904     0xe359e7ea77dcb1d7ULL,    0x526c0773749abe6eULL,
905     0x735ae5f9d09f734bULL,    0x493fc7cc8a558ba8ULL,
906     0xb0b9c1533041ab45ULL,    0x321958ba470a59bdULL,
907     0x852db00b5f46c393ULL,    0x91209b2bd336b0e5ULL,
908     0x6e604f7d659ef19fULL,    0xb99a8ae2782ccb24ULL,
909     0xccf52ab6c814c4c7ULL,    0x4727d9afbe11727bULL,
910     0x7e950d0c0121b34dULL,    0x756f435670ad471fULL,
911     0xf5add442615a6849ULL,    0x4e87e09980b9957aULL,
912     0x2acfa1df50aee355ULL,    0xd898263afd2fd556ULL,
913     0xc8f4924dd80c8fd6ULL,    0xcf99ca3d754a173aULL,
914     0xfe477bacaf91bf3cULL,    0xed5371f6d690c12dULL,
915     0x831a5c285e687094ULL,    0xc5d3c90a3708a0a4ULL,
916     0x0f7f903717d06580ULL,    0x19f9bb13b8fdf27fULL,
917     0xb1bd6f1b4d502843ULL,    0x1c761ba38fff4012ULL,
918     0x0d1530c4e2e21f3bULL,    0x8943ce69a7372c8aULL,
919     0xe5184e11feb5ce66ULL,    0x618bdb80bd736621ULL,
920     0x7d29bad68b574d0bULL,    0x81bb613e25e6fe5bULL,
921     0x071c9c10bc07913fULL,    0xc7beeb7909ac2d97ULL,
922     0xc3e58d353bc5d757ULL,    0xeb017892f38f61e8ULL,
923     0xd4effb9c9b1cc21aULL,    0x99727d26f494f7abULL,
924     0xa3e063a2956b3e03ULL,    0x9d4a8b9a4aa09c30ULL,
925     0x3f6ab7d500090fb4ULL,    0x9cc0f2a057268ac0ULL,
926     0x3dee9d2dedbf42d1ULL,    0x330f49c87960a972ULL,
927     0xc6b2720287421b41ULL,    0x0ac59ec07c00369cULL,
928     0xef4eac49cb353425ULL,    0xf450244eef0129d8ULL,
929     0x8acc46e5caf4deb6ULL,    0x2ffeab63989263f7ULL,
930     0x8f7cb9fe5d7a4578ULL,    0x5bd8f7644e634635ULL,
931     0x427a7315bf2dc900ULL,    0x17d0c4aa2125261cULL,
932     0x3992486c93518e50ULL,    0xb4cbfee0a2d7d4c3ULL,
933     0x7c75d6202c5ddd8dULL,    0xdbc295d8e35b6c61ULL,
934     0x60b369d302032b19ULL,    0xce42685fdce44132ULL,
935     0x06f3ddb9ddf65610ULL,    0x8ea4d21db5e148f0ULL,
936     0x20b0fce62fcd496fULL,    0x2c1b912358b0ee31ULL,
937     0xb28317b818f5a308ULL,    0xa89c1e189ca6d2cfULL,
938     0x0c6b18576aaadbc8ULL,    0xb65deaa91299fae3ULL,
939     0xfb2b794b7f1027e7ULL,    0x04e4317f443b5bebULL,
940     0x4b852d325939d0a6ULL,    0xd5ae6beefb207ffcULL,
941     0x309682b281c7d374ULL,    0xbae309a194c3b475ULL,
942     0x8cc3f97b13b49f05ULL,    0x98a9422ff8293967ULL,
943     0x244b16b01076ff7cULL,    0xf8bf571c663d67eeULL,
944     0x1f0d6758eee30da1ULL,    0xc9b611d97adeb9b7ULL,
945     0xb7afd5887b6c57a2ULL,    0x6290ae846b984fe1ULL,
946     0x94df4cdeacc1a5fdULL,    0x058a5bd1c5483affULL,
947     0x63166cc142ba3c37ULL,    0x8db8526eb2f76f40ULL,
948     0xe10880036f0d6d4eULL,    0x9e0523c9971d311dULL,
949     0x45ec2824cc7cd691ULL,    0x575b8359e62382c9ULL,
950     0xfa9e400dc4889995ULL,    0xd1823ecb45721568ULL,
951     0xdafd983b8206082fULL,    0xaa7d29082386a8cbULL,
952     0x269fcd4403b87588ULL,    0x1b91f5f728bdd1e0ULL,
953     0xe4669f39040201f6ULL,    0x7a1d7c218cf04adeULL,
954     0x65623c29d79ce5ceULL,    0x2368449096c00bb1ULL,
955     0xab9bf1879da503baULL,    0xbc23ecb1a458058eULL,
956     0x9a58df01bb401eccULL,    0xa070e868a85f143dULL,
957     0x4ff188307df2239eULL,    0x14d565b41a641183ULL,
958     0xee13337452701602ULL,    0x950e3dcf3f285e09ULL,
959     0x59930254b9c80953ULL,    0x3bf299408930da6dULL,
960     0xa955943f53691387ULL,    0xa15edecaa9cb8784ULL,
961     0x29142127352be9a0ULL,    0x76f0371fff4e7afbULL,
962     0x0239f450274f2228ULL,    0xbb073af01d5e868bULL,
963     0xbfc80571c10e96c1ULL,    0xd267088568222e23ULL,
964     0x9671a3d48e80b5b0ULL,    0x55b5d38ae193bb81ULL,
965     0x693ae2d0a18b04b8ULL,    0x5c48b4ecadd5335fULL,
966     0xfd743b194916a1caULL,    0x2577018134be98c4ULL,
967     0xe77987e83c54a4adULL,    0x28e11014da33e1b9ULL,
968     0x270cc59e226aa213ULL,    0x71495f756d1a5f60ULL,
969     0x9be853fb60afef77ULL,    0xadc786a7f7443dbfULL,
970     0x0904456173b29a82ULL,    0x58bc7a66c232bd5eULL,
971     0xf306558c673ac8b2ULL,    0x41f639c6b6c9772aULL,
972     0x216defe99fda35daULL,    0x11640cc71c7be615ULL,
973     0x93c43694565c5527ULL,    0xea038e6246777839ULL,
974     0xf9abf3ce5a3e2469ULL,    0x741e768d0fd312d2ULL,
975     0x0144b883ced652c6ULL,    0xc20b5a5ba33f8552ULL,
976     0x1ae69633c3435a9dULL,    0x97a28ca4088cfdecULL,
977     0x8824a43c1e96f420ULL,    0x37612fa66eeea746ULL,
978     0x6b4cb165f9cf0e5aULL,    0x43aa1c06a0abfb4aULL,
979     0x7f4dc26ff162796bULL,    0x6cbacc8e54ed9b0fULL,
980     0xa6b7ffefd2bb253eULL,    0x2e25bc95b0a29d4fULL,
981     0x86d6a58bdef1388cULL,    0xded74ac576b6f054ULL,
982     0x8030bdbc2b45805dULL,    0x3c81af70e94d9289ULL,
983     0x3eff6dda9e3100dbULL,    0xb38dc39fdfcc8847ULL,
984     0x123885528d17b87eULL,    0xf2da0ed240b1b642ULL,
985     0x44cefadcd54bf9a9ULL,    0x1312200e433c7ee6ULL,
986     0x9ffcc84f3a78c748ULL,    0xf0cd1f72248576bbULL,
987     0xec6974053638cfe4ULL,    0x2ba7b67c0cec4e4cULL,
988     0xac2f4df3e5ce32edULL,    0xcb33d14326ea4c11ULL,
989     0xa4e9044cc77e58bcULL,    0x5f513293d934fcefULL,
990     0x5dc9645506e55444ULL,    0x50de418f317de40aULL,
991     0x388cb31a69dde259ULL,    0x2db4a83455820a86ULL,
992     0x9010a91e84711ae9ULL,    0x4df7f0b7b1498371ULL,
993     0xd62a2eabc0977179ULL,    0x22fac097aa8d5c0eULL,
994     0xf49fcc2ff1daf39bULL,    0x487fd5c66ff29281ULL,
995     0xe8a30667fcdca83fULL,    0x2c9b4be3d2fcce63ULL,
996     0xda3ff74b93fbbbc2ULL,    0x2fa165d2fe70ba66ULL,
997     0xa103e279970e93d4ULL,    0xbecdec77b0e45e71ULL,
998     0xcfb41e723985e497ULL,    0xb70aaa025ef75017ULL,
999     0xd42309f03840b8e0ULL,    0x8efc1ad035898579ULL,
1000     0x96c6920be2b2abc5ULL,    0x66af4163375a9172ULL,
1001     0x2174abdcca7127fbULL,    0xb33ccea64a72ff41ULL,
1002     0xf04a4933083066a5ULL,    0x8d970acdd7289af5ULL,
1003     0x8f96e8e031c8c25eULL,    0xf3fec02276875d47ULL,
1004     0xec7bf310056190ddULL,    0xf5adb0aebb0f1491ULL,
1005     0x9b50f8850fd58892ULL,    0x4975488358b74de8ULL,
1006     0xa3354ff691531c61ULL,    0x0702bbe481d2c6eeULL,
1007     0x89fb24057deded98ULL,    0xac3075138596e902ULL,
1008     0x1d2d3580172772edULL,    0xeb738fc28e6bc30dULL,
1009     0x5854ef8f63044326ULL,    0x9e5c52325add3bbeULL,
1010     0x90aa53cf325c4623ULL,    0xc1d24d51349dd067ULL,
1011     0x2051cfeea69ea624ULL,    0x13220f0a862e7e4fULL,
1012     0xce39399404e04864ULL,    0xd9c42ca47086fcb7ULL,
1013     0x685ad2238a03e7ccULL,    0x066484b2ab2ff1dbULL,
1014     0xfe9d5d70efbf79ecULL,    0x5b13b9dd9c481854ULL,
1015     0x15f0d475ed1509adULL,    0x0bebcd060ec79851ULL,
1016     0xd58c6791183ab7f8ULL,    0xd1187c5052f3eee4ULL,
1017     0xc95d1192e54e82ffULL,    0x86eea14cb9ac6ca2ULL,
1018     0x3485beb153677d5dULL,    0xdd191d781f8c492aULL,
1019     0xf60866baa784ebf9ULL,    0x518f643ba2d08c74ULL,
1020     0x8852e956e1087c22ULL,    0xa768cb8dc410ae8dULL,
1021     0x38047726bfec8e1aULL,    0xa67738b4cd3b45aaULL,
1022     0xad16691cec0dde19ULL,    0xc6d4319380462e07ULL,
1023     0xc5a5876d0ba61938ULL,    0x16b9fa1fa58fd840ULL,
1024     0x188ab1173ca74f18ULL,    0xabda2f98c99c021fULL,
1025     0x3e0580ab134ae816ULL,    0x5f3b05b773645abbULL,
1026     0x2501a2be5575f2f6ULL,    0x1b2f74004e7e8ba9ULL,
1027     0x1cd7580371e8d953ULL,    0x7f6ed89562764e30ULL,
1028     0xb15926ff596f003dULL,    0x9f65293da8c5d6b9ULL,
1029     0x6ecef04dd690f84cULL,    0x4782275fff33af88ULL,
1030     0xe41433083f820801ULL,    0xfd0dfe409a1af9b5ULL,
1031     0x4325a3342cdb396bULL,    0x8ae77e62b301b252ULL,
1032     0xc36f9e9f6655615aULL,    0x85455a2d92d32c09ULL,
1033     0xf2c7dea949477485ULL,    0x63cfb4c133a39ebaULL,
1034     0x83b040cc6ebc5462ULL,    0x3b9454c8fdb326b0ULL,
1035     0x56f56a9e87ffd78cULL,    0x2dc2940d99f42bc6ULL,
1036     0x98f7df096b096e2dULL,    0x19a6e01e3ad852bfULL,
1037     0x42a99ccbdbd4b40bULL,    0xa59998af45e9c559ULL,
1038     0x366295e807d93186ULL,    0x6b48181bfaa1f773ULL,
1039     0x1fec57e2157a0a1dULL,    0x4667446af6201ad5ULL,
1040     0xe615ebcacfb0f075ULL,    0xb8f31f4f68290778ULL,
1041     0x22713ed6ce22d11eULL,    0x3057c1a72ec3c93bULL,
1042     0xcb46acc37c3f1f2fULL,    0xdbb893fd02aaf50eULL,
1043     0x331fd92e600b9fcfULL,    0xa498f96148ea3ad6ULL,
1044     0xa8d8426e8b6a83eaULL,    0xa089b274b7735cdcULL,
1045     0x87f6b3731e524a11ULL,    0x118808e5cbc96749ULL,
1046     0x9906e4c7b19bd394ULL,    0xafed7f7e9b24a20cULL,
1047     0x6509eadeeb3644a7ULL,    0x6c1ef1d3e8ef0edeULL,
1048     0xb9c97d43e9798fb4ULL,    0xa2f2d784740c28a3ULL,
1049     0x7b8496476197566fULL,    0x7a5be3e6b65f069dULL,
1050     0xf96330ed78be6f10ULL,    0xeee60de77a076a15ULL,
1051     0x2b4bee4aa08b9bd0ULL,    0x6a56a63ec7b8894eULL,
1052     0x02121359ba34fef4ULL,    0x4cbf99f8283703fcULL,
1053     0x398071350caf30c8ULL,    0xd0a77a89f017687aULL,
1054     0xf1c1a9eb9e423569ULL,    0x8c7976282dee8199ULL,
1055     0x5d1737a5dd1f7abdULL,    0x4f53433c09a9fa80ULL,
1056     0xfa8b0c53df7ca1d9ULL,    0x3fd9dcbc886ccb77ULL,
1057     0xc040917ca91b4720ULL,    0x7dd00142f9d1dcdfULL,
1058     0x8476fc1d4f387b58ULL,    0x23f8e7c5f3316503ULL,
1059     0x032a2244e7e37339ULL,    0x5c87a5d750f5a74bULL,
1060     0x082b4cc43698992eULL,    0xdf917becb858f63cULL,
1061     0x3270b8fc5bf86ddaULL,    0x10ae72bb29b5dd76ULL,
1062     0x576ac94e7700362bULL,    0x1ad112dac61efb8fULL,
1063     0x691bc30ec5faa427ULL,    0xff246311cc327143ULL,
1064     0x3142368e30e53206ULL,    0x71380e31e02ca396ULL,
1065     0x958d5c960aad76f1ULL,    0xf8d6f430c16da536ULL,
1066     0xc8ffd13f1be7e1d2ULL,    0x7578ae66004ddbe1ULL,
1067     0x05833f01067be646ULL,    0xbb34b5ad3bfe586dULL,
1068     0x095f34c9a12b97f0ULL,    0x247ab64525d60ca8ULL,
1069     0xdcdbc6f3017477d1ULL,    0x4a2e14d4decad24dULL,
1070     0xbdb5e6d9be0a1eebULL,    0x2a7e70f7794301abULL,
1071     0xdef42d8a270540fdULL,    0x01078ec0a34c22c1ULL,
1072     0xe5de511af4c16387ULL,    0x7ebb3a52bd9a330aULL,
1073     0x77697857aa7d6435ULL,    0x004e831603ae4c32ULL,
1074     0xe7a21020ad78e312ULL,    0x9d41a70c6ab420f2ULL,
1075     0x28e06c18ea1141e6ULL,    0xd2b28cbd984f6b28ULL,
1076     0x26b75f6c446e9d83ULL,    0xba47568c4d418d7fULL,
1077     0xd80badbfe6183d8eULL,    0x0e206d7f5f166044ULL,
1078     0xe258a43911cbca3eULL,    0x723a1746b21dc0bcULL,
1079     0xc7caa854f5d7cdd3ULL,    0x7cac32883d261d9cULL,
1080     0x7690c26423ba942cULL,    0x17e55524478042b8ULL,
1081     0xe0be477656a2389fULL,    0x4d289b5e67ab2da0ULL,
1082     0x44862b9c8fbbfd31ULL,    0xb47cc8049d141365ULL,
1083     0x822c1b362b91c793ULL,    0x4eb14655fb13dfd8ULL,
1084     0x1ecbba0714e2a97bULL,    0x6143459d5cde5f14ULL,
1085     0x53a8fbf1d5f0ac89ULL,    0x97ea04d81c5e5b00ULL,
1086     0x622181a8d4fdb3f3ULL,    0xe9bcd341572a1208ULL,
1087     0x1411258643cce58aULL,    0x9144c5fea4c6e0a4ULL,
1088     0x0d33d06565cf620fULL,    0x54a48d489f219ca1ULL,
1089     0xc43e5eac6d63c821ULL,    0xa9728b3a72770dafULL,
1090     0xd7934e7b20df87efULL,    0xe35503b61a3e86e5ULL,
1091     0xcae321fbc819d504ULL,    0x129a50b3ac60bfa6ULL,
1092     0xcd5e68ea7e9fb6c3ULL,    0xb01c90199483b1c7ULL,
1093     0x3de93cd5c295376cULL,    0xaed52edf2ab9ad13ULL,
1094     0x2e60f512c0a07884ULL,    0xbc3d86a3e36210c9ULL,
1095     0x35269d9b163951ceULL,    0x0c7d6e2ad0cdb5faULL,
1096     0x59e86297d87f5733ULL,    0x298ef221898db0e7ULL,
1097     0x55000029d1a5aa7eULL,    0x8bc08ae1b5061b45ULL,
1098     0xc2c31c2b6c92703aULL,    0x94cc596baf25ef42ULL,
1099     0x0a1d73db22540456ULL,    0x04b6a0f9d9c4179aULL,
1100     0xeffdafa2ae3d3c60ULL,    0xf7c8075bb49496c4ULL,
1101     0x9cc5c7141d1cd4e3ULL,    0x78bd1638218e5534ULL,
1102     0xb2f11568f850246aULL,    0xedfabcfa9502bc29ULL,
1103     0x796ce5f2da23051bULL,    0xaae128b0dc93537cULL,
1104     0x3a493da0ee4b29aeULL,    0xb5df6b2c416895d7ULL,
1105     0xfcabbd25122d7f37ULL,    0x70810b58105dc4b1ULL,
1106     0xe10fdd37f7882a90ULL,    0x524dcab5518a3f5cULL,
1107     0x3c9e85878451255bULL,    0x4029828119bd34e2ULL,
1108     0x74a05b6f5d3ceccbULL,    0xb610021542e13ecaULL,
1109     0x0ff979d12f59e2acULL,    0x6037da27e4f9cc50ULL,
1110     0x5e92975a0df1847dULL,    0xd66de190d3e623feULL,
1111     0x5032d6b87b568048ULL,    0x9a36b7ce8235216eULL,
1112     0x80272a7a24f64b4aULL,    0x93efed8b8c6916f7ULL,
1113     0x37ddbff44cce1555ULL,    0x4b95db5d4b99bd25ULL,
1114     0x92d3fda169812fc0ULL,    0xfb1a4a9a90660bb6ULL,
1115     0x730c196946a4b9b2ULL,    0x81e289aa7f49da68ULL,
1116     0x64669a0f83b1a05fULL,    0x27b3ff7d9644f48bULL,
1117     0xcc6b615c8db675b3ULL,    0x674f20b9bcebbe95ULL,
1118     0x6f31238275655982ULL,    0x5ae488713e45cf05ULL,
1119     0xbf619f9954c21157ULL,    0xeabac46040a8eae9ULL,
1120     0x454c6fe9f2c0c1cdULL,    0x419cf6496412691cULL,
1121     0xd3dc3bef265b0f70ULL,    0x6d0e60f5c3578a9eULL,
1122     0x5b0e608526323c55ULL,    0x1a46c1a9fa1b59f5ULL,
1123     0xa9e245a17c4c8ffaULL,    0x65ca5159db2955d7ULL,
1124     0x05db0a76ce35afc2ULL,    0x81eac77ea9113d45ULL,
1125     0x528ef88ab6ac0a0dULL,    0xa09ea253597be3ffULL,
1126     0x430ddfb3ac48cd56ULL,    0xc4b3a67af45ce46fULL,
1127     0x4ececfd8fbe2d05eULL,    0x3ef56f10b39935f0ULL,
1128     0x0b22d6829cd619c6ULL,    0x17fd460a74df2069ULL,
1129     0x6cf8cc8e8510ed40ULL,    0xd6c824bf3a6ecaa7ULL,
1130     0x61243d581a817049ULL,    0x048bacb6bbc163a2ULL,
1131     0xd9a38ac27d44cc32ULL,    0x7fddff5baaf410abULL,
1132     0xad6d495aa804824bULL,    0xe1a6a74f2d8c9f94ULL,
1133     0xd4f7851235dee8e3ULL,    0xfd4b7f886540d893ULL,
1134     0x247c20042aa4bfdaULL,    0x096ea1c517d1327cULL,
1135     0xd56966b4361a6685ULL,    0x277da5c31221057dULL,
1136     0x94d59893a43acff7ULL,    0x64f0c51ccdc02281ULL,
1137     0x3d33bcc4ff6189dbULL,    0xe005cb184ce66af1ULL,
1138     0xff5ccd1d1db99beaULL,    0xb0b854a7fe42980fULL,
1139     0x7bd46a6a718d4b9fULL,    0xd10fa8cc22a5fd8cULL,
1140     0xd31484952be4bd31ULL,    0xc7fa975fcb243847ULL,
1141     0x4886ed1e5846c407ULL,    0x28cddb791eb70b04ULL,
1142     0xc2b00be2f573417fULL,    0x5c9590452180f877ULL,
1143     0x7a6bddfff370eb00ULL,    0xce509e38d6d9d6a4ULL,
1144     0xebeb0f00647fa702ULL,    0x1dcc06cf76606f06ULL,
1145     0xe4d9f28ba286ff0aULL,    0xd85a305dc918c262ULL,
1146     0x475b1d8732225f54ULL,    0x2d4fb51668ccb5feULL,
1147     0xa679b9d9d72bba20ULL,    0x53841c0d912d43a5ULL,
1148     0x3b7eaa48bf12a4e8ULL,    0x781e0e47f22f1ddfULL,
1149     0xeff20ce60ab50973ULL,    0x20d261d19dffb742ULL,
1150     0x16a12b03062a2e39ULL,    0x1960eb2239650495ULL,
1151     0x251c16fed50eb8b8ULL,    0x9ac0c330f826016eULL,
1152     0xed152665953e7671ULL,    0x02d63194a6369570ULL,
1153     0x5074f08394b1c987ULL,    0x70ba598c90b25ce1ULL,
1154     0x794a15810b9742f6ULL,    0x0d5925e9fcaf8c6cULL,
1155     0x3067716cd868744eULL,    0x910ab077e8d7731bULL,
1156     0x6a61bbdb5ac42f61ULL,    0x93513efbf0851567ULL,
1157     0xf494724b9e83e9d5ULL,    0xe887e1985c09648dULL,
1158     0x34b1d3c675370cfdULL,    0xdc35e433bc0d255dULL,
1159     0xd0aab84234131be0ULL,    0x08042a50b48b7eafULL,
1160     0x9997c4ee44a3ab35ULL,    0x829a7b49201799d0ULL,
1161     0x263b8307b7c54441ULL,    0x752f95f4fd6a6ca6ULL,
1162     0x927217402c08c6e5ULL,    0x2a8ab754a795d9eeULL,
1163     0xa442f7552f72943dULL,    0x2c31334e19781208ULL,
1164     0x4fa98d7ceaee6291ULL,    0x55c3862f665db309ULL,
1165     0xbd0610175d53b1f3ULL,    0x46fe6cb840413f27ULL,
1166     0x3fe03792df0cfa59ULL,    0xcfe700372eb85e8fULL,
1167     0xa7be29e7adbce118ULL,    0xe544ee5cde8431ddULL,
1168     0x8a781b1b41f1873eULL,    0xa5c94c78a0d2f0e7ULL,
1169     0x39412e2877b60728ULL,    0xa1265ef3afc9a62cULL,
1170     0xbcc2770c6a2506c5ULL,    0x3ab66dd5dce1ce12ULL,
1171     0xe65499d04a675b37ULL,    0x7d8f523481bfd216ULL,
1172     0x0f6f64fcec15f389ULL,    0x74efbe618b5b13c8ULL,
1173     0xacdc82b714273e1dULL,    0xdd40bfe003199d17ULL,
1174     0x37e99257e7e061f8ULL,    0xfa52626904775aaaULL,
1175     0x8bbbf63a463d56f9ULL,    0xf0013f1543a26e64ULL,
1176     0xa8307e9f879ec898ULL,    0xcc4c27a4150177ccULL,
1177     0x1b432f2cca1d3348ULL,    0xde1d1f8f9f6fa013ULL,
1178     0x606602a047a7ddd6ULL,    0xd237ab64cc1cb2c7ULL,
1179     0x9b938e7225fcd1d3ULL,    0xec4e03708e0ff476ULL,
1180     0xfeb2fbda3d03c12dULL,    0xae0bced2ee43889aULL,
1181     0x22cb8923ebfb4f43ULL,    0x69360d013cf7396dULL,
1182     0x855e3602d2d4e022ULL,    0x073805bad01f784cULL,
1183     0x33e17a133852f546ULL,    0xdf4874058ac7b638ULL,
1184     0xba92b29c678aa14aULL,    0x0ce89fc76cfaadcdULL,
1185     0x5f9d4e0908339e34ULL,    0xf1afe9291f5923b9ULL,
1186     0x6e3480f60f4a265fULL,    0xeebf3a2ab29b841cULL,
1187     0xe21938a88f91b4adULL,    0x57dfeff845c6d3c3ULL,
1188     0x2f006b0bf62caaf2ULL,    0x62f479ef6f75ee78ULL,
1189     0x11a55ad41c8916a9ULL,    0xf229d29084fed453ULL,
1190     0x42f1c27b16b000e6ULL,    0x2b1f76749823c074ULL,
1191     0x4b76eca3c2745360ULL,    0x8c98f463b91691bdULL,
1192     0x14bcc93cf1ade66aULL,    0x8885213e6d458397ULL,
1193     0x8e177df0274d4711ULL,    0xb49b73b5503f2951ULL,
1194     0x10168168c3f96b6bULL,    0x0e3d963b63cab0aeULL,
1195     0x8dfc4b5655a1db14ULL,    0xf789f1356e14de5cULL,
1196     0x683e68af4e51dac1ULL,    0xc9a84f9d8d4b0fd9ULL,
1197     0x3691e03f52a0f9d1ULL,    0x5ed86e46e1878e80ULL,
1198     0x3c711a0e99d07150ULL,    0x5a0865b20c4e9310ULL,
1199     0x56fbfc1fe4f0682eULL,    0xea8d5de3105edf9bULL,
1200     0x71abfdb12379187aULL,    0x2eb99de1bee77b9cULL,
1201     0x21ecc0ea33cf4523ULL,    0x59a4d7521805c7a1ULL,
1202     0x3896f5eb56ae7c72ULL,    0xaa638f3db18f75dcULL,
1203     0x9f39358dabe9808eULL,    0xb7defa91c00b72acULL,
1204     0x6b5541fd62492d92ULL,    0x6dc6dee8f92e4d5bULL,
1205     0x353f57abc4beea7eULL,    0x735769d6da5690ceULL,
1206     0x0a234aa642391484ULL,    0xf6f9508028f80d9dULL,
1207     0xb8e319a27ab3f215ULL,    0x31ad9c1151341a4dULL,
1208     0x773c22a57bef5805ULL,    0x45c7561a07968633ULL,
1209     0xf913da9e249dbe36ULL,    0xda652d9b78a64c68ULL,
1210     0x4c27a97f3bc334efULL,    0x76621220e66b17f4ULL,
1211     0x967743899acd7d0bULL,    0xf3ee5bcae0ed6782ULL,
1212     0x409f753600c879fcULL,    0x06d09a39b5926db6ULL,
1213     0x6f83aeb0317ac588ULL,    0x01e6ca4a86381f21ULL,
1214     0x66ff3462d19f3025ULL,    0x72207c24ddfd3bfbULL,
1215     0x4af6b6d3e2ece2ebULL,    0x9c994dbec7ea08deULL,
1216     0x49ace597b09a8bc4ULL,    0xb38c4766cf0797baULL,
1217     0x131b9373c57c2a75ULL,    0xb1822cce61931e58ULL,
1218     0x9d7555b909ba1c0cULL,    0x127fafdd937d11d2ULL,
1219     0x29da3badc66d92e4ULL,    0xa2c1d57154c2ecbcULL,
1220     0x58c5134d82f6fe24ULL,    0x1c3ae3515b62274fULL,
1221     0xe907c82e01cb8126ULL,    0xf8ed091913e37fcbULL,
1222     0x3249d8f9c80046c9ULL,    0x80cf9bede388fb63ULL,
1223     0x1881539a116cf19eULL,    0x5103f3f76bd52457ULL,
1224     0x15b7e6f5ae47f7a8ULL,    0xdbd7c6ded47e9ccfULL,
1225     0x44e55c410228bb1aULL,    0xb647d4255edb4e99ULL,
1226     0x5d11882bb8aafc30ULL,    0xf5098bbb29d3212aULL,
1227     0x8fb5ea14e90296b3ULL,    0x677b942157dd025aULL,
1228     0xfb58e7c0a390acb5ULL,    0x89d3674c83bd4a01ULL,
1229     0x9e2da4df4bf3b93bULL,    0xfcc41e328cab4829ULL,
1230     0x03f38c96ba582c52ULL,    0xcad1bdbd7fd85db2ULL,
1231     0xbbb442c16082ae83ULL,    0xb95fe86ba5da9ab0ULL,
1232     0xb22e04673771a93fULL,    0x845358c9493152d8ULL,
1233     0xbe2a488697b4541eULL,    0x95a2dc2dd38e6966ULL,
1234     0xc02c11ac923c852bULL,    0x2388b1990df2a87bULL,
1235     0x7c8008fa1b4f37beULL,    0x1f70d0c84d54e503ULL,
1236     0x5490adec7ece57d4ULL,    0x002b3c27d9063a3aULL,
1237     0x7eaea3848030a2bfULL,    0xc602326ded2003c0ULL,
1238     0x83a7287d69a94086ULL,    0xc57a5fcb30f57a8aULL,
1239     0xb56844e479ebe779ULL,    0xa373b40f05dcbce9ULL,
1240     0xd71a786e88570ee2ULL,    0x879cbacdbde8f6a0ULL,
1241     0x976ad1bcc164a32fULL,    0xab21e25e9666d78bULL,
1242     0x901063aae5e5c33cULL,    0x9818b34448698d90ULL,
1243     0xe36487ae3e1e8abbULL,    0xafbdf931893bdcb4ULL,
1244     0x6345a0dc5fbbd519ULL,    0x8628fe269b9465caULL,
1245     0x1e5d01603f9c51ecULL,    0x4de44006a15049b7ULL,
1246     0xbf6c70e5f776cbb1ULL,    0x411218f2ef552bedULL,
1247     0xcb0c0708705a36a3ULL,    0xe74d14754f986044ULL,
1248     0xcd56d9430ea8280eULL,    0xc12591d7535f5065ULL,
1249     0xc83223f1720aef96ULL,    0xc3a0396f7363a51fULL
1250 };