From b5982be6cc79eadf8fa7f0bf7cce206c4474bab6 Mon Sep 17 00:00:00 2001 From: Rob Lourens Date: Fri, 3 Feb 2017 12:17:01 -0800 Subject: [PATCH 1/2] Attempt to fix #438 --- scripts/terminateProcess.sh | 12 ++++++++++++ src/debugAdapter/goDebug.ts | 24 ++++++++++++++++++++++-- 2 files changed, 34 insertions(+), 2 deletions(-) create mode 100755 scripts/terminateProcess.sh diff --git a/scripts/terminateProcess.sh b/scripts/terminateProcess.sh new file mode 100755 index 000000000..9b068843f --- /dev/null +++ b/scripts/terminateProcess.sh @@ -0,0 +1,12 @@ +#!/bin/bash + +terminateTree() { + for cpid in $(/usr/bin/pgrep -P $1); do + terminateTree $cpid + done + kill -9 $1 > /dev/null 2>&1 +} + +for pid in $*; do + terminateTree $pid +done diff --git a/src/debugAdapter/goDebug.ts b/src/debugAdapter/goDebug.ts index 826f1d7f7..927abb7b7 100644 --- a/src/debugAdapter/goDebug.ts +++ b/src/debugAdapter/goDebug.ts @@ -9,7 +9,7 @@ import { DebugProtocol } from 'vscode-debugprotocol'; import { DebugSession, InitializedEvent, TerminatedEvent, ThreadEvent, StoppedEvent, OutputEvent, Thread, StackFrame, Scope, Source, Handles } from 'vscode-debugadapter'; import { readFileSync, existsSync, lstatSync } from 'fs'; import { basename, dirname } from 'path'; -import { spawn, ChildProcess } from 'child_process'; +import { spawn, ChildProcess, execSync, spawnSync } from 'child_process'; import { Client, RPCConnection } from 'json-rpc2'; import { getBinPathWithPreferredGopath } from '../goPath'; import * as logger from 'vscode-debug-logger'; @@ -305,7 +305,7 @@ class Delve { }); }); } else { - this.debugProcess.kill(); + killTree(this.debugProcess.pid); } } } @@ -757,4 +757,24 @@ function random(low: number, high: number): number { return Math.floor(Math.random() * (high - low) + low); } +function killTree(processId: number): void { + if (process.platform === 'win32') { + const TASK_KILL = 'C:\\Windows\\System32\\taskkill.exe'; + + // when killing a process in Windows its child processes are *not* killed but become root processes. + // Therefore we use TASKKILL.EXE + try { + execSync(`${TASK_KILL} /F /T /PID ${processId}`); + } catch (err) { + } + } else { + // on linux and OS X we kill all direct and indirect child processes as well + try { + const cmd = path.join(__dirname, '../../../scripts/terminateProcess.sh'); + spawnSync(cmd, [ processId.toString() ]); + } catch (err) { + } + } +} + DebugSession.run(GoDebugSession); From b2d1ed31b5f7600fe8cc1b628093cc2822b6937f Mon Sep 17 00:00:00 2001 From: Ramya Achutha Rao Date: Sat, 4 Feb 2017 18:20:19 -0800 Subject: [PATCH 2/2] Fix linting issues --- src/debugAdapter/goDebug.ts | 34 +++++++++++++++++----------------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/src/debugAdapter/goDebug.ts b/src/debugAdapter/goDebug.ts index 927abb7b7..2fe4ffd47 100644 --- a/src/debugAdapter/goDebug.ts +++ b/src/debugAdapter/goDebug.ts @@ -758,23 +758,23 @@ function random(low: number, high: number): number { } function killTree(processId: number): void { - if (process.platform === 'win32') { - const TASK_KILL = 'C:\\Windows\\System32\\taskkill.exe'; - - // when killing a process in Windows its child processes are *not* killed but become root processes. - // Therefore we use TASKKILL.EXE - try { - execSync(`${TASK_KILL} /F /T /PID ${processId}`); - } catch (err) { - } - } else { - // on linux and OS X we kill all direct and indirect child processes as well - try { - const cmd = path.join(__dirname, '../../../scripts/terminateProcess.sh'); - spawnSync(cmd, [ processId.toString() ]); - } catch (err) { - } - } + if (process.platform === 'win32') { + const TASK_KILL = 'C:\\Windows\\System32\\taskkill.exe'; + + // when killing a process in Windows its child processes are *not* killed but become root processes. + // Therefore we use TASKKILL.EXE + try { + execSync(`${TASK_KILL} /F /T /PID ${processId}`); + } catch (err) { + } + } else { + // on linux and OS X we kill all direct and indirect child processes as well + try { + const cmd = path.join(__dirname, '../../../scripts/terminateProcess.sh'); + spawnSync(cmd, [ processId.toString() ]); + } catch (err) { + } + } } DebugSession.run(GoDebugSession);