2000-12-12 13:33:13 +03:00
|
|
|
/*
|
|
|
|
* PuTTY memory-handling header.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PUTTY_PUTTYMEM_H
|
|
|
|
#define PUTTY_PUTTYMEM_H
|
|
|
|
|
2001-05-06 18:35:20 +04:00
|
|
|
#include <stddef.h> /* for size_t */
|
|
|
|
#include <string.h> /* for memcpy() */
|
2001-04-28 13:24:19 +04:00
|
|
|
|
|
|
|
|
2000-12-12 13:33:13 +03:00
|
|
|
/* #define MALLOC_LOG do this if you suspect putty of leaking memory */
|
|
|
|
#ifdef MALLOC_LOG
|
2005-02-20 13:30:05 +03:00
|
|
|
#define smalloc(z) (mlog(__FILE__,__LINE__), safemalloc(z,1))
|
|
|
|
#define snmalloc(z,s) (mlog(__FILE__,__LINE__), safemalloc(z,s))
|
|
|
|
#define srealloc(y,z) (mlog(__FILE__,__LINE__), saferealloc(y,z,1))
|
2005-07-06 22:26:41 +04:00
|
|
|
#define snrealloc(y,z,s) (mlog(__FILE__,__LINE__), saferealloc(y,z,s))
|
2000-12-12 13:33:13 +03:00
|
|
|
#define sfree(z) (mlog(__FILE__,__LINE__), safefree(z))
|
|
|
|
void mlog(char *, int);
|
|
|
|
#else
|
2005-02-20 13:30:05 +03:00
|
|
|
#define smalloc(z) safemalloc(z,1)
|
|
|
|
#define snmalloc safemalloc
|
|
|
|
#define srealloc(y,z) saferealloc(y,z,1)
|
|
|
|
#define snrealloc saferealloc
|
2000-12-12 13:33:13 +03:00
|
|
|
#define sfree safefree
|
|
|
|
#endif
|
|
|
|
|
2005-02-20 13:30:05 +03:00
|
|
|
void *safemalloc(size_t, size_t);
|
|
|
|
void *saferealloc(void *, size_t, size_t);
|
2000-12-12 13:33:13 +03:00
|
|
|
void safefree(void *);
|
|
|
|
|
2003-03-29 19:14:26 +03:00
|
|
|
/*
|
|
|
|
* 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.
|
2012-07-19 08:29:50 +04:00
|
|
|
*
|
|
|
|
* The nasty trick in sresize with sizeof arranges for the compiler,
|
|
|
|
* in passing, to type-check the expression ((type *)0 == (ptr)), i.e.
|
|
|
|
* to type-check that the input pointer is a pointer to the correct
|
|
|
|
* type. The construction sizeof(stuff) ? (b) : (b) looks like a
|
|
|
|
* violation of the first principle of safe macros, but in fact it's
|
|
|
|
* OK - although it _expands_ the macro parameter more than once, it
|
|
|
|
* only _evaluates_ it once, so it's still side-effect safe.
|
2003-03-29 19:14:26 +03:00
|
|
|
*/
|
2005-02-20 13:30:05 +03:00
|
|
|
#define snew(type) ((type *)snmalloc(1, sizeof(type)))
|
|
|
|
#define snewn(n, type) ((type *)snmalloc((n), sizeof(type)))
|
2012-07-19 08:29:50 +04:00
|
|
|
#define sresize(ptr, n, type) \
|
|
|
|
((type *)snrealloc(sizeof((type *)0 == (ptr)) ? (ptr) : (ptr), \
|
|
|
|
(n), sizeof(type)))
|
2001-04-28 13:24:19 +04:00
|
|
|
|
2000-12-12 13:33:13 +03:00
|
|
|
#endif
|