annotate pyPRADA_1.2/tools/samtools-0.1.16/misc/md5fa.c @ 0:acc2ca1a3ba4

Uploaded
author siyuan
date Thu, 20 Feb 2014 00:44:58 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
1 #include <stdio.h>
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
2 #include <zlib.h>
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
3 #include "md5.h"
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
4 #include "kseq.h"
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
5
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
6 #define HEX_STR "0123456789abcdef"
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
7
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
8 KSEQ_INIT(gzFile, gzread)
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
9
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
10 static void md5_one(const char *fn)
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
11 {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
12 MD5_CTX md5_one, md5_all;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
13 int l, i, k;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
14 gzFile fp;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
15 kseq_t *seq;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
16 unsigned char unordered[16], digest[16];
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
17
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
18 for (l = 0; l < 16; ++l) unordered[l] = 0;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
19 fp = strcmp(fn, "-")? gzopen(fn, "r") : gzdopen(fileno(stdin), "r");
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
20 if (fp == 0) {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
21 fprintf(stderr, "md5fa: %s: No such file or directory\n", fn);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
22 exit(1);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
23 }
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
24
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
25 MD5Init(&md5_all);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
26 seq = kseq_init(fp);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
27 while ((l = kseq_read(seq)) >= 0) {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
28 for (i = k = 0; i < seq->seq.l; ++i) {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
29 if (islower(seq->seq.s[i])) seq->seq.s[k++] = toupper(seq->seq.s[i]);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
30 else if (isupper(seq->seq.s[i])) seq->seq.s[k++] = seq->seq.s[i];
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
31 }
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
32 MD5Init(&md5_one);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
33 MD5Update(&md5_one, (unsigned char*)seq->seq.s, k);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
34 MD5Final(digest, &md5_one);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
35 for (l = 0; l < 16; ++l) {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
36 printf("%c%c", HEX_STR[digest[l]>>4&0xf], HEX_STR[digest[l]&0xf]);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
37 unordered[l] ^= digest[l];
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
38 }
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
39 printf(" %s %s\n", fn, seq->name.s);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
40 MD5Update(&md5_all, (unsigned char*)seq->seq.s, k);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
41 }
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
42 MD5Final(digest, &md5_all);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
43 kseq_destroy(seq);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
44 for (l = 0; l < 16; ++l)
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
45 printf("%c%c", HEX_STR[digest[l]>>4&0xf], HEX_STR[digest[l]&0xf]);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
46 printf(" %s >ordered\n", fn);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
47 for (l = 0; l < 16; ++l)
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
48 printf("%c%c", HEX_STR[unordered[l]>>4&0xf], HEX_STR[unordered[l]&0xf]);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
49 printf(" %s >unordered\n", fn);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
50 }
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
51
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
52 int main(int argc, char *argv[])
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
53 {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
54 int i;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
55 if (argc == 1) md5_one("-");
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
56 else for (i = 1; i < argc; ++i) md5_one(argv[i]);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
57 return 0;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
58 }