From 11244886bbe63932f422dfe4ec388461464eec56 Mon Sep 17 00:00:00 2001 From: Ilya Guterman Date: Sun, 8 Sep 2019 19:45:04 +0300 Subject: [PATCH] add android support for host --- internal/common/common_android.go | 95 +++++++++++++++++++++++++++++++ internal/common/common_linux.go | 2 +- 2 files changed, 96 insertions(+), 1 deletion(-) create mode 100644 internal/common/common_android.go diff --git a/internal/common/common_android.go b/internal/common/common_android.go new file mode 100644 index 0000000..17e1b86 --- /dev/null +++ b/internal/common/common_android.go @@ -0,0 +1,95 @@ +// +build android + +package common + +import ( + "context" + "os/exec" + "sync/atomic" + "bufio" + + "golang.org/x/sys/unix" +) + +func NumProcs() (uint64, error) { + ps, err := exec.LookPath("ps") + if err != nil { + return 0, err + } + cmd := exec.Command(ps, "-A", "-o", "PID") + stdout, err := cmd.StdoutPipe() + if err != nil { + return 0, err + } + + if err := cmd.Start(); err != nil { + return 0, err + } + + var cnt uint64 + + scanner := bufio.NewScanner(stdout) + for scanner.Scan() { + cnt++ + } + + if err := scanner.Err(); err != nil { + return cnt, err + } + + if err := cmd.Wait(); err != nil { + return 0, err + } + + return cnt, err +} + +// cachedBootTime must be accessed via atomic.Load/StoreUint64 +var cachedBootTime uint64 + +func BootTimeWithContext(ctx context.Context) (uint64, error) { + t := atomic.LoadUint64(&cachedBootTime) + if t != 0 { + return t, nil + } + + sysinfo := &unix.Sysinfo_t{} + + if err := unix.Sysinfo(sysinfo); err != nil { + return 0, err + } + + uptime := uint64(sysinfo.Uptime) + atomic.StoreUint64(&uptime, t) + return uptime, nil +} + +func Virtualization() (string, string, error) { + return VirtualizationWithContext(context.Background()) +} + +func VirtualizationWithContext(ctx context.Context) (string, string, error) { + return "", "", nil +} + +func GetOSRelease() (platform string, version string, err error) { + getprop, err := exec.LookPath("getprop") + if err != nil { + return "", "", err + } + flavorCmd := exec.Command(getprop, "ro.build.flavor") + platformProp, err := flavorCmd.Output() + + if err != nil { + return "", "", err + } + + versionCmd := exec.Command(getprop, "ro.build.version.release") + versionProp, err := versionCmd.Output() + + if err != nil { + return "", "", err + } + + return string(platformProp), string(versionProp), nil +} diff --git a/internal/common/common_linux.go b/internal/common/common_linux.go index f558b74..70c6209 100644 --- a/internal/common/common_linux.go +++ b/internal/common/common_linux.go @@ -1,4 +1,4 @@ -// +build linux +// +build linux,!android package common