diff --git a/plugin/core/transports.py b/plugin/core/transports.py index 01564166b..375d8499c 100644 --- a/plugin/core/transports.py +++ b/plugin/core/transports.py @@ -251,7 +251,7 @@ def _stderr_loop(self) -> None: def create_transport(config: TransportConfig, cwd: Optional[str], callback_object: TransportCallbacks) -> Transport[Dict[str, Any]]: stderr = subprocess.PIPE - pass_fds = () # type: Union[Tuple[()], Tuple[int]] + close_fds = True if config.tcp_port is not None: assert config.tcp_port is not None if config.tcp_port < 0: @@ -263,7 +263,7 @@ def create_transport(config: TransportConfig, cwd: Optional[str], stdout = subprocess.PIPE stdin = subprocess.DEVNULL stderr = subprocess.STDOUT - pass_fds = (config.node_ipc.child_connection.fileno(),) + close_fds = False else: stdout = subprocess.PIPE stdin = subprocess.PIPE @@ -273,7 +273,7 @@ def create_transport(config: TransportConfig, cwd: Optional[str], process = None # type: Optional[subprocess.Popen] def start_subprocess() -> subprocess.Popen: - return _start_subprocess(config.command, stdin, stdout, stderr, startupinfo, config.env, cwd, pass_fds) + return _start_subprocess(config.command, stdin, stdout, stderr, startupinfo, config.env, cwd, close_fds) if config.listener_socket: assert isinstance(config.tcp_port, int) and config.tcp_port > 0 @@ -356,7 +356,7 @@ def _start_subprocess( startupinfo: Any, env: Dict[str, str], cwd: Optional[str], - pass_fds: Union[Tuple[()], Tuple[int]] + close_fds: bool ) -> subprocess.Popen: debug("starting {} in {}".format(args, cwd if cwd else os.getcwd())) process = subprocess.Popen( @@ -367,7 +367,7 @@ def _start_subprocess( startupinfo=startupinfo, env=env, cwd=cwd, - pass_fds=pass_fds) + close_fds=close_fds) _subprocesses.add(process) return process