diff options
-rw-r--r-- | cmd/gotop/main.go | 14 | ||||
-rw-r--r-- | widgets/help.go | 6 | ||||
-rw-r--r-- | widgets/proc.go | 7 |
3 files changed, 21 insertions, 6 deletions
diff --git a/cmd/gotop/main.go b/cmd/gotop/main.go index fafb5da..74891ef 100644 --- a/cmd/gotop/main.go +++ b/cmd/gotop/main.go @@ -322,7 +322,19 @@ func eventLoop(c gotop.Config, grid *layout.MyGrid) { case "d": if grid.Proc != nil { if previousKey == "d" { - grid.Proc.KillProc() + grid.Proc.KillProc("SIGTERM") + } + } + case "3": + if grid.Proc != nil { + if previousKey == "d" { + grid.Proc.KillProc("SIGQUIT") + } + } + case "9": + if grid.Proc != nil { + if previousKey == "d" { + grid.Proc.KillProc("SIGKILL") } } case "<Tab>": diff --git a/widgets/help.go b/widgets/help.go index 54ddfbc..953de45 100644 --- a/widgets/help.go +++ b/widgets/help.go @@ -22,7 +22,9 @@ Process navigation Process actions: - <Tab>: toggle process grouping - - dd: kill selected process or group of processes + - dd: kill selected process or group of processes with SIGTERM (15) + - d3: kill selected process or group of processes with SIGQUIT (3) + - d9: kill selected process or group of processes with SIGKILL (9) Process sorting - c: CPU @@ -50,7 +52,7 @@ func (self *HelpMenu) Resize(termWidth, termHeight int) { textWidth = maxInt(len(line), textWidth) } textWidth += 2 - textHeight := 22 + textHeight := 28 x := (termWidth - textWidth) / 2 y := (termHeight - textHeight) / 2 diff --git a/widgets/proc.go b/widgets/proc.go index 29ad19c..03f1de9 100644 --- a/widgets/proc.go +++ b/widgets/proc.go @@ -182,14 +182,15 @@ func (self *ProcWidget) ToggleShowingGroupedProcs() { self.convertProcsToTableRows() } -// KillProc kills a process or group of processes depending on if we're displaying the processes grouped or not. -func (self *ProcWidget) KillProc() { +// KillProc kills a process or group of processes depending on if we're +// displaying the processes grouped or not. +func (self *ProcWidget) KillProc(sigName string) { self.SelectedItem = "" command := "kill" if self.UniqueCol == 1 { command = "pkill" } - cmd := exec.Command(command, self.Rows[self.SelectedRow][self.UniqueCol]) + cmd := exec.Command(command, "--signal", sigName, self.Rows[self.SelectedRow][self.UniqueCol]) cmd.Start() cmd.Wait() } |