vicon drag tweaks, proxy drag fix, vicon mouseover, binfolder around sort fix, draw_r...
[goodguy/history.git] / cinelerra-5.1 / guicast / thread.C
index 26ccf9a45918ce78b7147c4dc7bb6829b136da18..dff53e61ec4e5eb656a09236f4486ef680ee7484 100644 (file)
@@ -65,8 +65,8 @@ void* Thread::entrypoint(void *parameters)
        thread->run();
        thread->finished = true;
        if( !thread->synchronous ) {
-               if( !thread->cancelled ) TheList::dbg_del(thread->tid);
                if( thread->autodelete ) delete thread;
+               else if( !thread->cancelled ) TheList::dbg_del(thread->tid);
                else thread->tid = ((pthread_t)-1);
        }
        return NULL;
@@ -106,9 +106,13 @@ void Thread::start()
                        perror("Thread::start pthread_attr_setinheritsched");
        }
 
+// autodelete may delete this immediately after create
+       int autodelete = this->autodelete;
+
        pthread_create(&tid, &attr, Thread::entrypoint, this);
 
-       TheList::dbg_add(tid, owner, typeid(*this).name());
+       if( !autodelete )
+               TheList::dbg_add(tid, owner, typeid(*this).name());
 }
 
 int Thread::cancel()
@@ -146,7 +150,7 @@ int Thread::join()   // join this thread
                while( running() && !cancelled ) {
                        int ret = pthread_kill(tid, 0);
                        if( ret ) break;
-                       usleep(200000);
+                       usleep(10000);
                }
                tid = ((pthread_t)-1);
        }
@@ -239,6 +243,6 @@ int Thread::get_realtime()
 
 unsigned long Thread::get_tid()
 {
-       return tid;
+       return (unsigned long)tid;
 }