summaryrefslogtreecommitdiffstats
path: root/Lib/multiprocessing
diff options
context:
space:
mode:
authorRichard Oudkerk <shibturn@gmail.com>2012-05-18 13:28:02 (GMT)
committerRichard Oudkerk <shibturn@gmail.com>2012-05-18 13:28:02 (GMT)
commit77c84f2defb0013e28d262be237142379a1407fe (patch)
tree16065331749bd8218eb74d80c9f10b54a816c0c5 /Lib/multiprocessing
parentcca802e354f776e79a55b3bc7dded6340b244824 (diff)
downloadcpython-77c84f2defb0013e28d262be237142379a1407fe.zip
cpython-77c84f2defb0013e28d262be237142379a1407fe.tar.gz
cpython-77c84f2defb0013e28d262be237142379a1407fe.tar.bz2
#12098: Make multiprocessing's child processes inherit sys.flags on Windows
Initial patch by Sergey Mezentsev.
Diffstat (limited to 'Lib/multiprocessing')
-rw-r--r--Lib/multiprocessing/forking.py3
-rw-r--r--Lib/multiprocessing/util.py31
2 files changed, 33 insertions, 1 deletions
diff --git a/Lib/multiprocessing/forking.py b/Lib/multiprocessing/forking.py
index 2729afe..eadc321 100644
--- a/Lib/multiprocessing/forking.py
+++ b/Lib/multiprocessing/forking.py
@@ -324,7 +324,8 @@ else:
return [sys.executable, '--multiprocessing-fork']
else:
prog = 'from multiprocessing.forking import main; main()'
- return [_python_exe, '-c', prog, '--multiprocessing-fork']
+ opts = util._args_from_interpreter_flags()
+ return [_python_exe] + opts + ['-c', prog, '--multiprocessing-fork']
def main():
diff --git a/Lib/multiprocessing/util.py b/Lib/multiprocessing/util.py
index 9b6dac2..7c71081 100644
--- a/Lib/multiprocessing/util.py
+++ b/Lib/multiprocessing/util.py
@@ -7,6 +7,7 @@
# Licensed to PSF under a Contributor Agreement.
#
+import sys
import functools
import itertools
import weakref
@@ -295,3 +296,33 @@ class ForkAwareLocal(threading.local):
register_after_fork(self, lambda obj : obj.__dict__.clear())
def __reduce__(self):
return type(self), ()
+
+#
+# Get options for python to produce the same sys.flags
+#
+
+def _args_from_interpreter_flags():
+ """Return a list of command-line arguments reproducing the current
+ settings in sys.flags and sys.warnoptions."""
+ flag_opt_map = {
+ 'debug': 'd',
+ # 'inspect': 'i',
+ # 'interactive': 'i',
+ 'optimize': 'O',
+ 'dont_write_bytecode': 'B',
+ 'no_user_site': 's',
+ 'no_site': 'S',
+ 'ignore_environment': 'E',
+ 'verbose': 'v',
+ 'bytes_warning': 'b',
+ 'quiet': 'q',
+ 'hash_randomization': 'R',
+ }
+ args = []
+ for flag, opt in flag_opt_map.items():
+ v = getattr(sys.flags, flag)
+ if v > 0:
+ args.append('-' + opt * v)
+ for opt in sys.warnoptions:
+ args.append('-W' + opt)
+ return args