diff options
| author | 2023-01-28 17:49:02 +0100 | |
|---|---|---|
| committer | 2023-01-28 17:49:02 +0100 | |
| commit | 876bebd9ac904ca930117237edaf8c3dcae7a922 (patch) | |
| tree | 7e91e26c49e18fd80c7de93ff275ffce83fb14df | |
| parent | Bumped version. (diff) | |
| download | penes-snac2-876bebd9ac904ca930117237edaf8c3dcae7a922.tar.gz penes-snac2-876bebd9ac904ca930117237edaf8c3dcae7a922.tar.xz penes-snac2-876bebd9ac904ca930117237edaf8c3dcae7a922.zip | |
Backport from xs.
| -rw-r--r-- | xs.h | 321 | ||||
| -rw-r--r-- | xs_curl.h | 22 | ||||
| -rw-r--r-- | xs_encdec.h | 28 | ||||
| -rw-r--r-- | xs_glob.h | 6 | ||||
| -rw-r--r-- | xs_httpd.h | 43 | ||||
| -rw-r--r-- | xs_io.h | 16 | ||||
| -rw-r--r-- | xs_json.h | 12 | ||||
| -rw-r--r-- | xs_openssl.h | 34 | ||||
| -rw-r--r-- | xs_regex.h | 19 | ||||
| -rw-r--r-- | xs_set.h | 12 | ||||
| -rw-r--r-- | xs_time.h | 6 | ||||
| -rw-r--r-- | xs_version.h | 2 |
12 files changed, 293 insertions, 228 deletions
| @@ -14,25 +14,31 @@ | |||
| 14 | #include <errno.h> | 14 | #include <errno.h> |
| 15 | 15 | ||
| 16 | typedef enum { | 16 | typedef enum { |
| 17 | XSTYPE_NULL = 0x18, | 17 | XSTYPE_STRING = 0x02, /* C string (\0 delimited) (NOT STORED) */ |
| 18 | XSTYPE_TRUE = 0x06, | 18 | XSTYPE_NUMBER = 0x17, /* C string (\0 delimited) */ |
| 19 | XSTYPE_FALSE = 0x15, | 19 | XSTYPE_NULL = 0x18, /* Special NULL value */ |
| 20 | XSTYPE_LIST = 0x11, | 20 | XSTYPE_TRUE = 0x06, /* Boolean */ |
| 21 | XSTYPE_LITEM = 0x1f, | 21 | XSTYPE_FALSE = 0x15, /* Boolean */ |
| 22 | XSTYPE_EOL = 0x12, | 22 | XSTYPE_LIST = 0x1d, /* Sequence of LITEMs up to EOM (with 24bit size) */ |
| 23 | XSTYPE_DICT = 0x13, | 23 | XSTYPE_LITEM = 0x1f, /* Element of a list (any type) */ |
| 24 | XSTYPE_DITEM = 0x1e, | 24 | XSTYPE_DICT = 0x1c, /* Sequence of DITEMs up to EOM (with 24bit size) */ |
| 25 | XSTYPE_EOD = 0x14, | 25 | XSTYPE_DITEM = 0x1e, /* Element of a dict (STRING key + any type) */ |
| 26 | XSTYPE_NUMBER = 0x17, | 26 | XSTYPE_EOM = 0x19 /* End of Multiple (LIST or DICT) */ |
| 27 | XSTYPE_STRING = 0x02 | ||
| 28 | } xstype; | 27 | } xstype; |
| 29 | 28 | ||
| 30 | 29 | ||
| 31 | /* dynamic strings */ | 30 | /* dynamic strings */ |
| 32 | typedef char d_char; | 31 | typedef char d_char; |
| 33 | 32 | ||
| 33 | /* types */ | ||
| 34 | typedef char xs_val; | ||
| 35 | typedef char xs_str; | ||
| 36 | typedef char xs_list; | ||
| 37 | typedef char xs_dict; | ||
| 38 | typedef char xs_number; | ||
| 39 | |||
| 34 | /* auto-destroyable strings */ | 40 | /* auto-destroyable strings */ |
| 35 | #define xs __attribute__ ((__cleanup__ (_xs_destroy))) d_char | 41 | #define xs __attribute__ ((__cleanup__ (_xs_destroy))) xs_val |
| 36 | 42 | ||
| 37 | /* not really all, just very much */ | 43 | /* not really all, just very much */ |
| 38 | #define XS_ALL 0xfffffff | 44 | #define XS_ALL 0xfffffff |
| @@ -43,60 +49,75 @@ void *_xs_realloc(void *ptr, size_t size, const char *file, int line, const char | |||
| 43 | int _xs_blk_size(int sz); | 49 | int _xs_blk_size(int sz); |
| 44 | void _xs_destroy(char **var); | 50 | void _xs_destroy(char **var); |
| 45 | #define xs_debug() raise(SIGTRAP) | 51 | #define xs_debug() raise(SIGTRAP) |
| 46 | xstype xs_type(const char *data); | 52 | xstype xs_type(const xs_val *data); |
| 47 | int xs_size(const char *data); | 53 | int xs_size(const xs_val *data); |
| 48 | int xs_is_null(const char *data); | 54 | int xs_is_null(const xs_val *data); |
| 49 | d_char *xs_dup(const char *data); | 55 | xs_val *xs_dup(const xs_val *data); |
| 50 | d_char *xs_expand(d_char *data, int offset, int size); | 56 | xs_val *xs_expand(xs_val *data, int offset, int size); |
| 51 | d_char *xs_collapse(d_char *data, int offset, int size); | 57 | xs_val *xs_collapse(xs_val *data, int offset, int size); |
| 52 | d_char *xs_insert_m(d_char *data, int offset, const char *mem, int size); | 58 | xs_val *xs_insert_m(xs_val *data, int offset, const char *mem, int size); |
| 53 | #define xs_insert(data, offset, data2) xs_insert_m(data, offset, data2, xs_size(data2)) | 59 | #define xs_insert(data, offset, data2) xs_insert_m(data, offset, data2, xs_size(data2)) |
| 54 | #define xs_append_m(data, mem, size) xs_insert_m(data, xs_size(data) - 1, mem, size) | 60 | #define xs_append_m(data, mem, size) xs_insert_m(data, xs_size(data) - 1, mem, size) |
| 55 | d_char *xs_str_new(const char *str); | 61 | |
| 56 | d_char *xs_str_wrap_i(const char *prefix, d_char *str, const char *suffix); | 62 | xs_str *xs_str_new(const char *str); |
| 63 | xs_str *xs_str_wrap_i(const char *prefix, xs_str *str, const char *suffix); | ||
| 57 | #define xs_str_prepend_i(str, prefix) xs_str_wrap_i(prefix, str, NULL) | 64 | #define xs_str_prepend_i(str, prefix) xs_str_wrap_i(prefix, str, NULL) |
| 58 | #define xs_str_cat(str, suffix) xs_str_wrap_i(NULL, str, suffix) | 65 | #define xs_str_cat(str, suffix) xs_str_wrap_i(NULL, str, suffix) |
| 59 | d_char *xs_replace_i(d_char *str, const char *sfrom, const char *sto); | 66 | xs_str *xs_replace_i(xs_str *str, const char *sfrom, const char *sto); |
| 60 | #define xs_replace(str, sfrom, sto) xs_replace_i(xs_dup(str), sfrom, sto) | 67 | #define xs_replace(str, sfrom, sto) xs_replace_i(xs_dup(str), sfrom, sto) |
| 61 | d_char *xs_fmt(const char *fmt, ...); | 68 | xs_str *xs_fmt(const char *fmt, ...); |
| 62 | int xs_str_in(const char *haystack, const char *needle); | 69 | int xs_str_in(const char *haystack, const char *needle); |
| 63 | int xs_startswith(const char *str, const char *prefix); | 70 | int xs_startswith(const char *str, const char *prefix); |
| 64 | int xs_endswith(const char *str, const char *postfix); | 71 | int xs_endswith(const char *str, const char *postfix); |
| 65 | d_char *xs_crop_i(d_char *str, int start, int end); | 72 | xs_str *xs_crop_i(xs_str *str, int start, int end); |
| 66 | d_char *xs_strip_chars_i(d_char *str, const char *chars); | 73 | xs_str *xs_strip_chars_i(xs_str *str, const char *chars); |
| 67 | #define xs_strip_i(str) xs_strip_chars_i(str, " \r\n\t\v\f") | 74 | #define xs_strip_i(str) xs_strip_chars_i(str, " \r\n\t\v\f") |
| 68 | d_char *xs_tolower_i(d_char *str); | 75 | xs_str *xs_tolower_i(xs_str *str); |
| 69 | d_char *xs_list_new(void); | 76 | |
| 70 | d_char *xs_list_append_m(d_char *list, const char *mem, int dsz); | 77 | xs_list *xs_list_new(void); |
| 78 | xs_list *xs_list_append_m(xs_list *list, const char *mem, int dsz); | ||
| 71 | #define xs_list_append(list, data) xs_list_append_m(list, data, xs_size(data)) | 79 | #define xs_list_append(list, data) xs_list_append_m(list, data, xs_size(data)) |
| 72 | int xs_list_iter(char **list, char **value); | 80 | int xs_list_iter(xs_list **list, xs_val **value); |
| 73 | int xs_list_len(char *list); | 81 | int xs_list_len(xs_list *list); |
| 74 | char *xs_list_get(char *list, int num); | 82 | char *xs_list_get(xs_list *list, int num); |
| 75 | d_char *xs_list_del(d_char *list, int num); | 83 | xs_list *xs_list_del(xs_list *list, int num); |
| 76 | d_char *xs_list_insert(d_char *list, int num, const char *data); | 84 | xs_list *xs_list_insert(xs_list *list, int num, const xs_val *data); |
| 77 | d_char *xs_list_insert_sorted(d_char *list, const char *str); | 85 | xs_list *xs_list_insert_sorted(xs_list *list, const char *str); |
| 78 | d_char *xs_list_set(d_char *list, int num, const char *data); | 86 | xs_list *xs_list_set(xs_list *list, int num, const xs_val *data); |
| 79 | d_char *xs_list_dequeue(d_char *list, char **data, int last); | 87 | xs_list *xs_list_dequeue(xs_list *list, xs_val **data, int last); |
| 80 | #define xs_list_pop(list, data) xs_list_dequeue(list, data, 1) | 88 | #define xs_list_pop(list, data) xs_list_dequeue(list, data, 1) |
| 81 | #define xs_list_shift(list, data) xs_list_dequeue(list, data, 0) | 89 | #define xs_list_shift(list, data) xs_list_dequeue(list, data, 0) |
| 82 | int xs_list_in(char *list, const char *val); | 90 | int xs_list_in(xs_list *list, const xs_val *val); |
| 83 | d_char *xs_join(char *list, const char *sep); | 91 | xs_str *xs_join(xs_list *list, const char *sep); |
| 84 | d_char *xs_split_n(const char *str, const char *sep, int times); | 92 | xs_list *xs_split_n(const char *str, const char *sep, int times); |
| 85 | #define xs_split(str, sep) xs_split_n(str, sep, XS_ALL) | 93 | #define xs_split(str, sep) xs_split_n(str, sep, XS_ALL) |
| 86 | d_char *xs_dict_new(void); | 94 | |
| 87 | d_char *xs_dict_append_m(d_char *dict, const char *key, const char *mem, int dsz); | 95 | xs_dict *xs_dict_new(void); |
| 96 | xs_dict *xs_dict_append_m(xs_dict *dict, const xs_str *key, const xs_val *mem, int dsz); | ||
| 88 | #define xs_dict_append(dict, key, data) xs_dict_append_m(dict, key, data, xs_size(data)) | 97 | #define xs_dict_append(dict, key, data) xs_dict_append_m(dict, key, data, xs_size(data)) |
| 89 | int xs_dict_iter(char **dict, char **key, char **value); | 98 | int xs_dict_iter(xs_dict **dict, xs_str **key, xs_val **value); |
| 90 | char *xs_dict_get(char *dict, const char *key); | 99 | xs_dict *xs_dict_get(xs_dict *dict, const xs_str *key); |
| 91 | d_char *xs_dict_del(d_char *dict, const char *key); | 100 | xs_dict *xs_dict_del(xs_dict *dict, const xs_str *key); |
| 92 | d_char *xs_dict_set(d_char *dict, const char *key, const char *data); | 101 | xs_dict *xs_dict_set(xs_dict *dict, const xs_str *key, const xs_val *data); |
| 93 | d_char *xs_val_new(xstype t); | 102 | |
| 94 | d_char *xs_number_new(double f); | 103 | xs_val *xs_val_new(xstype t); |
| 95 | double xs_number_get(const char *v); | 104 | xs_number *xs_number_new(double f); |
| 96 | const char *xs_number_str(const char *v); | 105 | double xs_number_get(const xs_number *v); |
| 106 | const char *xs_number_str(const xs_number *v); | ||
| 97 | 107 | ||
| 98 | void *xs_memmem(const char *haystack, int h_size, const char *needle, int n_size); | 108 | void *xs_memmem(const char *haystack, int h_size, const char *needle, int n_size); |
| 99 | 109 | ||
| 110 | |||
| 111 | #ifdef XS_ASSERT | ||
| 112 | #include <assert.h> | ||
| 113 | #define XS_ASSERT_TYPE(v, t) assert(xs_type(v) == t) | ||
| 114 | #define XS_ASSERT_TYPE_NULL(v, t) assert(v == NULL || xs_type(v) == t) | ||
| 115 | #else | ||
| 116 | #define XS_ASSERT_TYPE(v, t) (void)(0) | ||
| 117 | #define XS_ASSERT_TYPE_NULL(v, t) (void)(0) | ||
| 118 | #endif | ||
| 119 | |||
| 120 | |||
| 100 | #ifdef XS_IMPLEMENTATION | 121 | #ifdef XS_IMPLEMENTATION |
| 101 | 122 | ||
| 102 | void *_xs_realloc(void *ptr, size_t size, const char *file, int line, const char *func) | 123 | void *_xs_realloc(void *ptr, size_t size, const char *file, int line, const char *func) |
| @@ -183,22 +204,24 @@ int _xs_blk_size(int sz) | |||
| 183 | } | 204 | } |
| 184 | 205 | ||
| 185 | 206 | ||
| 186 | xstype xs_type(const char *data) | 207 | xstype xs_type(const xs_val *data) |
| 187 | /* return the type of data */ | 208 | /* return the type of data */ |
| 188 | { | 209 | { |
| 189 | xstype t; | 210 | xstype t; |
| 190 | 211 | ||
| 212 | if (data == NULL) | ||
| 213 | t = XSTYPE_NULL; | ||
| 214 | else | ||
| 191 | switch (data[0]) { | 215 | switch (data[0]) { |
| 192 | case XSTYPE_NULL: | 216 | case XSTYPE_NULL: |
| 193 | case XSTYPE_TRUE: | 217 | case XSTYPE_TRUE: |
| 194 | case XSTYPE_FALSE: | 218 | case XSTYPE_FALSE: |
| 195 | case XSTYPE_LIST: | 219 | case XSTYPE_LIST: |
| 196 | case XSTYPE_EOL: | ||
| 197 | case XSTYPE_DICT: | ||
| 198 | case XSTYPE_EOD: | ||
| 199 | case XSTYPE_LITEM: | 220 | case XSTYPE_LITEM: |
| 221 | case XSTYPE_DICT: | ||
| 200 | case XSTYPE_DITEM: | 222 | case XSTYPE_DITEM: |
| 201 | case XSTYPE_NUMBER: | 223 | case XSTYPE_NUMBER: |
| 224 | case XSTYPE_EOM: | ||
| 202 | t = data[0]; | 225 | t = data[0]; |
| 203 | break; | 226 | break; |
| 204 | default: | 227 | default: |
| @@ -210,7 +233,7 @@ xstype xs_type(const char *data) | |||
| 210 | } | 233 | } |
| 211 | 234 | ||
| 212 | 235 | ||
| 213 | void _xs_put_24b(char *ptr, int i) | 236 | void _xs_put_24b(xs_val *ptr, int i) |
| 214 | /* writes i as a 24 bit value */ | 237 | /* writes i as a 24 bit value */ |
| 215 | { | 238 | { |
| 216 | unsigned char *p = (unsigned char *)ptr; | 239 | unsigned char *p = (unsigned char *)ptr; |
| @@ -221,7 +244,7 @@ void _xs_put_24b(char *ptr, int i) | |||
| 221 | } | 244 | } |
| 222 | 245 | ||
| 223 | 246 | ||
| 224 | int _xs_get_24b(const char *ptr) | 247 | int _xs_get_24b(const xs_val *ptr) |
| 225 | /* reads a 24 bit value */ | 248 | /* reads a 24 bit value */ |
| 226 | { | 249 | { |
| 227 | unsigned char *p = (unsigned char *)ptr; | 250 | unsigned char *p = (unsigned char *)ptr; |
| @@ -230,7 +253,7 @@ int _xs_get_24b(const char *ptr) | |||
| 230 | } | 253 | } |
| 231 | 254 | ||
| 232 | 255 | ||
| 233 | int xs_size(const char *data) | 256 | int xs_size(const xs_val *data) |
| 234 | /* returns the size of data in bytes */ | 257 | /* returns the size of data in bytes */ |
| 235 | { | 258 | { |
| 236 | int len = 0; | 259 | int len = 0; |
| @@ -286,18 +309,18 @@ int xs_size(const char *data) | |||
| 286 | } | 309 | } |
| 287 | 310 | ||
| 288 | 311 | ||
| 289 | int xs_is_null(const char *data) | 312 | int xs_is_null(const xs_val *data) |
| 290 | /* checks for null */ | 313 | /* checks for null */ |
| 291 | { | 314 | { |
| 292 | return !!(data == NULL || xs_type(data) == XSTYPE_NULL); | 315 | return (xs_type(data) == XSTYPE_NULL); |
| 293 | } | 316 | } |
| 294 | 317 | ||
| 295 | 318 | ||
| 296 | d_char *xs_dup(const char *data) | 319 | xs_val *xs_dup(const xs_val *data) |
| 297 | /* creates a duplicate of data */ | 320 | /* creates a duplicate of data */ |
| 298 | { | 321 | { |
| 299 | int sz = xs_size(data); | 322 | int sz = xs_size(data); |
| 300 | d_char *s = xs_realloc(NULL, _xs_blk_size(sz)); | 323 | xs_val *s = xs_realloc(NULL, _xs_blk_size(sz)); |
| 301 | 324 | ||
| 302 | memcpy(s, data, sz); | 325 | memcpy(s, data, sz); |
| 303 | 326 | ||
| @@ -305,7 +328,7 @@ d_char *xs_dup(const char *data) | |||
| 305 | } | 328 | } |
| 306 | 329 | ||
| 307 | 330 | ||
| 308 | d_char *xs_expand(d_char *data, int offset, int size) | 331 | xs_val *xs_expand(xs_val *data, int offset, int size) |
| 309 | /* opens a hole in data */ | 332 | /* opens a hole in data */ |
| 310 | { | 333 | { |
| 311 | int sz = xs_size(data); | 334 | int sz = xs_size(data); |
| @@ -325,7 +348,7 @@ d_char *xs_expand(d_char *data, int offset, int size) | |||
| 325 | } | 348 | } |
| 326 | 349 | ||
| 327 | 350 | ||
| 328 | d_char *xs_collapse(d_char *data, int offset, int size) | 351 | xs_val *xs_collapse(xs_val *data, int offset, int size) |
| 329 | /* shrinks data */ | 352 | /* shrinks data */ |
| 330 | { | 353 | { |
| 331 | int sz = xs_size(data); | 354 | int sz = xs_size(data); |
| @@ -348,7 +371,7 @@ d_char *xs_collapse(d_char *data, int offset, int size) | |||
| 348 | } | 371 | } |
| 349 | 372 | ||
| 350 | 373 | ||
| 351 | d_char *xs_insert_m(d_char *data, int offset, const char *mem, int size) | 374 | xs_val *xs_insert_m(xs_val *data, int offset, const char *mem, int size) |
| 352 | /* inserts a memory block */ | 375 | /* inserts a memory block */ |
| 353 | { | 376 | { |
| 354 | data = xs_expand(data, offset, size); | 377 | data = xs_expand(data, offset, size); |
| @@ -360,16 +383,18 @@ d_char *xs_insert_m(d_char *data, int offset, const char *mem, int size) | |||
| 360 | 383 | ||
| 361 | /** strings **/ | 384 | /** strings **/ |
| 362 | 385 | ||
| 363 | d_char *xs_str_new(const char *str) | 386 | xs_str *xs_str_new(const char *str) |
| 364 | /* creates a new string */ | 387 | /* creates a new string */ |
| 365 | { | 388 | { |
| 366 | return xs_insert(NULL, 0, str ? str : ""); | 389 | return xs_insert(NULL, 0, str ? str : ""); |
| 367 | } | 390 | } |
| 368 | 391 | ||
| 369 | 392 | ||
| 370 | d_char *xs_str_wrap_i(const char *prefix, d_char *str, const char *suffix) | 393 | xs_str *xs_str_wrap_i(const char *prefix, xs_str *str, const char *suffix) |
| 371 | /* wraps str with prefix and suffix */ | 394 | /* wraps str with prefix and suffix */ |
| 372 | { | 395 | { |
| 396 | XS_ASSERT_TYPE(str, XSTYPE_STRING); | ||
| 397 | |||
| 373 | if (prefix) | 398 | if (prefix) |
| 374 | str = xs_insert_m(str, 0, prefix, strlen(prefix)); | 399 | str = xs_insert_m(str, 0, prefix, strlen(prefix)); |
| 375 | 400 | ||
| @@ -380,9 +405,11 @@ d_char *xs_str_wrap_i(const char *prefix, d_char *str, const char *suffix) | |||
| 380 | } | 405 | } |
| 381 | 406 | ||
| 382 | 407 | ||
| 383 | d_char *xs_replace_i(d_char *str, const char *sfrom, const char *sto) | 408 | xs_str *xs_replace_i(xs_str *str, const char *sfrom, const char *sto) |
| 384 | /* replaces inline all sfrom with sto */ | 409 | /* replaces inline all sfrom with sto */ |
| 385 | { | 410 | { |
| 411 | XS_ASSERT_TYPE(str, XSTYPE_STRING); | ||
| 412 | |||
| 386 | int sfsz = strlen(sfrom); | 413 | int sfsz = strlen(sfrom); |
| 387 | int stsz = strlen(sto); | 414 | int stsz = strlen(sto); |
| 388 | char *ss; | 415 | char *ss; |
| @@ -402,11 +429,11 @@ d_char *xs_replace_i(d_char *str, const char *sfrom, const char *sto) | |||
| 402 | } | 429 | } |
| 403 | 430 | ||
| 404 | 431 | ||
| 405 | d_char *xs_fmt(const char *fmt, ...) | 432 | xs_str *xs_fmt(const char *fmt, ...) |
| 406 | /* formats a string with printf()-like marks */ | 433 | /* formats a string with printf()-like marks */ |
| 407 | { | 434 | { |
| 408 | int n; | 435 | int n; |
| 409 | d_char *s = NULL; | 436 | xs_str *s = NULL; |
| 410 | va_list ap; | 437 | va_list ap; |
| 411 | 438 | ||
| 412 | va_start(ap, fmt); | 439 | va_start(ap, fmt); |
| @@ -455,9 +482,11 @@ int xs_endswith(const char *str, const char *postfix) | |||
| 455 | } | 482 | } |
| 456 | 483 | ||
| 457 | 484 | ||
| 458 | d_char *xs_crop_i(d_char *str, int start, int end) | 485 | xs_str *xs_crop_i(xs_str *str, int start, int end) |
| 459 | /* crops the d_char to be only from start to end */ | 486 | /* crops the d_char to be only from start to end */ |
| 460 | { | 487 | { |
| 488 | XS_ASSERT_TYPE(str, XSTYPE_STRING); | ||
| 489 | |||
| 461 | int sz = strlen(str); | 490 | int sz = strlen(str); |
| 462 | 491 | ||
| 463 | if (end <= 0) | 492 | if (end <= 0) |
| @@ -473,9 +502,11 @@ d_char *xs_crop_i(d_char *str, int start, int end) | |||
| 473 | } | 502 | } |
| 474 | 503 | ||
| 475 | 504 | ||
| 476 | d_char *xs_strip_chars_i(d_char *str, const char *chars) | 505 | xs_str *xs_strip_chars_i(xs_str *str, const char *chars) |
| 477 | /* strips the string of chars from the start and the end */ | 506 | /* strips the string of chars from the start and the end */ |
| 478 | { | 507 | { |
| 508 | XS_ASSERT_TYPE(str, XSTYPE_STRING); | ||
| 509 | |||
| 479 | int n; | 510 | int n; |
| 480 | 511 | ||
| 481 | /* strip first from the end */ | 512 | /* strip first from the end */ |
| @@ -494,9 +525,11 @@ d_char *xs_strip_chars_i(d_char *str, const char *chars) | |||
| 494 | } | 525 | } |
| 495 | 526 | ||
| 496 | 527 | ||
| 497 | d_char *xs_tolower_i(d_char *str) | 528 | xs_str *xs_tolower_i(xs_str *str) |
| 498 | /* convert to lowercase */ | 529 | /* convert to lowercase */ |
| 499 | { | 530 | { |
| 531 | XS_ASSERT_TYPE(str, XSTYPE_STRING); | ||
| 532 | |||
| 500 | int n; | 533 | int n; |
| 501 | 534 | ||
| 502 | for (n = 0; str[n]; n++) | 535 | for (n = 0; str[n]; n++) |
| @@ -508,14 +541,14 @@ d_char *xs_tolower_i(d_char *str) | |||
| 508 | 541 | ||
| 509 | /** lists **/ | 542 | /** lists **/ |
| 510 | 543 | ||
| 511 | d_char *xs_list_new(void) | 544 | xs_list *xs_list_new(void) |
| 512 | /* creates a new list */ | 545 | /* creates a new list */ |
| 513 | { | 546 | { |
| 514 | d_char *list; | 547 | xs_list *list; |
| 515 | 548 | ||
| 516 | list = xs_realloc(NULL, _xs_blk_size(5)); | 549 | list = xs_realloc(NULL, _xs_blk_size(5)); |
| 517 | list[0] = XSTYPE_LIST; | 550 | list[0] = XSTYPE_LIST; |
| 518 | list[4] = XSTYPE_EOL; | 551 | list[4] = XSTYPE_EOM; |
| 519 | 552 | ||
| 520 | _xs_put_24b(list + 1, 5); | 553 | _xs_put_24b(list + 1, 5); |
| 521 | 554 | ||
| @@ -523,9 +556,11 @@ d_char *xs_list_new(void) | |||
| 523 | } | 556 | } |
| 524 | 557 | ||
| 525 | 558 | ||
| 526 | d_char *_xs_list_write_litem(d_char *list, int offset, const char *mem, int dsz) | 559 | xs_list *_xs_list_write_litem(xs_list *list, int offset, const char *mem, int dsz) |
| 527 | /* writes a list item */ | 560 | /* writes a list item */ |
| 528 | { | 561 | { |
| 562 | XS_ASSERT_TYPE(list, XSTYPE_LIST); | ||
| 563 | |||
| 529 | char c = XSTYPE_LITEM; | 564 | char c = XSTYPE_LITEM; |
| 530 | 565 | ||
| 531 | list = xs_insert_m(list, offset, &c, 1); | 566 | list = xs_insert_m(list, offset, &c, 1); |
| @@ -535,30 +570,28 @@ d_char *_xs_list_write_litem(d_char *list, int offset, const char *mem, int dsz) | |||
| 535 | } | 570 | } |
| 536 | 571 | ||
| 537 | 572 | ||
| 538 | d_char *xs_list_append_m(d_char *list, const char *mem, int dsz) | 573 | xs_list *xs_list_append_m(xs_list *list, const char *mem, int dsz) |
| 539 | /* adds a memory block to the list */ | 574 | /* adds a memory block to the list */ |
| 540 | { | 575 | { |
| 576 | XS_ASSERT_TYPE(list, XSTYPE_LIST); | ||
| 577 | |||
| 541 | return _xs_list_write_litem(list, xs_size(list) - 1, mem, dsz); | 578 | return _xs_list_write_litem(list, xs_size(list) - 1, mem, dsz); |
| 542 | } | 579 | } |
| 543 | 580 | ||
| 544 | 581 | ||
| 545 | int xs_list_iter(char **list, char **value) | 582 | int xs_list_iter(xs_list **list, xs_val **value) |
| 546 | /* iterates a list value */ | 583 | /* iterates a list value */ |
| 547 | { | 584 | { |
| 548 | int goon = 1; | 585 | int goon = 1; |
| 549 | char *p; | ||
| 550 | |||
| 551 | if (list == NULL || *list == NULL) | ||
| 552 | return 0; | ||
| 553 | 586 | ||
| 554 | p = *list; | 587 | xs_val *p = *list; |
| 555 | 588 | ||
| 556 | /* skip the start of the list */ | 589 | /* skip the start of the list */ |
| 557 | if (*p == XSTYPE_LIST) | 590 | if (xs_type(p) == XSTYPE_LIST) |
| 558 | p += 4; | 591 | p += 4; |
| 559 | 592 | ||
| 560 | /* an element? */ | 593 | /* an element? */ |
| 561 | if (*p == XSTYPE_LITEM) { | 594 | if (xs_type(p) == XSTYPE_LITEM) { |
| 562 | p++; | 595 | p++; |
| 563 | 596 | ||
| 564 | *value = p; | 597 | *value = p; |
| @@ -567,7 +600,6 @@ int xs_list_iter(char **list, char **value) | |||
| 567 | } | 600 | } |
| 568 | else { | 601 | else { |
| 569 | /* end of list */ | 602 | /* end of list */ |
| 570 | p++; | ||
| 571 | goon = 0; | 603 | goon = 0; |
| 572 | } | 604 | } |
| 573 | 605 | ||
| @@ -578,11 +610,13 @@ int xs_list_iter(char **list, char **value) | |||
| 578 | } | 610 | } |
| 579 | 611 | ||
| 580 | 612 | ||
| 581 | int xs_list_len(char *list) | 613 | int xs_list_len(xs_list *list) |
| 582 | /* returns the number of elements in the list */ | 614 | /* returns the number of elements in the list */ |
| 583 | { | 615 | { |
| 616 | XS_ASSERT_TYPE_NULL(list, XSTYPE_LIST); | ||
| 617 | |||
| 584 | int c = 0; | 618 | int c = 0; |
| 585 | char *v; | 619 | xs_val *v; |
| 586 | 620 | ||
| 587 | while (xs_list_iter(&list, &v)) | 621 | while (xs_list_iter(&list, &v)) |
| 588 | c++; | 622 | c++; |
| @@ -591,11 +625,13 @@ int xs_list_len(char *list) | |||
| 591 | } | 625 | } |
| 592 | 626 | ||
| 593 | 627 | ||
| 594 | char *xs_list_get(char *list, int num) | 628 | xs_val *xs_list_get(xs_list *list, int num) |
| 595 | /* returns the element #num */ | 629 | /* returns the element #num */ |
| 596 | { | 630 | { |
| 597 | char *v; | 631 | XS_ASSERT_TYPE(list, XSTYPE_LIST); |
| 632 | |||
| 598 | int c = 0; | 633 | int c = 0; |
| 634 | xs_val *v; | ||
| 599 | 635 | ||
| 600 | if (num < 0) | 636 | if (num < 0) |
| 601 | num = xs_list_len(list) + num; | 637 | num = xs_list_len(list) + num; |
| @@ -611,10 +647,12 @@ char *xs_list_get(char *list, int num) | |||
| 611 | } | 647 | } |
| 612 | 648 | ||
| 613 | 649 | ||
| 614 | d_char *xs_list_del(d_char *list, int num) | 650 | xs_list *xs_list_del(xs_list *list, int num) |
| 615 | /* deletes element #num */ | 651 | /* deletes element #num */ |
| 616 | { | 652 | { |
| 617 | char *v; | 653 | XS_ASSERT_TYPE(list, XSTYPE_LIST); |
| 654 | |||
| 655 | xs_val *v; | ||
| 618 | 656 | ||
| 619 | if ((v = xs_list_get(list, num)) != NULL) | 657 | if ((v = xs_list_get(list, num)) != NULL) |
| 620 | list = xs_collapse(list, v - 1 - list, xs_size(v - 1)); | 658 | list = xs_collapse(list, v - 1 - list, xs_size(v - 1)); |
| @@ -623,10 +661,12 @@ d_char *xs_list_del(d_char *list, int num) | |||
| 623 | } | 661 | } |
| 624 | 662 | ||
| 625 | 663 | ||
| 626 | d_char *xs_list_insert(d_char *list, int num, const char *data) | 664 | xs_list *xs_list_insert(xs_list *list, int num, const xs_val *data) |
| 627 | /* inserts an element at #num position */ | 665 | /* inserts an element at #num position */ |
| 628 | { | 666 | { |
| 629 | char *v; | 667 | XS_ASSERT_TYPE(list, XSTYPE_LIST); |
| 668 | |||
| 669 | xs_val *v; | ||
| 630 | int offset; | 670 | int offset; |
| 631 | 671 | ||
| 632 | if ((v = xs_list_get(list, num)) != NULL) | 672 | if ((v = xs_list_get(list, num)) != NULL) |
| @@ -638,9 +678,12 @@ d_char *xs_list_insert(d_char *list, int num, const char *data) | |||
| 638 | } | 678 | } |
| 639 | 679 | ||
| 640 | 680 | ||
| 641 | d_char *xs_list_insert_sorted(d_char *list, const char *str) | 681 | xs_list *xs_list_insert_sorted(xs_list *list, const xs_str *str) |
| 642 | /* inserts a string in the list in its ordered position */ | 682 | /* inserts a string in the list in its ordered position */ |
| 643 | { | 683 | { |
| 684 | XS_ASSERT_TYPE(list, XSTYPE_LIST); | ||
| 685 | XS_ASSERT_TYPE(str, XSTYPE_STRING); | ||
| 686 | |||
| 644 | char *p, *v; | 687 | char *p, *v; |
| 645 | int offset = xs_size(list); | 688 | int offset = xs_size(list); |
| 646 | 689 | ||
| @@ -657,9 +700,11 @@ d_char *xs_list_insert_sorted(d_char *list, const char *str) | |||
| 657 | } | 700 | } |
| 658 | 701 | ||
| 659 | 702 | ||
| 660 | d_char *xs_list_set(d_char *list, int num, const char *data) | 703 | xs_list *xs_list_set(xs_list *list, int num, const xs_val *data) |
| 661 | /* sets the element at #num position */ | 704 | /* sets the element at #num position */ |
| 662 | { | 705 | { |
| 706 | XS_ASSERT_TYPE(list, XSTYPE_LIST); | ||
| 707 | |||
| 663 | list = xs_list_del(list, num); | 708 | list = xs_list_del(list, num); |
| 664 | list = xs_list_insert(list, num, data); | 709 | list = xs_list_insert(list, num, data); |
| 665 | 710 | ||
| @@ -667,10 +712,13 @@ d_char *xs_list_set(d_char *list, int num, const char *data) | |||
| 667 | } | 712 | } |
| 668 | 713 | ||
| 669 | 714 | ||
| 670 | d_char *xs_list_dequeue(d_char *list, char **data, int last) | 715 | xs_list *xs_list_dequeue(xs_list *list, xs_val **data, int last) |
| 671 | /* gets a copy of the first or last element of a list, shrinking it */ | 716 | /* gets a copy of the first or last element of a list, shrinking it */ |
| 672 | { | 717 | { |
| 673 | char *p = list, *v = NULL; | 718 | XS_ASSERT_TYPE(list, XSTYPE_LIST); |
| 719 | |||
| 720 | xs_list *p = list; | ||
| 721 | xs_val *v = NULL; | ||
| 674 | 722 | ||
| 675 | if (!last) { | 723 | if (!last) { |
| 676 | /* get the first */ | 724 | /* get the first */ |
| @@ -692,11 +740,13 @@ d_char *xs_list_dequeue(d_char *list, char **data, int last) | |||
| 692 | } | 740 | } |
| 693 | 741 | ||
| 694 | 742 | ||
| 695 | int xs_list_in(char *list, const char *val) | 743 | int xs_list_in(xs_list *list, const xs_val *val) |
| 696 | /* returns the position of val in list or -1 */ | 744 | /* returns the position of val in list or -1 */ |
| 697 | { | 745 | { |
| 746 | XS_ASSERT_TYPE_NULL(list, XSTYPE_LIST); | ||
| 747 | |||
| 698 | int n = 0; | 748 | int n = 0; |
| 699 | char *v; | 749 | xs_val *v; |
| 700 | int sz = xs_size(val); | 750 | int sz = xs_size(val); |
| 701 | 751 | ||
| 702 | while (xs_list_iter(&list, &v)) { | 752 | while (xs_list_iter(&list, &v)) { |
| @@ -710,11 +760,13 @@ int xs_list_in(char *list, const char *val) | |||
| 710 | } | 760 | } |
| 711 | 761 | ||
| 712 | 762 | ||
| 713 | d_char *xs_join(char *list, const char *sep) | 763 | xs_str *xs_join(xs_list *list, const char *sep) |
| 714 | /* joins a list into a string */ | 764 | /* joins a list into a string */ |
| 715 | { | 765 | { |
| 716 | d_char *s = NULL; | 766 | XS_ASSERT_TYPE(list, XSTYPE_LIST); |
| 717 | char *v; | 767 | |
| 768 | xs_str *s = NULL; | ||
| 769 | xs_val *v; | ||
| 718 | int c = 0; | 770 | int c = 0; |
| 719 | int offset = 0; | 771 | int offset = 0; |
| 720 | int ssz = strlen(sep); | 772 | int ssz = strlen(sep); |
| @@ -749,12 +801,12 @@ d_char *xs_join(char *list, const char *sep) | |||
| 749 | } | 801 | } |
| 750 | 802 | ||
| 751 | 803 | ||
| 752 | d_char *xs_split_n(const char *str, const char *sep, int times) | 804 | xs_list *xs_split_n(const char *str, const char *sep, int times) |
| 753 | /* splits a string into a list upto n times */ | 805 | /* splits a string into a list upto n times */ |
| 754 | { | 806 | { |
| 755 | int sz = strlen(sep); | 807 | int sz = strlen(sep); |
| 756 | char *ss; | 808 | char *ss; |
| 757 | d_char *list; | 809 | xs_list *list; |
| 758 | 810 | ||
| 759 | list = xs_list_new(); | 811 | list = xs_list_new(); |
| 760 | 812 | ||
| @@ -763,7 +815,7 @@ d_char *xs_split_n(const char *str, const char *sep, int times) | |||
| 763 | list = xs_list_append_m(list, str, ss - str); | 815 | list = xs_list_append_m(list, str, ss - str); |
| 764 | 816 | ||
| 765 | /* add the asciiz */ | 817 | /* add the asciiz */ |
| 766 | list = xs_str_cat(list, ""); | 818 | list = xs_insert_m(list, xs_size(list) - 1, "", 1); |
| 767 | 819 | ||
| 768 | /* skip past the separator */ | 820 | /* skip past the separator */ |
| 769 | str = ss + sz; | 821 | str = ss + sz; |
| @@ -780,14 +832,14 @@ d_char *xs_split_n(const char *str, const char *sep, int times) | |||
| 780 | 832 | ||
| 781 | /** dicts **/ | 833 | /** dicts **/ |
| 782 | 834 | ||
| 783 | d_char *xs_dict_new(void) | 835 | xs_dict *xs_dict_new(void) |
| 784 | /* creates a new dict */ | 836 | /* creates a new dict */ |
| 785 | { | 837 | { |
| 786 | d_char *dict; | 838 | xs_dict *dict; |
| 787 | 839 | ||
| 788 | dict = xs_realloc(NULL, _xs_blk_size(5)); | 840 | dict = xs_realloc(NULL, _xs_blk_size(5)); |
| 789 | dict[0] = XSTYPE_DICT; | 841 | dict[0] = XSTYPE_DICT; |
| 790 | dict[4] = XSTYPE_EOD; | 842 | dict[4] = XSTYPE_EOM; |
| 791 | 843 | ||
| 792 | _xs_put_24b(dict + 1, 5); | 844 | _xs_put_24b(dict + 1, 5); |
| 793 | 845 | ||
| @@ -795,9 +847,12 @@ d_char *xs_dict_new(void) | |||
| 795 | } | 847 | } |
| 796 | 848 | ||
| 797 | 849 | ||
| 798 | d_char *xs_dict_append_m(d_char *dict, const char *key, const char *mem, int dsz) | 850 | xs_dict *xs_dict_append_m(xs_dict *dict, const xs_str *key, const xs_val *mem, int dsz) |
| 799 | /* adds a memory block to the dict */ | 851 | /* adds a memory block to the dict */ |
| 800 | { | 852 | { |
| 853 | XS_ASSERT_TYPE(dict, XSTYPE_DICT); | ||
| 854 | XS_ASSERT_TYPE(key, XSTYPE_STRING); | ||
| 855 | |||
| 801 | char c = XSTYPE_DITEM; | 856 | char c = XSTYPE_DITEM; |
| 802 | int sz = xs_size(dict); | 857 | int sz = xs_size(dict); |
| 803 | int ksz = xs_size(key); | 858 | int ksz = xs_size(key); |
| @@ -810,23 +865,19 @@ d_char *xs_dict_append_m(d_char *dict, const char *key, const char *mem, int dsz | |||
| 810 | } | 865 | } |
| 811 | 866 | ||
| 812 | 867 | ||
| 813 | int xs_dict_iter(char **dict, char **key, char **value) | 868 | int xs_dict_iter(xs_dict **dict, xs_str **key, xs_val **value) |
| 814 | /* iterates a dict value */ | 869 | /* iterates a dict value */ |
| 815 | { | 870 | { |
| 816 | int goon = 1; | 871 | int goon = 1; |
| 817 | char *p; | ||
| 818 | |||
| 819 | if (dict == NULL || *dict == NULL) | ||
| 820 | return 0; | ||
| 821 | 872 | ||
| 822 | p = *dict; | 873 | xs_val *p = *dict; |
| 823 | 874 | ||
| 824 | /* skip the start of the list */ | 875 | /* skip the start of the list */ |
| 825 | if (*p == XSTYPE_DICT) | 876 | if (xs_type(p) == XSTYPE_DICT) |
| 826 | p += 4; | 877 | p += 4; |
| 827 | 878 | ||
| 828 | /* an element? */ | 879 | /* an element? */ |
| 829 | if (*p == XSTYPE_DITEM) { | 880 | if (xs_type(p) == XSTYPE_DITEM) { |
| 830 | p++; | 881 | p++; |
| 831 | 882 | ||
| 832 | *key = p; | 883 | *key = p; |
| @@ -837,7 +888,6 @@ int xs_dict_iter(char **dict, char **key, char **value) | |||
| 837 | } | 888 | } |
| 838 | else { | 889 | else { |
| 839 | /* end of list */ | 890 | /* end of list */ |
| 840 | p++; | ||
| 841 | goon = 0; | 891 | goon = 0; |
| 842 | } | 892 | } |
| 843 | 893 | ||
| @@ -848,10 +898,14 @@ int xs_dict_iter(char **dict, char **key, char **value) | |||
| 848 | } | 898 | } |
| 849 | 899 | ||
| 850 | 900 | ||
| 851 | char *xs_dict_get(char *dict, const char *key) | 901 | xs_val *xs_dict_get(xs_dict *dict, const xs_str *key) |
| 852 | /* returns the value directed by key */ | 902 | /* returns the value directed by key */ |
| 853 | { | 903 | { |
| 854 | char *k, *v; | 904 | XS_ASSERT_TYPE(dict, XSTYPE_DICT); |
| 905 | XS_ASSERT_TYPE(key, XSTYPE_STRING); | ||
| 906 | |||
| 907 | xs_str *k; | ||
| 908 | xs_val *v; | ||
| 855 | 909 | ||
| 856 | while (xs_dict_iter(&dict, &k, &v)) { | 910 | while (xs_dict_iter(&dict, &k, &v)) { |
| 857 | if (strcmp(k, key) == 0) | 911 | if (strcmp(k, key) == 0) |
| @@ -862,11 +916,15 @@ char *xs_dict_get(char *dict, const char *key) | |||
| 862 | } | 916 | } |
| 863 | 917 | ||
| 864 | 918 | ||
| 865 | d_char *xs_dict_del(d_char *dict, const char *key) | 919 | xs_dict *xs_dict_del(xs_dict *dict, const xs_str *key) |
| 866 | /* deletes a key */ | 920 | /* deletes a key */ |
| 867 | { | 921 | { |
| 868 | char *k, *v; | 922 | XS_ASSERT_TYPE(dict, XSTYPE_DICT); |
| 869 | char *p = dict; | 923 | XS_ASSERT_TYPE(key, XSTYPE_STRING); |
| 924 | |||
| 925 | xs_str *k; | ||
| 926 | xs_val *v; | ||
| 927 | xs_dict *p = dict; | ||
| 870 | 928 | ||
| 871 | while (xs_dict_iter(&p, &k, &v)) { | 929 | while (xs_dict_iter(&p, &k, &v)) { |
| 872 | if (strcmp(k, key) == 0) { | 930 | if (strcmp(k, key) == 0) { |
| @@ -882,9 +940,12 @@ d_char *xs_dict_del(d_char *dict, const char *key) | |||
| 882 | } | 940 | } |
| 883 | 941 | ||
| 884 | 942 | ||
| 885 | d_char *xs_dict_set(d_char *dict, const char *key, const char *data) | 943 | xs_dict *xs_dict_set(xs_dict *dict, const xs_str *key, const xs_val *data) |
| 886 | /* sets (replaces) a key */ | 944 | /* sets (replaces) a key */ |
| 887 | { | 945 | { |
| 946 | XS_ASSERT_TYPE(dict, XSTYPE_DICT); | ||
| 947 | XS_ASSERT_TYPE(key, XSTYPE_STRING); | ||
| 948 | |||
| 888 | /* delete the possibly existing key */ | 949 | /* delete the possibly existing key */ |
| 889 | dict = xs_dict_del(dict, key); | 950 | dict = xs_dict_del(dict, key); |
| 890 | 951 | ||
| @@ -897,10 +958,10 @@ d_char *xs_dict_set(d_char *dict, const char *key, const char *data) | |||
| 897 | 958 | ||
| 898 | /** other values **/ | 959 | /** other values **/ |
| 899 | 960 | ||
| 900 | d_char *xs_val_new(xstype t) | 961 | xs_val *xs_val_new(xstype t) |
| 901 | /* adds a new special value */ | 962 | /* adds a new special value */ |
| 902 | { | 963 | { |
| 903 | d_char *v = xs_realloc(NULL, _xs_blk_size(1)); | 964 | xs_val *v = xs_realloc(NULL, _xs_blk_size(1)); |
| 904 | 965 | ||
| 905 | v[0] = t; | 966 | v[0] = t; |
| 906 | 967 | ||
| @@ -910,10 +971,10 @@ d_char *xs_val_new(xstype t) | |||
| 910 | 971 | ||
| 911 | /** numbers */ | 972 | /** numbers */ |
| 912 | 973 | ||
| 913 | d_char *xs_number_new(double f) | 974 | xs_number *xs_number_new(double f) |
| 914 | /* adds a new number value */ | 975 | /* adds a new number value */ |
| 915 | { | 976 | { |
| 916 | d_char *v; | 977 | xs_number *v; |
| 917 | char tmp[64]; | 978 | char tmp[64]; |
| 918 | 979 | ||
| 919 | snprintf(tmp, sizeof(tmp), "%.15lf", f); | 980 | snprintf(tmp, sizeof(tmp), "%.15lf", f); |
| @@ -940,7 +1001,7 @@ d_char *xs_number_new(double f) | |||
| 940 | } | 1001 | } |
| 941 | 1002 | ||
| 942 | 1003 | ||
| 943 | double xs_number_get(const char *v) | 1004 | double xs_number_get(const xs_number *v) |
| 944 | /* gets the number as a double */ | 1005 | /* gets the number as a double */ |
| 945 | { | 1006 | { |
| 946 | double f = 0.0; | 1007 | double f = 0.0; |
| @@ -952,7 +1013,7 @@ double xs_number_get(const char *v) | |||
| 952 | } | 1013 | } |
| 953 | 1014 | ||
| 954 | 1015 | ||
| 955 | const char *xs_number_str(const char *v) | 1016 | const char *xs_number_str(const xs_number *v) |
| 956 | /* gets the number as a string */ | 1017 | /* gets the number as a string */ |
| 957 | { | 1018 | { |
| 958 | const char *p = NULL; | 1019 | const char *p = NULL; |
| @@ -4,18 +4,18 @@ | |||
| 4 | 4 | ||
| 5 | #define _XS_CURL_H | 5 | #define _XS_CURL_H |
| 6 | 6 | ||
| 7 | d_char *xs_http_request(char *method, char *url, d_char *headers, | 7 | xs_dict *xs_http_request(char *method, char *url, xs_dict *headers, |
| 8 | d_char *body, int b_size, int *status, | 8 | xs_str *body, int b_size, int *status, |
| 9 | d_char **payload, int *p_size, int timeout); | 9 | xs_str **payload, int *p_size, int timeout); |
| 10 | 10 | ||
| 11 | #ifdef XS_IMPLEMENTATION | 11 | #ifdef XS_IMPLEMENTATION |
| 12 | 12 | ||
| 13 | #include <curl/curl.h> | 13 | #include <curl/curl.h> |
| 14 | 14 | ||
| 15 | static size_t _header_callback(char *buffer, size_t size, | 15 | static size_t _header_callback(char *buffer, size_t size, |
| 16 | size_t nitems, d_char **userdata) | 16 | size_t nitems, xs_dict **userdata) |
| 17 | { | 17 | { |
| 18 | d_char *headers = *userdata; | 18 | xs_dict *headers = *userdata; |
| 19 | xs *l; | 19 | xs *l; |
| 20 | 20 | ||
| 21 | /* get the line */ | 21 | /* get the line */ |
| @@ -83,15 +83,17 @@ static int _post_callback(char *buffer, size_t size, | |||
| 83 | } | 83 | } |
| 84 | 84 | ||
| 85 | 85 | ||
| 86 | d_char *xs_http_request(char *method, char *url, d_char *headers, | 86 | xs_dict *xs_http_request(char *method, char *url, xs_dict *headers, |
| 87 | d_char *body, int b_size, int *status, | 87 | xs_str *body, int b_size, int *status, |
| 88 | d_char **payload, int *p_size, int timeout) | 88 | xs_str **payload, int *p_size, int timeout) |
| 89 | /* does an HTTP request */ | 89 | /* does an HTTP request */ |
| 90 | { | 90 | { |
| 91 | d_char *response; | 91 | xs_dict *response; |
| 92 | CURL *curl; | 92 | CURL *curl; |
| 93 | struct curl_slist *list = NULL; | 93 | struct curl_slist *list = NULL; |
| 94 | char *k, *v, *p; | 94 | xs_dict *p; |
| 95 | xs_str *k; | ||
| 96 | xs_val *v; | ||
| 95 | long lstatus; | 97 | long lstatus; |
| 96 | struct _payload_data pd; | 98 | struct _payload_data pd; |
| 97 | 99 | ||
diff --git a/xs_encdec.h b/xs_encdec.h index 5f9ae01..5966583 100644 --- a/xs_encdec.h +++ b/xs_encdec.h | |||
| @@ -4,19 +4,19 @@ | |||
| 4 | 4 | ||
| 5 | #define _XS_ENCDEC_H | 5 | #define _XS_ENCDEC_H |
| 6 | 6 | ||
| 7 | d_char *xs_hex_enc(const char *data, int size); | 7 | xs_str *xs_hex_enc(const xs_val *data, int size); |
| 8 | d_char *xs_hex_dec(const char *hex, int *size); | 8 | xs_val *xs_hex_dec(const xs_str *hex, int *size); |
| 9 | d_char *xs_base64_enc(const char *data, int sz); | 9 | xs_str *xs_base64_enc(const xs_val *data, int sz); |
| 10 | d_char *xs_base64_dec(const char *data, int *size); | 10 | xs_val *xs_base64_dec(const xs_str *data, int *size); |
| 11 | d_char *xs_utf8_enc(d_char *str, unsigned int cpoint); | 11 | xs_str *xs_utf8_enc(xs_str *str, unsigned int cpoint); |
| 12 | 12 | ||
| 13 | 13 | ||
| 14 | #ifdef XS_IMPLEMENTATION | 14 | #ifdef XS_IMPLEMENTATION |
| 15 | 15 | ||
| 16 | d_char *xs_hex_enc(const char *data, int size) | 16 | xs_str *xs_hex_enc(const xs_val *data, int size) |
| 17 | /* returns an hexdump of data */ | 17 | /* returns an hexdump of data */ |
| 18 | { | 18 | { |
| 19 | d_char *s; | 19 | xs_str *s; |
| 20 | char *p; | 20 | char *p; |
| 21 | int n; | 21 | int n; |
| 22 | 22 | ||
| @@ -33,11 +33,11 @@ d_char *xs_hex_enc(const char *data, int size) | |||
| 33 | } | 33 | } |
| 34 | 34 | ||
| 35 | 35 | ||
| 36 | d_char *xs_hex_dec(const char *hex, int *size) | 36 | xs_val *xs_hex_dec(const xs_str *hex, int *size) |
| 37 | /* decodes an hexdump into data */ | 37 | /* decodes an hexdump into data */ |
| 38 | { | 38 | { |
| 39 | int sz = strlen(hex); | 39 | int sz = strlen(hex); |
| 40 | d_char *s = NULL; | 40 | xs_val *s = NULL; |
| 41 | char *p; | 41 | char *p; |
| 42 | int n; | 42 | int n; |
| 43 | 43 | ||
| @@ -65,10 +65,10 @@ d_char *xs_hex_dec(const char *hex, int *size) | |||
| 65 | } | 65 | } |
| 66 | 66 | ||
| 67 | 67 | ||
| 68 | d_char *xs_base64_enc(const char *data, int sz) | 68 | xs_str *xs_base64_enc(const xs_val *data, int sz) |
| 69 | /* encodes data to base64 */ | 69 | /* encodes data to base64 */ |
| 70 | { | 70 | { |
| 71 | d_char *s; | 71 | xs_str *s; |
| 72 | unsigned char *p; | 72 | unsigned char *p; |
| 73 | char *i; | 73 | char *i; |
| 74 | int bsz, n; | 74 | int bsz, n; |
| @@ -110,10 +110,10 @@ d_char *xs_base64_enc(const char *data, int sz) | |||
| 110 | } | 110 | } |
| 111 | 111 | ||
| 112 | 112 | ||
| 113 | d_char *xs_base64_dec(const char *data, int *size) | 113 | xs_val *xs_base64_dec(const xs_str *data, int *size) |
| 114 | /* decodes data from base64 */ | 114 | /* decodes data from base64 */ |
| 115 | { | 115 | { |
| 116 | d_char *s = NULL; | 116 | xs_val *s = NULL; |
| 117 | int sz = 0; | 117 | int sz = 0; |
| 118 | char *p; | 118 | char *p; |
| 119 | static char *b64_tbl = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" | 119 | static char *b64_tbl = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" |
| @@ -171,7 +171,7 @@ d_char *xs_base64_dec(const char *data, int *size) | |||
| 171 | } | 171 | } |
| 172 | 172 | ||
| 173 | 173 | ||
| 174 | d_char *xs_utf8_enc(d_char *str, unsigned int cpoint) | 174 | xs_str *xs_utf8_enc(xs_str *str, unsigned int cpoint) |
| 175 | /* encodes an Unicode codepoint to utf8 */ | 175 | /* encodes an Unicode codepoint to utf8 */ |
| 176 | { | 176 | { |
| 177 | unsigned char tmp[4]; | 177 | unsigned char tmp[4]; |
| @@ -4,7 +4,7 @@ | |||
| 4 | 4 | ||
| 5 | #define _XS_GLOB_H | 5 | #define _XS_GLOB_H |
| 6 | 6 | ||
| 7 | d_char *xs_glob_n(const char *spec, int basename, int reverse, int max); | 7 | xs_list *xs_glob_n(const char *spec, int basename, int reverse, int max); |
| 8 | #define xs_glob(spec, basename, reverse) xs_glob_n(spec, basename, reverse, XS_ALL) | 8 | #define xs_glob(spec, basename, reverse) xs_glob_n(spec, basename, reverse, XS_ALL) |
| 9 | 9 | ||
| 10 | 10 | ||
| @@ -12,11 +12,11 @@ d_char *xs_glob_n(const char *spec, int basename, int reverse, int max); | |||
| 12 | 12 | ||
| 13 | #include <glob.h> | 13 | #include <glob.h> |
| 14 | 14 | ||
| 15 | d_char *xs_glob_n(const char *spec, int basename, int reverse, int max) | 15 | xs_list *xs_glob_n(const char *spec, int basename, int reverse, int max) |
| 16 | /* does a globbing and returns the found files */ | 16 | /* does a globbing and returns the found files */ |
| 17 | { | 17 | { |
| 18 | glob_t globbuf; | 18 | glob_t globbuf; |
| 19 | d_char *list = xs_list_new(); | 19 | xs_list *list = xs_list_new(); |
| 20 | 20 | ||
| 21 | if (glob(spec, 0, NULL, &globbuf) == 0) { | 21 | if (glob(spec, 0, NULL, &globbuf) == 0) { |
| 22 | int n; | 22 | int n; |
| @@ -4,18 +4,18 @@ | |||
| 4 | 4 | ||
| 5 | #define _XS_HTTPD_H | 5 | #define _XS_HTTPD_H |
| 6 | 6 | ||
| 7 | d_char *xs_url_dec(char *str); | 7 | xs_str *xs_url_dec(char *str); |
| 8 | d_char *xs_url_vars(char *str); | 8 | xs_dict *xs_url_vars(char *str); |
| 9 | d_char *xs_httpd_request(FILE *f, d_char **payload, int *p_size); | 9 | xs_dict *xs_httpd_request(FILE *f, xs_str **payload, int *p_size); |
| 10 | void xs_httpd_response(FILE *f, int status, d_char *headers, char *body, int b_size); | 10 | void xs_httpd_response(FILE *f, int status, xs_dict *headers, xs_str *body, int b_size); |
| 11 | 11 | ||
| 12 | 12 | ||
| 13 | #ifdef XS_IMPLEMENTATION | 13 | #ifdef XS_IMPLEMENTATION |
| 14 | 14 | ||
| 15 | d_char *xs_url_dec(char *str) | 15 | xs_str *xs_url_dec(char *str) |
| 16 | /* decodes an URL */ | 16 | /* decodes an URL */ |
| 17 | { | 17 | { |
| 18 | d_char *s = xs_str_new(NULL); | 18 | xs_str *s = xs_str_new(NULL); |
| 19 | 19 | ||
| 20 | while (*str) { | 20 | while (*str) { |
| 21 | if (*str == '%') { | 21 | if (*str == '%') { |
| @@ -41,19 +41,19 @@ d_char *xs_url_dec(char *str) | |||
| 41 | } | 41 | } |
| 42 | 42 | ||
| 43 | 43 | ||
| 44 | d_char *xs_url_vars(char *str) | 44 | xs_dict *xs_url_vars(char *str) |
| 45 | /* parse url variables */ | 45 | /* parse url variables */ |
| 46 | { | 46 | { |
| 47 | d_char *vars; | 47 | xs_dict *vars; |
| 48 | 48 | ||
| 49 | vars = xs_dict_new(); | 49 | vars = xs_dict_new(); |
| 50 | 50 | ||
| 51 | if (str != NULL) { | 51 | if (str != NULL) { |
| 52 | char *v, *l; | ||
| 53 | xs *args; | ||
| 54 | |||
| 55 | /* split by arguments */ | 52 | /* split by arguments */ |
| 56 | args = xs_split(str, "&"); | 53 | xs *args = xs_split(str, "&"); |
| 54 | |||
| 55 | xs_list *l; | ||
| 56 | xs_val *v; | ||
| 57 | 57 | ||
| 58 | l = args; | 58 | l = args; |
| 59 | while (xs_list_iter(&l, &v)) { | 59 | while (xs_list_iter(&l, &v)) { |
| @@ -69,7 +69,7 @@ d_char *xs_url_vars(char *str) | |||
| 69 | } | 69 | } |
| 70 | 70 | ||
| 71 | 71 | ||
| 72 | d_char *_xs_multipart_form_data(char *payload, int p_size, char *header) | 72 | xs_dict *_xs_multipart_form_data(xs_str *payload, int p_size, char *header) |
| 73 | /* parses a multipart/form-data payload */ | 73 | /* parses a multipart/form-data payload */ |
| 74 | { | 74 | { |
| 75 | xs *boundary = NULL; | 75 | xs *boundary = NULL; |
| @@ -89,7 +89,7 @@ d_char *_xs_multipart_form_data(char *payload, int p_size, char *header) | |||
| 89 | 89 | ||
| 90 | bsz = strlen(boundary); | 90 | bsz = strlen(boundary); |
| 91 | 91 | ||
| 92 | d_char *p_vars = xs_dict_new(); | 92 | xs_dict *p_vars = xs_dict_new(); |
| 93 | 93 | ||
| 94 | /* iterate searching the boundaries */ | 94 | /* iterate searching the boundaries */ |
| 95 | while ((p = xs_memmem(payload + offset, p_size - offset, boundary, bsz)) != NULL) { | 95 | while ((p = xs_memmem(payload + offset, p_size - offset, boundary, bsz)) != NULL) { |
| @@ -173,12 +173,11 @@ d_char *_xs_multipart_form_data(char *payload, int p_size, char *header) | |||
| 173 | } | 173 | } |
| 174 | 174 | ||
| 175 | 175 | ||
| 176 | d_char *xs_httpd_request(FILE *f, d_char **payload, int *p_size) | 176 | xs_dict *xs_httpd_request(FILE *f, xs_str **payload, int *p_size) |
| 177 | /* processes an httpd connection */ | 177 | /* processes an httpd connection */ |
| 178 | { | 178 | { |
| 179 | d_char *req = NULL; | 179 | xs *q_vars = NULL; |
| 180 | xs *q_vars = NULL; | 180 | xs *p_vars = NULL; |
| 181 | xs *p_vars = NULL; | ||
| 182 | xs *l1, *l2; | 181 | xs *l1, *l2; |
| 183 | char *v; | 182 | char *v; |
| 184 | 183 | ||
| @@ -193,7 +192,7 @@ d_char *xs_httpd_request(FILE *f, d_char **payload, int *p_size) | |||
| 193 | return NULL; | 192 | return NULL; |
| 194 | } | 193 | } |
| 195 | 194 | ||
| 196 | req = xs_dict_new(); | 195 | xs_dict *req = xs_dict_new(); |
| 197 | 196 | ||
| 198 | req = xs_dict_append(req, "method", xs_list_get(l2, 0)); | 197 | req = xs_dict_append(req, "method", xs_list_get(l2, 0)); |
| 199 | req = xs_dict_append(req, "proto", xs_list_get(l2, 2)); | 198 | req = xs_dict_append(req, "proto", xs_list_get(l2, 2)); |
| @@ -258,11 +257,13 @@ d_char *xs_httpd_request(FILE *f, d_char **payload, int *p_size) | |||
| 258 | } | 257 | } |
| 259 | 258 | ||
| 260 | 259 | ||
| 261 | void xs_httpd_response(FILE *f, int status, d_char *headers, char *body, int b_size) | 260 | void xs_httpd_response(FILE *f, int status, xs_dict *headers, xs_str *body, int b_size) |
| 262 | /* sends an httpd response */ | 261 | /* sends an httpd response */ |
| 263 | { | 262 | { |
| 264 | xs *proto; | 263 | xs *proto; |
| 265 | char *p, *k, *v; | 264 | xs_dict *p; |
| 265 | xs_str *k; | ||
| 266 | xs_val *v; | ||
| 266 | 267 | ||
| 267 | proto = xs_fmt("HTTP/1.1 %d ", status); | 268 | proto = xs_fmt("HTTP/1.1 %d ", status); |
| 268 | fprintf(f, "%s\r\n", proto); | 269 | fprintf(f, "%s\r\n", proto); |
| @@ -4,17 +4,17 @@ | |||
| 4 | 4 | ||
| 5 | #define _XS_IO_H | 5 | #define _XS_IO_H |
| 6 | 6 | ||
| 7 | d_char *xs_readline(FILE *f); | 7 | xs_str *xs_readline(FILE *f); |
| 8 | d_char *xs_read(FILE *f, int *size); | 8 | xs_val *xs_read(FILE *f, int *size); |
| 9 | d_char *xs_readall(FILE *f); | 9 | xs_val *xs_readall(FILE *f); |
| 10 | 10 | ||
| 11 | 11 | ||
| 12 | #ifdef XS_IMPLEMENTATION | 12 | #ifdef XS_IMPLEMENTATION |
| 13 | 13 | ||
| 14 | d_char *xs_readline(FILE *f) | 14 | xs_str *xs_readline(FILE *f) |
| 15 | /* reads a line from a file */ | 15 | /* reads a line from a file */ |
| 16 | { | 16 | { |
| 17 | d_char *s = NULL; | 17 | xs_str *s = NULL; |
| 18 | 18 | ||
| 19 | errno = 0; | 19 | errno = 0; |
| 20 | 20 | ||
| @@ -38,10 +38,10 @@ d_char *xs_readline(FILE *f) | |||
| 38 | } | 38 | } |
| 39 | 39 | ||
| 40 | 40 | ||
| 41 | d_char *xs_read(FILE *f, int *sz) | 41 | xs_val *xs_read(FILE *f, int *sz) |
| 42 | /* reads up to size bytes from f */ | 42 | /* reads up to size bytes from f */ |
| 43 | { | 43 | { |
| 44 | d_char *s = NULL; | 44 | xs_val *s = NULL; |
| 45 | int size = *sz; | 45 | int size = *sz; |
| 46 | int rdsz = 0; | 46 | int rdsz = 0; |
| 47 | 47 | ||
| @@ -76,7 +76,7 @@ d_char *xs_read(FILE *f, int *sz) | |||
| 76 | } | 76 | } |
| 77 | 77 | ||
| 78 | 78 | ||
| 79 | d_char *xs_readall(FILE *f) | 79 | xs_val *xs_readall(FILE *f) |
| 80 | /* reads the rest of the file into a string */ | 80 | /* reads the rest of the file into a string */ |
| 81 | { | 81 | { |
| 82 | int size = XS_ALL; | 82 | int size = XS_ALL; |
| @@ -4,9 +4,9 @@ | |||
| 4 | 4 | ||
| 5 | #define _XS_JSON_H | 5 | #define _XS_JSON_H |
| 6 | 6 | ||
| 7 | d_char *xs_json_dumps_pp(char *data, int indent); | 7 | xs_str *xs_json_dumps_pp(xs_val *data, int indent); |
| 8 | #define xs_json_dumps(data) xs_json_dumps_pp(data, 0) | 8 | #define xs_json_dumps(data) xs_json_dumps_pp(data, 0) |
| 9 | d_char *xs_json_loads(const char *json); | 9 | xs_val *xs_json_loads(const xs_str *json); |
| 10 | 10 | ||
| 11 | 11 | ||
| 12 | #ifdef XS_IMPLEMENTATION | 12 | #ifdef XS_IMPLEMENTATION |
| @@ -148,11 +148,11 @@ d_char *_xs_json_dumps(d_char *s, char *data, int level, int indent) | |||
| 148 | } | 148 | } |
| 149 | 149 | ||
| 150 | 150 | ||
| 151 | d_char *xs_json_dumps_pp(char *data, int indent) | 151 | xs_str *xs_json_dumps_pp(xs_val *data, int indent) |
| 152 | /* dumps a piece of data as JSON */ | 152 | /* dumps a piece of data as JSON */ |
| 153 | { | 153 | { |
| 154 | xstype t = xs_type(data); | 154 | xstype t = xs_type(data); |
| 155 | d_char *s = NULL; | 155 | xs_str *s = NULL; |
| 156 | 156 | ||
| 157 | if (t == XSTYPE_LIST || t == XSTYPE_DICT) { | 157 | if (t == XSTYPE_LIST || t == XSTYPE_DICT) { |
| 158 | s = xs_str_new(NULL); | 158 | s = xs_str_new(NULL); |
| @@ -481,10 +481,10 @@ d_char *_xs_json_loads_object(const char **json, js_type *t) | |||
| 481 | } | 481 | } |
| 482 | 482 | ||
| 483 | 483 | ||
| 484 | d_char *xs_json_loads(const char *json) | 484 | xs_val *xs_json_loads(const xs_str *json) |
| 485 | /* loads a string in JSON format and converts to a multiple data */ | 485 | /* loads a string in JSON format and converts to a multiple data */ |
| 486 | { | 486 | { |
| 487 | d_char *v = NULL; | 487 | xs_val *v = NULL; |
| 488 | js_type t; | 488 | js_type t; |
| 489 | 489 | ||
| 490 | xs_free(_xs_json_loads_lexer(&json, &t)); | 490 | xs_free(_xs_json_loads_lexer(&json, &t)); |
diff --git a/xs_openssl.h b/xs_openssl.h index 33de853..f9cc452 100644 --- a/xs_openssl.h +++ b/xs_openssl.h | |||
| @@ -4,14 +4,14 @@ | |||
| 4 | 4 | ||
| 5 | #define _XS_OPENSSL_H | 5 | #define _XS_OPENSSL_H |
| 6 | 6 | ||
| 7 | d_char *xs_md5_hex(const void *input, int size); | 7 | xs_str *xs_md5_hex(const xs_val *input, int size); |
| 8 | d_char *xs_sha1_hex(const void *input, int size); | 8 | xs_str *xs_sha1_hex(const xs_val *input, int size); |
| 9 | d_char *xs_sha256_hex(const void *input, int size); | 9 | xs_str *xs_sha256_hex(const xs_val *input, int size); |
| 10 | d_char *xs_sha256_base64(const void *input, int size); | 10 | xs_str *xs_sha256_base64(const xs_val *input, int size); |
| 11 | d_char *xs_rsa_genkey(int bits); | 11 | xs_dict *xs_rsa_genkey(int bits); |
| 12 | d_char *xs_rsa_sign(const char *secret, const char *mem, int size); | 12 | xs_str *xs_rsa_sign(const char *secret, const char *mem, int size); |
| 13 | int xs_rsa_verify(const char *pubkey, const char *mem, int size, const char *b64sig); | 13 | int xs_rsa_verify(const char *pubkey, const char *mem, int size, const char *b64sig); |
| 14 | d_char *xs_evp_sign(const char *secret, const char *mem, int size); | 14 | xs_str *xs_evp_sign(const char *secret, const char *mem, int size); |
| 15 | int xs_evp_verify(const char *pubkey, const char *mem, int size, const char *b64sig); | 15 | int xs_evp_verify(const char *pubkey, const char *mem, int size, const char *b64sig); |
| 16 | 16 | ||
| 17 | 17 | ||
| @@ -23,7 +23,7 @@ int xs_evp_verify(const char *pubkey, const char *mem, int size, const char *b64 | |||
| 23 | #include "openssl/pem.h" | 23 | #include "openssl/pem.h" |
| 24 | #include "openssl/evp.h" | 24 | #include "openssl/evp.h" |
| 25 | 25 | ||
| 26 | d_char *xs_md5_hex(const void *input, int size) | 26 | xs_str *xs_md5_hex(const xs_val *input, int size) |
| 27 | { | 27 | { |
| 28 | unsigned char md5[16]; | 28 | unsigned char md5[16]; |
| 29 | MD5_CTX ctx; | 29 | MD5_CTX ctx; |
| @@ -36,7 +36,7 @@ d_char *xs_md5_hex(const void *input, int size) | |||
| 36 | } | 36 | } |
| 37 | 37 | ||
| 38 | 38 | ||
| 39 | d_char *xs_sha1_hex(const void *input, int size) | 39 | xs_str *xs_sha1_hex(const xs_val *input, int size) |
| 40 | { | 40 | { |
| 41 | unsigned char sha1[20]; | 41 | unsigned char sha1[20]; |
| 42 | SHA_CTX ctx; | 42 | SHA_CTX ctx; |
| @@ -61,7 +61,7 @@ unsigned char *_xs_sha256(const void *input, int size, unsigned char *sha256) | |||
| 61 | } | 61 | } |
| 62 | 62 | ||
| 63 | 63 | ||
| 64 | d_char *xs_sha256_hex(const void *input, int size) | 64 | xs_str *xs_sha256_hex(const xs_val *input, int size) |
| 65 | { | 65 | { |
| 66 | unsigned char sha256[32]; | 66 | unsigned char sha256[32]; |
| 67 | 67 | ||
| @@ -71,7 +71,7 @@ d_char *xs_sha256_hex(const void *input, int size) | |||
| 71 | } | 71 | } |
| 72 | 72 | ||
| 73 | 73 | ||
| 74 | d_char *xs_sha256_base64(const void *input, int size) | 74 | xs_str *xs_sha256_base64(const xs_val *input, int size) |
| 75 | { | 75 | { |
| 76 | unsigned char sha256[32]; | 76 | unsigned char sha256[32]; |
| 77 | 77 | ||
| @@ -81,12 +81,12 @@ d_char *xs_sha256_base64(const void *input, int size) | |||
| 81 | } | 81 | } |
| 82 | 82 | ||
| 83 | 83 | ||
| 84 | d_char *xs_rsa_genkey(int bits) | 84 | xs_dict *xs_rsa_genkey(int bits) |
| 85 | /* generates an RSA keypair */ | 85 | /* generates an RSA keypair */ |
| 86 | { | 86 | { |
| 87 | BIGNUM *bne; | 87 | BIGNUM *bne; |
| 88 | RSA *rsa; | 88 | RSA *rsa; |
| 89 | d_char *keypair = NULL; | 89 | xs_dict *keypair = NULL; |
| 90 | 90 | ||
| 91 | if ((bne = BN_new()) != NULL) { | 91 | if ((bne = BN_new()) != NULL) { |
| 92 | if (BN_set_word(bne, RSA_F4) == 1) { | 92 | if (BN_set_word(bne, RSA_F4) == 1) { |
| @@ -119,10 +119,10 @@ d_char *xs_rsa_genkey(int bits) | |||
| 119 | } | 119 | } |
| 120 | 120 | ||
| 121 | 121 | ||
| 122 | d_char *xs_rsa_sign(const char *secret, const char *mem, int size) | 122 | xs_str *xs_rsa_sign(const char *secret, const char *mem, int size) |
| 123 | /* signs a memory block (secret is in PEM format) */ | 123 | /* signs a memory block (secret is in PEM format) */ |
| 124 | { | 124 | { |
| 125 | d_char *signature = NULL; | 125 | xs_str *signature = NULL; |
| 126 | BIO *b; | 126 | BIO *b; |
| 127 | RSA *rsa; | 127 | RSA *rsa; |
| 128 | unsigned char *sig; | 128 | unsigned char *sig; |
| @@ -176,10 +176,10 @@ int xs_rsa_verify(const char *pubkey, const char *mem, int size, const char *b64 | |||
| 176 | } | 176 | } |
| 177 | 177 | ||
| 178 | 178 | ||
| 179 | d_char *xs_evp_sign(const char *secret, const char *mem, int size) | 179 | xs_str *xs_evp_sign(const char *secret, const char *mem, int size) |
| 180 | /* signs a memory block (secret is in PEM format) */ | 180 | /* signs a memory block (secret is in PEM format) */ |
| 181 | { | 181 | { |
| 182 | d_char *signature = NULL; | 182 | xs_str *signature = NULL; |
| 183 | BIO *b; | 183 | BIO *b; |
| 184 | unsigned char *sig; | 184 | unsigned char *sig; |
| 185 | unsigned int sig_len; | 185 | unsigned int sig_len; |
| @@ -4,22 +4,22 @@ | |||
| 4 | 4 | ||
| 5 | #define _XS_REGEX_H | 5 | #define _XS_REGEX_H |
| 6 | 6 | ||
| 7 | d_char *xs_regex_split_n(const char *str, const char *rx, int count); | 7 | xs_list *xs_regex_split_n(const char *str, const char *rx, int count); |
| 8 | #define xs_regex_split(str, rx) xs_regex_split_n(str, rx, XS_ALL) | 8 | #define xs_regex_split(str, rx) xs_regex_split_n(str, rx, XS_ALL) |
| 9 | d_char *xs_regex_match_n(const char *str, const char *rx, int count); | 9 | xs_list *xs_regex_match_n(const char *str, const char *rx, int count); |
| 10 | #define xs_regex_match(str, rx) xs_regex_match_n(str, rx, XS_ALL) | 10 | #define xs_regex_match(str, rx) xs_regex_match_n(str, rx, XS_ALL) |
| 11 | 11 | ||
| 12 | #ifdef XS_IMPLEMENTATION | 12 | #ifdef XS_IMPLEMENTATION |
| 13 | 13 | ||
| 14 | #include <regex.h> | 14 | #include <regex.h> |
| 15 | 15 | ||
| 16 | d_char *xs_regex_split_n(const char *str, const char *rx, int count) | 16 | xs_list *xs_regex_split_n(const char *str, const char *rx, int count) |
| 17 | /* splits str by regex */ | 17 | /* splits str by regex */ |
| 18 | { | 18 | { |
| 19 | regex_t re; | 19 | regex_t re; |
| 20 | regmatch_t rm; | 20 | regmatch_t rm; |
| 21 | int offset = 0; | 21 | int offset = 0; |
| 22 | d_char *list = NULL; | 22 | xs_list *list = NULL; |
| 23 | const char *p; | 23 | const char *p; |
| 24 | 24 | ||
| 25 | if (regcomp(&re, rx, REG_EXTENDED)) | 25 | if (regcomp(&re, rx, REG_EXTENDED)) |
| @@ -30,11 +30,11 @@ d_char *xs_regex_split_n(const char *str, const char *rx, int count) | |||
| 30 | while (count > 0 && !regexec(&re, (p = str + offset), 1, &rm, offset > 0 ? REG_NOTBOL : 0)) { | 30 | while (count > 0 && !regexec(&re, (p = str + offset), 1, &rm, offset > 0 ? REG_NOTBOL : 0)) { |
| 31 | /* add first the leading part of the string */ | 31 | /* add first the leading part of the string */ |
| 32 | list = xs_list_append_m(list, p, rm.rm_so); | 32 | list = xs_list_append_m(list, p, rm.rm_so); |
| 33 | list = xs_str_cat(list, ""); | 33 | list = xs_insert_m(list, xs_size(list) - 1, "", 1); |
| 34 | 34 | ||
| 35 | /* add now the matched text as the separator */ | 35 | /* add now the matched text as the separator */ |
| 36 | list = xs_list_append_m(list, p + rm.rm_so, rm.rm_eo - rm.rm_so); | 36 | list = xs_list_append_m(list, p + rm.rm_so, rm.rm_eo - rm.rm_so); |
| 37 | list = xs_str_cat(list, ""); | 37 | list = xs_insert_m(list, xs_size(list) - 1, "", 1); |
| 38 | 38 | ||
| 39 | /* move forward */ | 39 | /* move forward */ |
| 40 | offset += rm.rm_eo; | 40 | offset += rm.rm_eo; |
| @@ -51,12 +51,13 @@ d_char *xs_regex_split_n(const char *str, const char *rx, int count) | |||
| 51 | } | 51 | } |
| 52 | 52 | ||
| 53 | 53 | ||
| 54 | d_char *xs_regex_match_n(const char *str, const char *rx, int count) | 54 | xs_list *xs_regex_match_n(const char *str, const char *rx, int count) |
| 55 | /* returns a list with upto count matches */ | 55 | /* returns a list with upto count matches */ |
| 56 | { | 56 | { |
| 57 | d_char *list = xs_list_new(); | 57 | xs_list *list = xs_list_new(); |
| 58 | xs *split = NULL; | 58 | xs *split = NULL; |
| 59 | char *p, *v; | 59 | xs_list *p; |
| 60 | xs_val *v; | ||
| 60 | int n = 0; | 61 | int n = 0; |
| 61 | 62 | ||
| 62 | /* split */ | 63 | /* split */ |
| @@ -8,13 +8,13 @@ typedef struct _xs_set { | |||
| 8 | int elems; /* number of hash entries */ | 8 | int elems; /* number of hash entries */ |
| 9 | int used; /* number of used hash entries */ | 9 | int used; /* number of used hash entries */ |
| 10 | int *hash; /* hashed offsets */ | 10 | int *hash; /* hashed offsets */ |
| 11 | d_char *list; /* list of stored data */ | 11 | xs_list *list; /* list of stored data */ |
| 12 | } xs_set; | 12 | } xs_set; |
| 13 | 13 | ||
| 14 | void xs_set_init(xs_set *s); | 14 | void xs_set_init(xs_set *s); |
| 15 | d_char *xs_set_result(xs_set *s); | 15 | xs_list *xs_set_result(xs_set *s); |
| 16 | void xs_set_free(xs_set *s); | 16 | void xs_set_free(xs_set *s); |
| 17 | int xs_set_add(xs_set *s, const char *data); | 17 | int xs_set_add(xs_set *s, const xs_val *data); |
| 18 | 18 | ||
| 19 | 19 | ||
| 20 | #ifdef XS_IMPLEMENTATION | 20 | #ifdef XS_IMPLEMENTATION |
| @@ -33,10 +33,10 @@ void xs_set_init(xs_set *s) | |||
| 33 | } | 33 | } |
| 34 | 34 | ||
| 35 | 35 | ||
| 36 | d_char *xs_set_result(xs_set *s) | 36 | xs_list *xs_set_result(xs_set *s) |
| 37 | /* returns the set as a list and frees it */ | 37 | /* returns the set as a list and frees it */ |
| 38 | { | 38 | { |
| 39 | d_char *list = s->list; | 39 | xs_list *list = s->list; |
| 40 | s->list = NULL; | 40 | s->list = NULL; |
| 41 | s->hash = xs_free(s->hash); | 41 | s->hash = xs_free(s->hash); |
| 42 | 42 | ||
| @@ -93,7 +93,7 @@ static int _store_hash(xs_set *s, const char *data, int value) | |||
| 93 | } | 93 | } |
| 94 | 94 | ||
| 95 | 95 | ||
| 96 | int xs_set_add(xs_set *s, const char *data) | 96 | int xs_set_add(xs_set *s, const xs_val *data) |
| 97 | /* adds the data to the set */ | 97 | /* adds the data to the set */ |
| 98 | /* returns: 1 if added, 0 if already there */ | 98 | /* returns: 1 if added, 0 if already there */ |
| 99 | { | 99 | { |
| @@ -6,7 +6,7 @@ | |||
| 6 | 6 | ||
| 7 | #include <time.h> | 7 | #include <time.h> |
| 8 | 8 | ||
| 9 | d_char *xs_str_time(time_t t, const char *fmt, int local); | 9 | xs_str *xs_str_time(time_t t, const char *fmt, int local); |
| 10 | #define xs_str_localtime(t, fmt) xs_str_time(t, fmt, 1) | 10 | #define xs_str_localtime(t, fmt) xs_str_time(t, fmt, 1) |
| 11 | #define xs_str_utctime(t, fmt) xs_str_time(t, fmt, 0) | 11 | #define xs_str_utctime(t, fmt) xs_str_time(t, fmt, 0) |
| 12 | time_t xs_parse_time(const char *str, const char *fmt, int local); | 12 | time_t xs_parse_time(const char *str, const char *fmt, int local); |
| @@ -15,8 +15,8 @@ time_t xs_parse_time(const char *str, const char *fmt, int local); | |||
| 15 | 15 | ||
| 16 | #ifdef XS_IMPLEMENTATION | 16 | #ifdef XS_IMPLEMENTATION |
| 17 | 17 | ||
| 18 | d_char *xs_str_time(time_t t, const char *fmt, int local) | 18 | xs_str *xs_str_time(time_t t, const char *fmt, int local) |
| 19 | /* returns a d_char with a formated time */ | 19 | /* returns a string with a formated time */ |
| 20 | { | 20 | { |
| 21 | struct tm tm; | 21 | struct tm tm; |
| 22 | char tmp[64]; | 22 | char tmp[64]; |
diff --git a/xs_version.h b/xs_version.h index 1475b6f..0fe4322 100644 --- a/xs_version.h +++ b/xs_version.h | |||
| @@ -1 +1 @@ | |||
| /* f64030f1449390169bd09bdcbb052b1a70f8002a */ | /* 86f70ffc75a8c9601adde42146af65c14d41518a */ | ||