X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=blobdiff_plain;f=puttymem.h;h=9fe272fd51bf709987169233e63e0032fce9f38c;hb=6ef62aacfc5108355532ce82dc8eae7b7dc70e39;hp=ba4fd0ed8d2f400886d6bd92338fa442471a9f8d;hpb=d5240d41571b86c0f1e7887972c4e3af2febd5e4;p=PuTTY.git diff --git a/puttymem.h b/puttymem.h index ba4fd0ed..9fe272fd 100644 --- a/puttymem.h +++ b/puttymem.h @@ -5,6 +5,10 @@ #ifndef PUTTY_PUTTYMEM_H #define PUTTY_PUTTYMEM_H +#include /* for size_t */ +#include /* for memcpy() */ + + /* #define MALLOC_LOG do this if you suspect putty of leaking memory */ #ifdef MALLOC_LOG #define smalloc(z) (mlog(__FILE__,__LINE__), safemalloc(z)) @@ -21,4 +25,14 @@ void *safemalloc(size_t); void *saferealloc(void *, size_t); void safefree(void *); +/* + * Direct use of smalloc within the code should be avoided where + * possible, in favour of these type-casting macros which ensure + * you don't mistakenly allocate enough space for one sort of + * structure and assign it to a different sort of pointer. + */ +#define snew(type) ((type *)smalloc(sizeof(type))) +#define snewn(n, type) ((type *)smalloc((n)*sizeof(type))) +#define sresize(ptr, n, type) ((type *)srealloc(ptr, (n)*sizeof(type))) + #endif