}
unsigned int crc32_add_string(unsigned int checksum, const char*s)
{
+ if(!s)
+ return checksum;
while(*s) {
checksum = crc32_add_byte(checksum, *s);
s++;
char charptr_equals(const void*o1, const void*o2)
{
+ if(!o1 || !o2)
+ return o1==o2;
return !strcmp(o1,o2);
}
unsigned int charptr_hash(const void*o)
{
+ if(!o)
+ return 0;
return string_hash2(o);
}
void* charptr_dup(const void*o)
{
+ if(!o)
+ return 0;
return strdup(o);
}
void charptr_free(void*o)
{
- rfx_free(o);
+ if(o) {
+ rfx_free(o);
+ }
}
char stringstruct_equals(const void*o1, const void*o2)
{
listinfo_t info[0];
} commonlist_t;
-int list_length(void*_list)
+int list_length_(void*_list)
{
commonlist_t*l = (commonlist_t*)_list;
if(!l)
extern "C" {
#endif
-#define NEW(t,y) t*y = (t*)malloc(sizeof(t));memset(y, 0, sizeof(t));
+#define NEW(t,y) t*y = (t*)rfx_calloc(sizeof(t));
/* dynamically growing mem section */
typedef struct _mem_t {
struct _##x##_list*next; \
}; \
typedef struct _##x##_list x##_list_t;
-int list_length(void*_list);
+int list_length_(void*_list);
void*list_clone_(void*_list);
void list_append_(void*_list, void*entry);
void list_free_(void*_list);
#define list_append(list, e) {sizeof((list)->next);list_append_(&(list),(e));}
#define list_free(list) {sizeof((list)->next);list_free_(&(list));}
#define list_clone(list) (sizeof((list)->next),list_clone_(&(list)))
+#define list_length(list) (sizeof((list)->next),list_length_(list))
#ifdef __cplusplus
}