2018-04-28 15:24:36 +02:00
|
|
|
package termstatus
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/restic/restic/internal/debug"
|
|
|
|
|
2020-10-13 12:56:23 +02:00
|
|
|
"golang.org/x/sys/unix"
|
|
|
|
)
|
2018-04-28 15:24:36 +02:00
|
|
|
|
2020-10-13 12:56:23 +02:00
|
|
|
// IsProcessBackground reports whether the current process is running in the
|
|
|
|
// background. fd must be a file descriptor for the terminal.
|
|
|
|
func IsProcessBackground(fd uintptr) bool {
|
|
|
|
bg, err := isProcessBackground(fd)
|
|
|
|
if err != nil {
|
2018-04-28 15:24:36 +02:00
|
|
|
debug.Log("Can't check if we are in the background. Using default behaviour. Error: %s\n", err.Error())
|
|
|
|
return false
|
|
|
|
}
|
2020-10-13 12:56:23 +02:00
|
|
|
return bg
|
|
|
|
}
|
2018-04-28 15:24:36 +02:00
|
|
|
|
2020-10-13 12:56:23 +02:00
|
|
|
func isProcessBackground(fd uintptr) (bool, error) {
|
2023-05-25 17:20:42 +02:00
|
|
|
// We need to use IoctlGetUint32 here, because pid_t is 32-bit even on
|
|
|
|
// 64-bit Linux. IoctlGetInt doesn't work on big-endian platforms:
|
|
|
|
// https://github.com/golang/go/issues/45585
|
|
|
|
// https://github.com/golang/go/issues/60429
|
|
|
|
pid, err := unix.IoctlGetUint32(int(fd), unix.TIOCGPGRP)
|
|
|
|
return int(pid) != unix.Getpgrp(), err
|
2018-04-28 15:24:36 +02:00
|
|
|
}
|