2020-08-10 17:43:49 +00:00
|
|
|
// +build windows
|
|
|
|
|
2021-03-18 22:40:29 +00:00
|
|
|
package windowsconsole
|
2020-08-10 17:43:49 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
|
2021-03-18 22:40:29 +00:00
|
|
|
"golang.org/x/sys/windows"
|
2020-08-10 17:43:49 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// GetHandleInfo returns file descriptor and bool indicating whether the file is a console.
|
|
|
|
func GetHandleInfo(in interface{}) (uintptr, bool) {
|
|
|
|
switch t := in.(type) {
|
|
|
|
case *ansiReader:
|
|
|
|
return t.Fd(), true
|
|
|
|
case *ansiWriter:
|
|
|
|
return t.Fd(), true
|
|
|
|
}
|
|
|
|
|
|
|
|
var inFd uintptr
|
|
|
|
var isTerminal bool
|
|
|
|
|
|
|
|
if file, ok := in.(*os.File); ok {
|
|
|
|
inFd = file.Fd()
|
2021-03-18 22:40:29 +00:00
|
|
|
isTerminal = isConsole(inFd)
|
2020-08-10 17:43:49 +00:00
|
|
|
}
|
|
|
|
return inFd, isTerminal
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsConsole returns true if the given file descriptor is a Windows Console.
|
|
|
|
// The code assumes that GetConsoleMode will return an error for file descriptors that are not a console.
|
2021-03-18 22:40:29 +00:00
|
|
|
// Deprecated: use golang.org/x/sys/windows.GetConsoleMode() or golang.org/x/term.IsTerminal()
|
|
|
|
var IsConsole = isConsole
|
|
|
|
|
|
|
|
func isConsole(fd uintptr) bool {
|
|
|
|
var mode uint32
|
|
|
|
err := windows.GetConsoleMode(windows.Handle(fd), &mode)
|
|
|
|
return err == nil
|
2020-08-10 17:43:49 +00:00
|
|
|
}
|