Annotation of parser3/src/include/pa_memory.h, revision 1.1.2.9.2.6
1.1.2.1 paf 1: /** @file
2: Parser: memory reference counting classes decls.
3:
4: Copyright (c) 2001-2003 ArtLebedev Group (http://www.artlebedev.com)
5:
6: Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
7: */
8:
9: #ifndef PA_MEMORY_H
10: #define PA_MEMORY_H
11:
1.1.2.9.2.6! paf 12: static const char* IDENT_MEMORY_H="$Date: 2003/03/20 09:41:45 $";
1.1.2.9 paf 13:
14: #define PA_DEBUG_REFERENCES
1.1.2.1 paf 15:
16: // include
17:
18: #include "pa_config_includes.h"
1.1.2.9.2.1 paf 19: #include "gc.h"
20:
1.1.2.1 paf 21:
22: #ifdef XML
23: # include "gdome.h"
24: // for xmlChar
25: # include "libxml/tree.h"
26: #endif
27:
28: // forwards
29:
1.1.2.9.2.5 paf 30: void *pa_fail_alloc(const char* what, size_t size);
1.1.2.2 paf 31:
32: // inlines
33:
34: inline void *pa_malloc(size_t size) {
1.1.2.9.2.1 paf 35: if(void *result=GC_MALLOC(size))
1.1.2.2 paf 36: return result;
37:
38: return pa_fail_alloc("allocate", size);
39: }
40:
1.1.2.9.2.1 paf 41: inline void *pa_malloc_atomic(size_t size) {
42: if(void *result=GC_MALLOC_ATOMIC(size))
1.1.2.2 paf 43: return result;
44:
45: return pa_fail_alloc("allocate clean", size);
46: }
1.1.2.9.2.4 paf 47: /// @a length may be null, which mean "autocalc it"
1.1.2.9.2.5 paf 48: inline char *pa_strdup(const char* auto_variable_never_null, size_t length=0) {
1.1.2.9.2.4 paf 49: if(!length)
50: length=strlen(auto_variable_never_null);
51: size_t size=length+1; // terminating zero
52: if(char *result=static_cast<char*>(GC_MALLOC_ATOMIC(size))) {
53: memcpy(result, auto_variable_never_null, size);
54: return result;
55: }
56:
57: return static_cast<char*>(pa_fail_alloc("allocate clean", size));
58: }
1.1.2.2 paf 59: inline void pa_free(void *ptr) {
1.1.2.9.2.1 paf 60: GC_FREE(ptr);
1.1.2.2 paf 61: }
62:
63: inline void *pa_realloc(void *ptr, size_t size) {
1.1.2.9.2.1 paf 64: if(void *result=GC_REALLOC(ptr, size))
1.1.2.2 paf 65: return result;
66:
67: return pa_fail_alloc("reallocate to", size);
68: }
1.1.2.1 paf 69:
1.1.2.9.2.4 paf 70: //{@ these operators are disabled, one should explicitely specify either new(UseGC) or new(PointerFreeGC)
1.1.2.9.2.6! paf 71: inline void *operator new(size_t size) { abort(); } // disabled
! 72: inline void operator delete (void *ptr) { abort(); } // disabled
! 73: inline void *operator new[] (size_t size) { abort(); } // disabled
1.1.2.9.2.4 paf 74: //}@
1.1.2.9.2.3 paf 75:
76: #define UseGC ((int)1)
77: #define PointerFreeGC (true)
78:
79: inline void *operator new[] (size_t size, int) { // UseGC
80: return pa_malloc(size);
81: }
82: inline void *operator new[] (size_t size, bool) { // PointerFreeGC
1.1.2.9.2.1 paf 83: return pa_malloc_atomic(size);
1.1.2.1 paf 84: }
85: inline void operator delete[] (void *ptr) {
86: pa_free(ptr);
87: }
88:
1.1.2.9.2.1 paf 89: /// memory allocation/dallocation goes via pa_malloc/pa_free.
1.1.2.1 paf 90: class PA_Allocated {
91: public:
92: /// the sole: instances allocated using our functions
93: static void *operator new(size_t size) {
94: return pa_malloc(size);
95: }
96: static void operator delete(void *ptr) {
97: pa_free(ptr);
98: }
99: static void *malloc(size_t size) {
100: return pa_malloc(size);
101: }
1.1.2.9.2.1 paf 102: static void *malloc_atomic(size_t size) {
103: return pa_malloc_atomic(size);
1.1.2.1 paf 104: }
105: static void free(void *ptr) {
106: pa_free(ptr);
107: }
108: static void *realloc(void *ptr, size_t size) {
109: return pa_realloc(ptr, size);
110: }
1.1.2.9.2.2 paf 111:
112: private: // disabled from accidental use
113:
114: /// use malloc instead [GC clears malloc result]
115: static void *calloc(size_t size);
1.1.2.1 paf 116:
117: };
118:
1.1.2.9.2.1 paf 119: /// Base for all Parser classes
120: typedef PA_Allocated PA_Object;
1.1.2.1 paf 121:
1.1.2.9.2.6! paf 122: // defines
! 123:
! 124: #define override
! 125: #define rethrow throw
1.1.2.1 paf 126:
127: #endif
E-mail: