]> granicus.if.org Git - python/commitdiff
When using shell=True on Windows, don't display a shell window by default. Fixes...
authorPeter Astrand <astrand@lysator.liu.se>
Sun, 7 Nov 2004 14:30:34 +0000 (14:30 +0000)
committerPeter Astrand <astrand@lysator.liu.se>
Sun, 7 Nov 2004 14:30:34 +0000 (14:30 +0000)
Lib/subprocess.py
PC/_subprocess.c

index 76ea25fff4577f16a778ad919223ab0598465b44..db19d1ff688839f570dd5d4e5c10b9c10f65006a 100644 (file)
@@ -372,11 +372,11 @@ if mswindows:
                              STD_OUTPUT_HANDLE, STD_ERROR_HANDLE
         from win32api import GetCurrentProcess, DuplicateHandle, \
                              GetModuleFileName, GetVersion
-        from win32con import DUPLICATE_SAME_ACCESS
+        from win32con import DUPLICATE_SAME_ACCESS, SW_HIDE
         from win32pipe import CreatePipe
         from win32process import CreateProcess, STARTUPINFO, \
                                  GetExitCodeProcess, STARTF_USESTDHANDLES, \
-                                 CREATE_NEW_CONSOLE
+                                 STARTF_USESHOWWINDOW, CREATE_NEW_CONSOLE
         from win32event import WaitForSingleObject, INFINITE, WAIT_OBJECT_0
     else:
         from _subprocess import *
@@ -673,7 +673,19 @@ class Popen(object):
             if not isinstance(args, types.StringTypes):
                 args = list2cmdline(args)
 
+            # Process startup details
+            default_startupinfo = STARTUPINFO()
+            if startupinfo == None:
+                startupinfo = default_startupinfo
+            if not None in (p2cread, c2pwrite, errwrite):
+                startupinfo.dwFlags |= STARTF_USESTDHANDLES
+                startupinfo.hStdInput = p2cread
+                startupinfo.hStdOutput = c2pwrite
+                startupinfo.hStdError = errwrite
+
             if shell:
+                default_startupinfo.dwFlags |= STARTF_USESHOWWINDOW
+                default_startupinfo.wShowWindow = SW_HIDE
                 comspec = os.environ.get("COMSPEC", "cmd.exe")
                 args = comspec + " /c " + args
                 if (GetVersion() >= 0x80000000L or
@@ -692,15 +704,6 @@ class Popen(object):
                     # kill children.
                     creationflags |= CREATE_NEW_CONSOLE
 
-            # Process startup details
-            if startupinfo == None:
-                startupinfo = STARTUPINFO()
-            if not None in (p2cread, c2pwrite, errwrite):
-                startupinfo.dwFlags |= STARTF_USESTDHANDLES
-                startupinfo.hStdInput = p2cread
-                startupinfo.hStdOutput = c2pwrite
-                startupinfo.hStdError = errwrite
-
             # Start the process
             try:
                 hp, ht, pid, tid = CreateProcess(executable, args,
index 34073c66681fa9413d3a4ed50a1e4915a5ee9bdf..61544c32343ac25041d60eff58665c4885a644c9 100644 (file)
@@ -377,6 +377,7 @@ sp_CreateProcess(PyObject* self, PyObject* args)
 
        /* note: we only support a small subset of all SI attributes */
        si.dwFlags = getint(startup_info, "dwFlags");
+       si.wShowWindow = getint(startup_info, "wShowWindow");
        si.hStdInput = gethandle(startup_info, "hStdInput");
        si.hStdOutput = gethandle(startup_info, "hStdOutput");
        si.hStdError = gethandle(startup_info, "hStdError");
@@ -530,6 +531,8 @@ init_subprocess()
        defint(d, "STD_ERROR_HANDLE", STD_ERROR_HANDLE);
        defint(d, "DUPLICATE_SAME_ACCESS", DUPLICATE_SAME_ACCESS);
        defint(d, "STARTF_USESTDHANDLES", STARTF_USESTDHANDLES);
+       defint(d, "STARTF_USESHOWWINDOW", STARTF_USESHOWWINDOW);
+       defint(d, "SW_HIDE", SW_HIDE);
        defint(d, "INFINITE", INFINITE);
        defint(d, "WAIT_OBJECT_0", WAIT_OBJECT_0);
        defint(d, "CREATE_NEW_CONSOLE", CREATE_NEW_CONSOLE);