Merge branch 'v4.0.2' into master

This commit is contained in:
Sean E. Russell 2020-08-25 08:25:39 -05:00
commit 72cde05458
8 changed files with 46 additions and 5 deletions

@ -62,7 +62,11 @@ gotop should build with most versions of Go. If you have a version other than 1
git clone https://github.com/xxxserxxx/gotop.git git clone https://github.com/xxxserxxx/gotop.git
cd gotop cd gotop
sed -i '/^go/d' go.mod # Do this if you have go != 1.14 sed -i '/^go/d' go.mod # Do this if you have go != 1.14
go build -o gotop ./cmd/gotop VERS="$(git tag -l --sort=-v:refname | sed 's/v\([^-].*\)/\1/g' | head -1 | tr -d '-' ).$(git describe --long --tags | sed 's/\([^-].*\)-\([0-9]*\)-\(g.*\)/r\2.\3/g' | tr -d '-')"
DAT=$(date +%Y%m%dT%H%M%S)
go build -o gotop \
-ldflags "-X main.Version=v${VERS} -X main.BuildDate=${DAT}" \
./cmd/gotop
``` ```
Move `gotop` to somewhere in your `$PATH`. Move `gotop` to somewhere in your `$PATH`.

@ -8,7 +8,7 @@ import (
func init() { func init() {
f := func(cpus map[string]int, l bool) map[string]error { f := func(cpus map[string]int, l bool) map[string]error {
cpuCount, err := psCpu.Counts(l) cpuCount, err := CpuCount()
if err != nil { if err != nil {
return nil return nil
} }

23
devices/cpu_linux.go Normal file

@ -0,0 +1,23 @@
// +build linux
package devices
import "github.com/shirou/gopsutil/cpu"
func CpuCount() (int, error) {
cpuCount, err := cpu.Counts(false)
if err != nil {
return 0, err
}
if cpuCount == 0 {
is, err := cpu.Info()
if err != nil {
return 0, err
}
if is[0].Cores > 0 {
return len(is) / 2, nil
}
return len(is), nil
}
return cpuCount, nil
}

9
devices/cpu_other.go Normal file

@ -0,0 +1,9 @@
// +build !linux
package devices
import "github.com/shirou/gopsutil/cpu"
func CpuCount() (int, error) {
return cpu.Counts(false)
}

@ -15,6 +15,7 @@ func devs() []string {
} }
sensors, err := host.SensorsTemperatures() sensors, err := host.SensorsTemperatures()
if err != nil { if err != nil {
// FIXME report the error
return []string{} return []string{}
} }
rv := make([]string, 0, len(sensors)) rv := make([]string, 0, len(sensors))

@ -51,6 +51,10 @@ func (b *BatteryGauge) update() {
} }
return return
} }
if len(bats) < 1 {
b.Label = fmt.Sprintf("N/A")
return
}
mx := 0.0 mx := 0.0
cu := 0.0 cu := 0.0
charging := "%d%% ⚡%s" charging := "%d%% ⚡%s"

@ -9,9 +9,8 @@ import (
"strings" "strings"
"time" "time"
psCPU "github.com/shirou/gopsutil/cpu"
tui "github.com/gizak/termui/v3" tui "github.com/gizak/termui/v3"
"github.com/xxxserxxx/gotop/v4/devices"
ui "github.com/xxxserxxx/gotop/v4/termui" ui "github.com/xxxserxxx/gotop/v4/termui"
"github.com/xxxserxxx/gotop/v4/utils" "github.com/xxxserxxx/gotop/v4/utils"
) )
@ -49,7 +48,7 @@ type ProcWidget struct {
} }
func NewProcWidget() *ProcWidget { func NewProcWidget() *ProcWidget {
cpuCount, err := psCPU.Counts(false) cpuCount, err := devices.CpuCount()
if err != nil { if err != nil {
log.Printf("failed to get CPU count from gopsutil: %v", err) log.Printf("failed to get CPU count from gopsutil: %v", err)
} }

@ -19,6 +19,7 @@ func getProcs() ([]Proc, error) {
procs := []Proc{} procs := []Proc{}
for _, line := range linesOfProcStrings { for _, line := range linesOfProcStrings {
log.Printf("line is '%s', pid is '%s', cpu is '%s', mem is '%s'", line, strings.TrimSpace(line[0:10]), strings.TrimSpace(line[63:68]), strings.TrimSpace(line[69:74]))
pid, err := strconv.Atoi(strings.TrimSpace(line[0:10])) pid, err := strconv.Atoi(strings.TrimSpace(line[0:10]))
if err != nil { if err != nil {
log.Printf("failed to convert PID to int: %v. line: %v", err, line) log.Printf("failed to convert PID to int: %v. line: %v", err, line)