diff options
author | Richard Oudkerk <shibturn@gmail.com> | 2014-03-23 11:54:15 (GMT) |
---|---|---|
committer | Richard Oudkerk <shibturn@gmail.com> | 2014-03-23 11:54:15 (GMT) |
commit | a40675a1a232479bbc2cb9437db265416eeb5b2d (patch) | |
tree | 298062361b79c40489fbf9a20e2d3398ead87a1e | |
parent | 75c5ab49edff23dacd1410062480c031afc80c9d (diff) | |
download | cpython-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.py | 12 | ||||
-rw-r--r-- | Lib/multiprocessing/synchronize.py | 7 | ||||
-rw-r--r-- | Misc/NEWS | 2 |
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( @@ -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". |