Merge branch 'feat-sort-procs-cmd' of https://github.com/Kqzz/gotop

This commit is contained in:
Sean E. Russell 2022-09-29 12:26:59 -05:00
commit 7a06ff5fa7
10 changed files with 30 additions and 1 deletions

View File

@ -353,7 +353,7 @@ func eventLoop(c gotop.Config, grid *layout.MyGrid) {
grid.Proc.ToggleShowingGroupedProcs() grid.Proc.ToggleShowingGroupedProcs()
ui.Render(grid.Proc) ui.Render(grid.Proc)
} }
case "m", "c", "p": case "m", "c", "n", "p":
if grid.Proc != nil { if grid.Proc != nil {
grid.Proc.ChangeProcSortMethod(w.ProcSortMethod(e.ID)) grid.Proc.ChangeProcSortMethod(w.ProcSortMethod(e.ID))
ui.Render(grid.Proc) ui.Render(grid.Proc)

View File

@ -28,6 +28,7 @@ Process actions:
Prozesssortierung: Prozesssortierung:
- c: CPU - c: CPU
- n: Cmd
- m: Mem - m: Mem
- p: PID - p: PID

View File

@ -28,6 +28,7 @@ Process actions:
Process sorting: Process sorting:
- c: CPU - c: CPU
- n: Cmd
- m: Mem - m: Mem
- p: PID - p: PID

View File

@ -28,6 +28,7 @@ Proceza agoj:
Proceza ordigoj: Proceza ordigoj:
- c: CPU - c: CPU
- n: Cmd
- m: Memoro - m: Memoro
- p: PID - p: PID

View File

@ -28,6 +28,7 @@ Acciones de proceso :
Ordenación de procesos: Ordenación de procesos:
- c: CPU - c: CPU
- n: Cmd
- m: Mem - m: Mem
- p: PID - p: PID

View File

@ -28,6 +28,7 @@ Action sur les processus:
Tri des processus: Tri des processus:
- c: CPU - c: CPU
- n: Cmd
- m: Mem - m: Mem
- p: PID - p: PID

View File

@ -25,6 +25,7 @@ help="""
- d9: убить выбранный процесс или группу процессов с помощью SIGKILL (9) - d9: убить выбранный процесс или группу процессов с помощью SIGKILL (9)
Сортировка процессов: Сортировка процессов:
- c: CPU - c: CPU
- n: Cmd
- m: Память - m: Память
- p: PID - p: PID
Фильтр процессов: Фильтр процессов:

View File

@ -28,6 +28,7 @@ gnipuorg ssecorp elggot :>baT< -
:gnitros ssecorP :gnitros ssecorP
UPC :c - UPC :c -
dmC :n -
meM :m - meM :m -
DIP :p - DIP :p -

View File

@ -28,6 +28,7 @@ help="""
: :
- c: CPU - c: CPU
- n: Cmd
- m: - m:
- p: - p:

View File

@ -25,6 +25,7 @@ const (
ProcSortCPU ProcSortMethod = "c" ProcSortCPU ProcSortMethod = "c"
ProcSortMem = "m" ProcSortMem = "m"
ProcSortPid = "p" ProcSortPid = "p"
ProcSortCmd = "n"
) )
type Proc struct { type Proc struct {
@ -188,6 +189,9 @@ func (proc *ProcWidget) sortProcs() {
case ProcSortMem: case ProcSortMem:
sort.Sort(sort.Reverse(SortProcsByMem(*procs))) sort.Sort(sort.Reverse(SortProcsByMem(*procs)))
proc.Header[3] += _downArrow proc.Header[3] += _downArrow
case ProcSortCmd:
sort.Sort(sort.Reverse(SortProcsByCmd(*procs)))
proc.Header[1] += _downArrow
} }
} }
@ -336,3 +340,20 @@ func (procs SortProcsByMem) Swap(i, j int) {
func (procs SortProcsByMem) Less(i, j int) bool { func (procs SortProcsByMem) Less(i, j int) bool {
return procs[i].Mem < procs[j].Mem return procs[i].Mem < procs[j].Mem
} }
type SortProcsByCmd []Proc
// Len implements Sort interface
func (procs SortProcsByCmd) Len() int {
return len(procs)
}
// Swap implements Sort interface
func (procs SortProcsByCmd) Swap(i, j int) {
procs[i], procs[j] = procs[j], procs[i]
}
// Less implements Sort interface
func (procs SortProcsByCmd) Less(i, j int) bool {
return strings.ToLower(procs[j].CommandName) < strings.ToLower(procs[i].CommandName)
}