56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
-
-
-
+
-
+
+
+
-
+
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
|
return NULL;
iter->ptr = ptr;
return ptr;
}
}
fprintf(stderr, "WARNING: Memory at %p was not allocated as part of "
"object %s!\n-> Memory was not resized!\n", ptr, [self name]);
@throw [OFMemNotPartOfObjException new: ptr fromObject: self];
return NULL;
}
- (void)freeMem: (void*)ptr;
{
struct __ofobject_allocated_mem *iter;
for (iter = __mem_pool; iter != NULL; iter = iter->prev) {
if (iter->ptr == ptr) {
if (iter->prev != NULL)
if (iter->prev != NULL)
iter->prev->next = iter->next;
if (iter->next != NULL)
iter->next->prev = iter->prev;
if (__mem_pool == iter)
__mem_pool = NULL;
free(iter);
free(ptr);
return;
}
}
fprintf(stderr, "WARNING: Memory at %p was not allocated as part of "
@throw [OFMemNotPartOfObjException new: ptr fromObject: self];
"object %s!\n-> Memory was not free'd!\n", ptr, [self name]);
}
- free
{
struct __ofobject_allocated_mem *iter, *iter2;
for (iter = __mem_pool; iter != NULL; iter = iter2) {
iter2 = iter->prev;
free(iter->ptr);
free(iter);
}
return [super free];
}
@end
@implementation OFMemNotPartOfObjException
+ new: (void*)ptr fromObject: (id)obj
{
return [[OFMemNotPartOfObjException alloc] init: ptr
fromObject: obj];
}
- init: (void*)ptr fromObject: (id)obj
{
fprintf(stderr, "ERROR: Memory at %p was not allocated as part of "
"object %s!\n"
"ERROR: -> Not changing memory allocation!\n"
"ERROR: (Hint: It is possible that you tried to free the same "
"memory twice!)\n", ptr, [obj name]);
return [super init];
}
@end
|