X-Git-Url: http://www.project-moonshot.org/gitweb/?a=blobdiff_plain;f=src%2Fjansson_private.h;h=951780c6a061af6c012df6cdcdb376c9981823d4;hb=5422a862de2354b3419ef628bac5a18c6ef522da;hp=bd80346fa6d90ce95649bc30c4596dd6e0bda591;hpb=ffbab6fedd86ee1a0c7884d62fa7233ce9d745d2;p=jansson.git diff --git a/src/jansson_private.h b/src/jansson_private.h index bd80346..951780c 100644 --- a/src/jansson_private.h +++ b/src/jansson_private.h @@ -8,11 +8,17 @@ #ifndef JANSSON_PRIVATE_H #define JANSSON_PRIVATE_H +#include #include "jansson.h" #include "hashtable.h" #define container_of(ptr_, type_, member_) \ - ((type_ *)((char *)ptr_ - (size_t)&((type_ *)0)->member_)) + ((type_ *)((char *)ptr_ - offsetof(type_, member_))) + +/* On some platforms, max() may already be defined */ +#ifndef max +#define max(a, b) ((a) > (b) ? (a) : (b)) +#endif typedef struct { json_t json; @@ -52,9 +58,13 @@ typedef struct { typedef struct { size_t serial; - char key[]; + char key[1]; } object_key_t; const object_key_t *jsonp_object_iter_fullkey(void *iter); +void jsonp_error_init(json_error_t *error, const char *source); +void jsonp_error_set(json_error_t *error, int line, int column, + const char *msg, ...); + #endif