123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- #ifndef _XS_ENCDEC_H
- #define _XS_ENCDEC_H
- d_char *xs_hex_enc(const char *data, int size);
- d_char *xs_hex_dec(const char *hex, int *size);
- d_char *xs_base64_enc(const char *data, int sz);
- d_char *xs_base64_dec(const char *data, int *size);
- d_char *xs_utf8_enc(d_char *str, unsigned int cpoint);
- #ifdef XS_IMPLEMENTATION
- d_char *xs_hex_enc(const char *data, int size)
- {
- d_char *s;
- char *p;
- int n;
- p = s = xs_realloc(NULL, _xs_blk_size(size * 2 + 1));
- for (n = 0; n < size; n++) {
- sprintf(p, "%02x", (unsigned char)data[n]);
- p += 2;
- }
- *p = '\0';
- return s;
- }
- d_char *xs_hex_dec(const char *hex, int *size)
- {
- int sz = strlen(hex);
- d_char *s = NULL;
- char *p;
- int n;
- if (sz % 2)
- return NULL;
- p = s = xs_realloc(NULL, _xs_blk_size(sz / 2 + 1));
- for (n = 0; n < sz; n += 2) {
- int i;
- if (sscanf(&hex[n], "%02x", &i) == 0) {
-
- free(s);
- return NULL;
- }
- else
- *p = i;
- p++;
- }
- *p = '\0';
- *size = sz / 2;
- return s;
- }
- d_char *xs_base64_enc(const char *data, int sz)
- {
- d_char *s;
- unsigned char *p;
- char *i;
- int bsz, n;
- static char *b64_tbl = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
- "abcdefghijklmnopqrstuvwxyz"
- "0123456789+/";
- bsz = ((sz + 3 - 1) / 3) * 4;
- i = s = xs_realloc(NULL, _xs_blk_size(bsz + 1));
- p = (unsigned char *)data;
- for (n = 0; n < sz; n += 3) {
- int l = sz - n;
- if (l == 1) {
- *i++ = b64_tbl[(p[n] >> 2) & 0x3f];
- *i++ = b64_tbl[(p[n] << 4) & 0x3f];
- *i++ = '=';
- *i++ = '=';
- }
- else
- if (l == 2) {
- *i++ = b64_tbl[(p[n] >> 2) & 0x3f];
- *i++ = b64_tbl[(p[n] << 4 | p[n + 1] >> 4) & 0x3f];
- *i++ = b64_tbl[(p[n + 1] << 2) & 0x3f];
- *i++ = '=';
- }
- else {
- *i++ = b64_tbl[(p[n] >> 2) & 0x3f];
- *i++ = b64_tbl[(p[n] << 4 | p[n + 1] >> 4) & 0x3f];
- *i++ = b64_tbl[(p[n + 1] << 2 | p[n + 2] >> 6) & 0x3f];
- *i++ = b64_tbl[(p[n + 2]) & 0x3f];
- }
- }
- *i = '\0';
- return s;
- }
- d_char *xs_base64_dec(const char *data, int *size)
- {
- d_char *s = NULL;
- int sz = 0;
- char *p;
- static char *b64_tbl = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
- "abcdefghijklmnopqrstuvwxyz"
- "0123456789+/=";
- p = (char *)data;
-
- if (strlen(p) % 4)
- return NULL;
- for (p = (char *)data; *p; p += 4) {
- int cs[4];
- int n;
- unsigned char tmp[3];
- for (n = 0; n < 4; n++) {
- char *ss = strchr(b64_tbl, p[n]);
- if (ss == NULL) {
-
- free(s);
- return NULL;
- }
- cs[n] = ss - b64_tbl;
- }
- n = 0;
-
- tmp[n++] = cs[0] << 2 | ((cs[1] >> 4) & 0x0f);
-
- if (cs[2] != 64)
- tmp[n++] = cs[1] << 4 | ((cs[2] >> 2) & 0x3f);
-
- if (cs[3] != 64)
- tmp[n++] = cs[2] << 6 | (cs[3] & 0x3f);
-
- s = xs_realloc(s, _xs_blk_size(sz + n));
- memcpy(s + sz, tmp, n);
- sz += n;
- }
-
- s = xs_realloc(s, _xs_blk_size(sz + 1));
- s[sz] = '\0';
- *size = sz;
- return s;
- }
- d_char *xs_utf8_enc(d_char *str, unsigned int cpoint)
- {
- unsigned char tmp[4];
- int n = 0;
- if (cpoint < 0x80)
- tmp[n++] = cpoint & 0xff;
- else
- if (cpoint < 0x800) {
- tmp[n++] = 0xc0 | (cpoint >> 6);
- tmp[n++] = 0x80 | (cpoint & 0x3f);
- }
- else
- if (cpoint < 0x10000) {
- tmp[n++] = 0xe0 | (cpoint >> 12);
- tmp[n++] = 0x80 | ((cpoint >> 6) & 0x3f);
- tmp[n++] = 0x80 | (cpoint & 0x3f);
- }
- else
- if (cpoint < 0x200000) {
- tmp[n++] = 0xf0 | (cpoint >> 18);
- tmp[n++] = 0x80 | ((cpoint >> 12) & 0x3f);
- tmp[n++] = 0x80 | ((cpoint >> 6) & 0x3f);
- tmp[n++] = 0x80 | (cpoint & 0x3f);
- }
- return xs_append_m(str, (char *)tmp, n);
- }
- #endif
- #endif
|