summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Oudkerk <shibturn@gmail.com>2014-03-23 11:54:15 (GMT)
committerRichard Oudkerk <shibturn@gmail.com>2014-03-23 11:54:15 (GMT)
commita40675a1a232479bbc2cb9437db265416eeb5b2d (patch)
tree298062361b79c40489fbf9a20e2d3398ead87a1e
parent75c5ab49edff23dacd1410062480c031afc80c9d (diff)
downloadcpython-a40675a1a232479bbc2cb9437db265416eeb5b2d.zip
cpython-a40675a1a232479bbc2cb9437db265416eeb5b2d.tar.gz
cpython-a40675a1a232479bbc2cb9437db265416eeb5b2d.tar.bz2
Issue #20990: Fix issues found by pyflakes for multiprocessing.
-rw-r--r--Lib/multiprocessing/spawn.py12
-rw-r--r--Lib/multiprocessing/synchronize.py7
-rw-r--r--Misc/NEWS2
3 files changed, 16 insertions, 5 deletions
diff --git a/Lib/multiprocessing/spawn.py b/Lib/multiprocessing/spawn.py
index c8297f3..8dc48dd 100644
--- a/Lib/multiprocessing/spawn.py
+++ b/Lib/multiprocessing/spawn.py
@@ -64,7 +64,14 @@ def freeze_support():
Run code for process object if this in not the main process
'''
if is_forking(sys.argv):
- main()
+ kwds = {}
+ for arg in sys.argv[2:]:
+ name, value = arg.split('=')
+ if value == 'None':
+ kwds[name] = None
+ else:
+ kwds[name] = int(value)
+ spawn_main(**kwds)
sys.exit()
@@ -73,7 +80,8 @@ def get_command_line(**kwds):
Returns prefix of command line used for spawning a child process
'''
if getattr(sys, 'frozen', False):
- return [sys.executable, '--multiprocessing-fork']
+ tmp = ' '.join('%s=%r' % item for item in kwds.items())
+ return [sys.executable, '--multiprocessing-fork'] + tmp
else:
prog = 'from multiprocessing.spawn import spawn_main; spawn_main(%s)'
prog %= ', '.join('%s=%r' % item for item in kwds.items())
diff --git a/Lib/multiprocessing/synchronize.py b/Lib/multiprocessing/synchronize.py
index 0e3f6ec..dea1cbd 100644
--- a/Lib/multiprocessing/synchronize.py
+++ b/Lib/multiprocessing/synchronize.py
@@ -49,9 +49,10 @@ class SemLock(object):
_rand = tempfile._RandomNameSequence()
def __init__(self, kind, value, maxvalue, *, ctx):
- ctx = ctx or get_context()
- ctx = ctx.get_context()
- unlink_now = sys.platform == 'win32' or ctx._name == 'fork'
+ if ctx is None:
+ ctx = context._default_context.get_context()
+ name = ctx.get_start_method()
+ unlink_now = sys.platform == 'win32' or name == 'fork'
for i in range(100):
try:
sl = self._semlock = _multiprocessing.SemLock(
diff --git a/Misc/NEWS b/Misc/NEWS
index 6b527ea..2f9afb9 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -21,6 +21,8 @@ Core and Builtins
Library
-------
+- Issue #20990: Fix issues found by pyflakes for multiprocessing.
+
- Issue #21015: SSL contexts will now automatically select an elliptic
curve for ECDH key exchange on OpenSSL 1.0.2 and later, and otherwise
default to "prime256v1".