mirror of
https://github.com/gnustep/libs-base.git
synced 2025-05-20 12:16:40 +00:00
Revert back to working code!
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/base/trunk@32072 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
parent
f3f69cccc2
commit
336c7bf021
13 changed files with 57 additions and 71 deletions
|
@ -277,6 +277,7 @@ commonModes(void)
|
|||
static BOOL entered_multi_threaded_state = NO;
|
||||
|
||||
static NSThread *defaultThread;
|
||||
static NSLock *thread_creation_lock;
|
||||
|
||||
static pthread_key_t thread_object_key;
|
||||
|
||||
|
@ -304,7 +305,6 @@ static void exitedThread(void *thread)
|
|||
fprintf(stderr, "WARNING thread %p terminated without calling +exit!\n",
|
||||
thread);
|
||||
}
|
||||
[(id)thread release];
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -458,15 +458,17 @@ unregisterActiveThread(NSThread *thread)
|
|||
|
||||
if (t == nil)
|
||||
{
|
||||
[thread_creation_lock lock];
|
||||
t = pthread_getspecific(thread_object_key);
|
||||
if (t == nil)
|
||||
{
|
||||
t = [self new];
|
||||
t->_active = YES;
|
||||
pthread_setspecific(thread_object_key, t);
|
||||
[t release];
|
||||
[thread_creation_lock unlock];
|
||||
return YES;
|
||||
}
|
||||
[thread_creation_lock unlock];
|
||||
}
|
||||
return NO;
|
||||
}
|
||||
|
@ -527,6 +529,7 @@ unregisterActiveThread(NSThread *thread)
|
|||
[NSException raise: NSInternalInconsistencyException
|
||||
format: @"Unable to create thread key!"];
|
||||
}
|
||||
thread_creation_lock = [NSLock new];
|
||||
/*
|
||||
* Ensure that the default thread exists.
|
||||
*/
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue