diff options
| author | Andrew Svetlov <andrew.svetlov@gmail.com> | 2013-09-04 07:01:07 +0300 | 
|---|---|---|
| committer | Andrew Svetlov <andrew.svetlov@gmail.com> | 2013-09-04 07:01:07 +0300 | 
| commit | 58b5c5ad144242b6ac6f5d155e69e124be36af48 (patch) | |
| tree | 162a477828b8c8994d0ecb1c0d5ad409b802a099 /Lib/threading.py | |
| parent | 3c561456380ff54efb3784a92ba74ee904470b35 (diff) | |
| download | cpython-git-58b5c5ad144242b6ac6f5d155e69e124be36af48.tar.gz | |
Issue #18882: Add threading.main_thread() function.
Diffstat (limited to 'Lib/threading.py')
| -rw-r--r-- | Lib/threading.py | 36 | 
1 files changed, 20 insertions, 16 deletions
| diff --git a/Lib/threading.py b/Lib/threading.py index 21bc78161f..2c06d99ab5 100644 --- a/Lib/threading.py +++ b/Lib/threading.py @@ -840,20 +840,6 @@ class _MainThread(Thread):          with _active_limbo_lock:              _active[self._ident] = self -    def _exitfunc(self): -        self._stop() -        t = _pickSomeNonDaemonThread() -        while t: -            t.join() -            t = _pickSomeNonDaemonThread() -        self._delete() - -def _pickSomeNonDaemonThread(): -    for t in enumerate(): -        if not t.daemon and t.is_alive(): -            return t -    return None -  # Dummy thread class to represent threads not started here.  # These aren't garbage collected when they die, nor can they be waited for. @@ -915,7 +901,24 @@ from _thread import stack_size  # and make it available for the interpreter  # (Py_Main) as threading._shutdown. -_shutdown = _MainThread()._exitfunc +_main_thread = _MainThread() + +def _shutdown(): +    _main_thread._stop() +    t = _pickSomeNonDaemonThread() +    while t: +        t.join() +        t = _pickSomeNonDaemonThread() +    _main_thread._delete() + +def _pickSomeNonDaemonThread(): +    for t in enumerate(): +        if not t.daemon and t.is_alive(): +            return t +    return None + +def main_thread(): +    return _main_thread  # get thread-local implementation, either from the thread  # module, or from the python fallback @@ -933,12 +936,13 @@ def _after_fork():      # Reset _active_limbo_lock, in case we forked while the lock was held      # by another (non-forked) thread.  http://bugs.python.org/issue874900 -    global _active_limbo_lock +    global _active_limbo_lock, _main_thread      _active_limbo_lock = _allocate_lock()      # fork() only copied the current thread; clear references to others.      new_active = {}      current = current_thread() +    _main_thread = current      with _active_limbo_lock:          for thread in _enumerate():              # Any lock/condition variable may be currently locked or in an | 
