X-Git-Url: http://sjero.net/git/?p=wget;a=blobdiff_plain;f=src%2Futils.h;h=1b3f43ab56909ef90eff518f013281c289eca869;hp=456a9c99948e0c1ead47adb7a509b0d28e3b7c42;hb=d5e283b1a75c5f8249300b465b4e7b55130bec49;hpb=7a54d852bfa09c828bbc4907adddee7e4beb1715 diff --git a/src/utils.h b/src/utils.h index 456a9c99..1b3f43ab 100644 --- a/src/utils.h +++ b/src/utils.h @@ -31,6 +31,28 @@ as that of the covered work. */ #ifndef UTILS_H #define UTILS_H +/* Constant is using when we don`t know attempted size exactly */ +#define UNKNOWN_ATTEMPTED_SIZE -3 + +/* Macros that interface to malloc, but know about type sizes, and + cast the result to the appropriate type. The casts are not + necessary in standard C, but Wget performs them anyway for the sake + of pre-standard environments and possibly C++. */ + +#define xnew(type) (xmalloc (sizeof (type))) +#define xnew0(type) (xcalloc (1, sizeof (type))) +#define xnew_array(type, len) (xmalloc ((len) * sizeof (type))) +#define xnew0_array(type, len) (xcalloc ((len), sizeof (type))) + +#define alloca_array(type, size) ((type *) alloca ((size) * sizeof (type))) + +#define xfree free +/* Free P if it is non-NULL. C requires free() to behaves this way by + default, but Wget's code is historically careful not to pass NULL + to free. This allows us to assert p!=NULL in xfree to check + additional errors. (But we currently don't do that!) */ +#define xfree_null(p) if (!(p)) ; else xfree (p) + struct hash_table; struct file_memory { @@ -44,10 +66,6 @@ struct file_memory { char *time_str (time_t); char *datetime_str (time_t); -#ifdef DEBUG_MALLOC -void print_malloc_debug_stats (); -#endif - char *xstrdup_lower (const char *); char *strdupdelim (const char *, const char *);