oh-my-posh/src/environment_windows.go
2021-06-08 08:34:28 +02:00

69 lines
1.6 KiB
Go

// +build windows
package main
import (
"errors"
"os"
"golang.org/x/sys/windows"
)
func (env *environment) isRunningAsRoot() bool {
var sid *windows.SID
// Although this looks scary, it is directly copied from the
// official windows documentation. The Go API for this is a
// direct wrap around the official C++ API.
// See https://docs.microsoft.com/en-us/windows/desktop/api/securitybaseapi/nf-securitybaseapi-checktokenmembership
err := windows.AllocateAndInitializeSid(
&windows.SECURITY_NT_AUTHORITY,
2,
windows.SECURITY_BUILTIN_DOMAIN_RID,
windows.DOMAIN_ALIAS_RID_ADMINS,
0, 0, 0, 0, 0, 0,
&sid)
if err != nil {
return false
}
defer func() {
_ = windows.FreeSid(sid)
}()
// This appears to cast a null pointer so I'm not sure why this
// works, but this guy says it does and it Works for Me™:
// https://github.com/golang/go/issues/28804#issuecomment-438838144
token := windows.Token(0)
member, err := token.IsMember(sid)
if err != nil {
return false
}
return member
}
func (env *environment) homeDir() string {
// return the right HOME reference when using MSYS2
if env.getShellName() == bash {
return os.Getenv("HOME")
}
home := os.Getenv("HOMEDRIVE") + os.Getenv("HOMEPATH")
if home == "" {
home = os.Getenv("USERPROFILE")
}
return home
}
func (env *environment) getWindowTitle(imageName, windowTitleRegex string) (string, error) {
return getWindowTitle(imageName, windowTitleRegex)
}
func (env *environment) isWsl() bool {
return false
}
func (env *environment) getTerminalWidth() (int, error) {
return 0, errors.New("Unsupported on Windows")
}