Skip to content
This repository has been archived by the owner on Aug 29, 2020. It is now read-only.

Commit

Permalink
Remove 8 cores limit in CPU widget
Browse files Browse the repository at this point in the history
  • Loading branch information
tie committed Jul 31, 2018
1 parent eb17f69 commit 12527db
Show file tree
Hide file tree
Showing 2 changed files with 36 additions and 40 deletions.
20 changes: 12 additions & 8 deletions main.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,9 @@ var (
zoom = 7
zoomInterval = 3

averageLoad = true
percpuLoad = true

cpu *w.CPU
mem *w.Mem
proc *w.Proc
Expand Down Expand Up @@ -173,15 +176,16 @@ func widgetColors() {
mem.LineColor["Main"] = ui.Color(colorscheme.MainMem)
mem.LineColor["Swap"] = ui.Color(colorscheme.SwapMem)

LineColor := make(map[string]ui.Color)
if cpu.Count <= 8 {
for i := 0; i < len(cpu.Data); i++ {
LineColor[fmt.Sprintf("CPU%d", i)] = ui.Color(colorscheme.CPULines[i])
i := 0
for k := range cpu.Data {
if i >= len(colorscheme.CPULines) {
// assuming colorscheme for CPU lines is not empty
i = 0
}
} else {
LineColor["Average"] = ui.Color(colorscheme.CPULines[0])
c := colorscheme.CPULines[i]
cpu.LineColor[k] = ui.Color(c)
i++
}
cpu.LineColor = LineColor

if !minimal {
temp.TempLow = ui.Color(colorscheme.TempLow)
Expand All @@ -194,7 +198,7 @@ func initWidgets() {
wg.Add(widgetCount)

go func() {
cpu = w.NewCPU(interval, zoom)
cpu = w.NewCPU(interval, zoom, averageLoad, percpuLoad)
wg.Done()
}()
go func() {
Expand Down
56 changes: 24 additions & 32 deletions src/widgets/cpu.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,43 +2,46 @@ package widgets

import (
"fmt"
"strconv"
"time"

"github.com/cjbassi/gotop/src/utils"
ui "github.com/cjbassi/termui"
psCPU "github.com/shirou/gopsutil/cpu"
)

type CPU struct {
*ui.LineGraph
Count int // number of cores
Average bool // show average load
PerCPU bool // show per-core load
interval time.Duration
}

func NewCPU(interval time.Duration, zoom int) *CPU {
func NewCPU(interval time.Duration, zoom int, average bool, percpu bool) *CPU {
count, _ := psCPU.Counts(false)
self := &CPU{
LineGraph: ui.NewLineGraph(),
Count: count,
interval: interval,
Average: average,
PerCPU: percpu,
}
self.Label = "CPU Usage"
self.Zoom = zoom
if self.Count <= 8 {
for i := 0; i < self.Count; i++ {
key := "CPU" + strconv.Itoa(i)
self.Data[key] = []float64{0}
}
} else {

if self.Average {
self.Data["Average"] = []float64{0}
}

// update asynchronously because of 1 second blocking period
go self.update()
if self.PerCPU {
for i := 0; i < self.Count; i++ {
k := fmt.Sprintf("CPU%d", i)
self.Data[k] = []float64{0}
}
}

ticker := time.NewTicker(self.interval)
go func() {
self.update()
for range ticker.C {
self.update()
}
Expand All @@ -49,29 +52,18 @@ func NewCPU(interval time.Duration, zoom int) *CPU {

// calculates the CPU usage over a 1 second interval and blocks for the duration
func (self *CPU) update() {
// show average cpu usage if more than 8 cores
if self.Count <= 8 {
percents, _ := psCPU.Percent(self.interval, true)
if len(percents) != self.Count {
count, _ := psCPU.Counts(false)
utils.Error("CPU percentages",
fmt.Sprint(
"self.Count: ", self.Count, "\n",
"gopsutil.Counts(): ", count, "\n",
"len(percents): ", len(percents), "\n",
"percents: ", percents, "\n",
"self.interval: ", self.interval,
))
}
for i := 0; i < self.Count; i++ {
key := "CPU" + strconv.Itoa(i)
percent := percents[i]
self.Data[key] = append(self.Data[key], percent)
self.Labels[key] = fmt.Sprintf("%3.0f%%", percent)
}
} else {
if self.Average {
percent, _ := psCPU.Percent(self.interval, false)
self.Data["Average"] = append(self.Data["Average"], percent[0])
self.Labels["Average"] = fmt.Sprintf("%3.0f%%", percent[0])
}

if self.PerCPU {
percents, _ := psCPU.Percent(self.interval, true)
for i := 0; i < self.Count; i++ {
k := fmt.Sprintf("CPU%d", i)
self.Data[k] = append(self.Data[k], percents[i])
self.Labels[k] = fmt.Sprintf("%3.0f%%", percents[i])
}
}
}

0 comments on commit 12527db

Please sign in to comment.