--- parser3/src/include/pa_memory.h 2015/04/23 17:59:16 1.23 +++ parser3/src/include/pa_memory.h 2015/10/12 14:36:56 1.26 @@ -9,12 +9,13 @@ #ifndef PA_MEMORY_H #define PA_MEMORY_H -#define IDENT_PA_MEMORY_H "$Id: pa_memory.h,v 1.23 2015/04/23 17:59:16 moko Exp $" +#define IDENT_PA_MEMORY_H "$Id: pa_memory.h,v 1.26 2015/10/12 14:36:56 moko Exp $" // include #include "pa_config_includes.h" #include "gc.h" +#include // define destructors use for Array, Hash and VMethodFrame #define USE_DESTRUCTORS @@ -69,28 +70,34 @@ inline void *pa_realloc(void *ptr, size_ return pa_fail_alloc("reallocate to", size); } +#ifdef _MSC_VER +#define PA_THROW(what) +#else +#define PA_THROW(what) throw(what) +#endif + #define PointerFreeGC (true) //{@ Array-oriented -inline void *operator new[] (size_t size) { - return pa_malloc(size); -} inline void *operator new[] (size_t size, bool) { // PointerFreeGC return pa_malloc_atomic(size); } -inline void operator delete[] (void *ptr) { +inline void *operator new[] (std::size_t size) PA_THROW(std::bad_alloc) { + return pa_malloc(size); +} +inline void operator delete[] (void *ptr) PA_THROW() { pa_free(ptr); } //}@ //{@ Structure-oriented -inline void *operator new(size_t size) { - return pa_malloc(size); -} inline void *operator new (size_t size, bool) { // PointerFreeGC return pa_malloc_atomic(size); } -inline void operator delete(void *ptr) { +inline void *operator new(std::size_t size) PA_THROW(std::bad_alloc) { + return pa_malloc(size); +} +inline void operator delete(void *ptr) PA_THROW() { pa_free(ptr); } //}@ @@ -104,10 +111,10 @@ void *realloc_disabled(); void free_disabled(); char *strdup_disabled(); -inline void *calloc(size_t){ return calloc_disabled(); } -inline void *malloc(size_t){ return malloc_disabled(); } -inline void *realloc(void *, size_t){ return realloc_disabled(); } -inline void free(void *){ free_disabled(); } +inline void *calloc(size_t) { return calloc_disabled(); } +inline void *malloc(size_t) { return malloc_disabled(); } +inline void *realloc(void *, size_t) { return realloc_disabled(); } +inline void free(void *) { free_disabled(); } inline char *strdup(const char*, size_t){ return strdup_disabled(); } #endif