mirror of https://github.com/liamg/aminal.git
Make getting the up-time more portable across unix-like systems
This commit is contained in:
parent
41f8406484
commit
18215381dd
|
@ -4,7 +4,6 @@ import (
|
|||
"regexp"
|
||||
"strconv"
|
||||
"strings"
|
||||
"syscall"
|
||||
"time"
|
||||
|
||||
"github.com/liamg/darktile/internal/app/darktile/termutil"
|
||||
|
@ -52,7 +51,5 @@ func (h *DmesgTimestampHinter) Click(api HintAPI) error {
|
|||
}
|
||||
|
||||
func setSysStartTime() {
|
||||
sysInfo := &syscall.Sysinfo_t{}
|
||||
_ = syscall.Sysinfo(sysInfo)
|
||||
sysStart = time.Now().Local().Add(time.Duration(int(sysInfo.Uptime*-1)) * time.Second)
|
||||
sysStart = time.Now().Local().Add(time.Duration(int(getUptime()*-1)) * time.Second)
|
||||
}
|
||||
|
|
|
@ -0,0 +1,22 @@
|
|||
//go:build cgo && (!linux || unix)
|
||||
package hinters
|
||||
|
||||
/*
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <time.h>
|
||||
#include <sys/timespec.h>
|
||||
|
||||
|
||||
time_t getuptime() {
|
||||
struct timespec tp;
|
||||
clock_gettime(CLOCK_UPTIME, &tp);
|
||||
return tp.tv_sec;
|
||||
}
|
||||
*/
|
||||
import "C"
|
||||
|
||||
func getUptime() int64 {
|
||||
time := C.getuptime()
|
||||
return int64(time)
|
||||
}
|
|
@ -0,0 +1,11 @@
|
|||
package hinters
|
||||
|
||||
import (
|
||||
"syscall"
|
||||
)
|
||||
|
||||
func getUptime() int64 {
|
||||
sysInfo := &syscall.Sysinfo_t{}
|
||||
_ = syscall.Sysinfo(sysInfo)
|
||||
return sysInfo.Uptime
|
||||
}
|
Loading…
Reference in New Issue