Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
5a2dcd88
Commit
5a2dcd88
authored
Feb 02, 2013
by
Benjamin Peterson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Issue #15881: Fixed atexit hook in multiprocessing.
parent
48daafe7
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
34 additions
and
9 deletions
+34
-9
Lib/multiprocessing/util.py
Lib/multiprocessing/util.py
+32
-9
Misc/NEWS
Misc/NEWS
+2
-0
No files found.
Lib/multiprocessing/util.py
View file @
5a2dcd88
...
...
@@ -247,6 +247,12 @@ def _run_finalizers(minpriority=None):
Finalizers with highest priority are called first; finalizers with
the same priority will be called in reverse order of creation.
'''
if
_finalizer_registry
is
None
:
# This function may be called after this module's globals are
# destroyed. See the _exit_function function in this module for more
# notes.
return
if
minpriority
is
None
:
f
=
lambda
p
:
p
[
0
][
0
]
is
not
None
else
:
...
...
@@ -278,21 +284,38 @@ def is_exiting():
_exiting
=
False
def
_exit_function
():
def
_exit_function
(
info
=
info
,
debug
=
debug
,
_run_finalizers
=
_run_finalizers
,
active_children
=
active_children
,
current_process
=
current_process
):
# NB: we hold on to references to functions in the arglist due to the
# situation described below, where this function is called after this
# module's globals are destroyed.
global
_exiting
info
(
'process shutting down'
)
debug
(
'running all "atexit" finalizers with priority >= 0'
)
_run_finalizers
(
0
)
for
p
in
active_children
():
if
p
.
_daemonic
:
info
(
'calling terminate() for daemon %s'
,
p
.
name
)
p
.
_popen
.
terminate
()
for
p
in
active_children
():
info
(
'calling join() for process %s'
,
p
.
name
)
p
.
join
()
if
current_process
()
is
not
None
:
# NB: we check if the current process is None here because if
# it's None, any call to ``active_children()`` will throw an
# AttributeError (active_children winds up trying to get
# attributes from util._current_process). This happens in a
# variety of shutdown circumstances that are not well-understood
# because module-scope variables are not apparently supposed to
# be destroyed until after this function is called. However,
# they are indeed destroyed before this function is called. See
# issues 9775 and 15881. Also related: 4106, 9205, and 9207.
for
p
in
active_children
():
if
p
.
_daemonic
:
info
(
'calling terminate() for daemon %s'
,
p
.
name
)
p
.
_popen
.
terminate
()
for
p
in
active_children
():
info
(
'calling join() for process %s'
,
p
.
name
)
p
.
join
()
debug
(
'running the remaining "atexit" finalizers'
)
_run_finalizers
()
...
...
Misc/NEWS
View file @
5a2dcd88
...
...
@@ -202,6 +202,8 @@ Core and Builtins
Library
-------
- Issue #15881: Fixed atexit hook in multiprocessing.
- Issue #14340: Upgrade the embedded expat library to version 2.1.0.
- Issue #11159: SAX parser now supports unicode file names.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment