215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
|
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
|
-
+
+
-
+
|
}
+ (void)callAllDestructors
{
of_list_object_t *iter;
@synchronized (tlskeys) {
for (iter = [tlskeys first]; iter != NULL; iter = iter->next)
for (iter = [tlskeys firstListObject]; iter != NULL;
iter = iter->next)
((OFTLSKey*)iter->object)->destructor(iter->object);
}
}
- init
{
self = [super init];
if (!of_tlskey_new(&key)) {
Class c = isa;
[super dealloc];
@throw [OFInitializationFailedException newWithClass: c];
}
destructor = NULL;
@synchronized (tlskeys) {
@try {
listobj = [tlskeys append: self];
listobj = [tlskeys appendObject: self];
} @catch (OFException *e) {
/*
* We can't use [super dealloc] on OS X here.
* Compiler bug? Anyway, [self dealloc] will do here
* as we check listobj != NULL in dealloc.
*/
listobj = NULL;
|
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
|
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
|
-
+
|
destructor(self);
of_tlskey_free(key);
@synchronized (tlskeys) {
/* In case we called [self dealloc] in init */
if (listobj != NULL)
[tlskeys remove: listobj];
[tlskeys removeListObject: listobj];
}
[super dealloc];
}
@end
@implementation OFMutex
|