Blob


1 #include "os.h"
2 #include <libsec.h>
4 char*
5 md5pickle(MD5state *s)
6 {
7 char *p;
8 int m, n;
10 m = 4*9+4*((s->blen+3)/3);
11 p = malloc(m);
12 if(p == nil)
13 return p;
14 n = sprint(p, "%8.8ux %8.8ux %8.8ux %8.8ux ",
15 s->state[0], s->state[1], s->state[2],
16 s->state[3]);
17 enc64(p+n, m-n, s->buf, s->blen);
18 return p;
19 }
21 MD5state*
22 md5unpickle(char *p)
23 {
24 MD5state *s;
26 s = malloc(sizeof(*s));
27 if(s == nil)
28 return nil;
29 s->state[0] = strtoul(p, &p, 16);
30 s->state[1] = strtoul(p, &p, 16);
31 s->state[2] = strtoul(p, &p, 16);
32 s->state[3] = strtoul(p, &p, 16);
33 s->blen = dec64(s->buf, sizeof(s->buf), p, strlen(p));
34 s->malloced = 1;
35 s->seeded = 1;
36 return s;
37 }