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()
ui.Render(grid.Proc)
}
case "m", "c", "p":
case "m", "c", "n", "p":
if grid.Proc != nil {
grid.Proc.ChangeProcSortMethod(w.ProcSortMethod(e.ID))
ui.Render(grid.Proc)

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

@ -25,6 +25,7 @@ const (
ProcSortCPU ProcSortMethod = "c"
ProcSortMem = "m"
ProcSortPid = "p"
ProcSortCmd = "n"
)
type Proc struct {
@ -188,6 +189,9 @@ func (proc *ProcWidget) sortProcs() {
case ProcSortMem:
sort.Sort(sort.Reverse(SortProcsByMem(*procs)))
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 {
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)
}