fzf/src/util/util.go

107 lines
1.9 KiB
Go
Raw Normal View History

2015-01-12 03:56:17 +00:00
package util
2015-01-01 19:49:30 +00:00
2015-01-12 03:56:17 +00:00
// #include <unistd.h>
import "C"
import (
"os"
"time"
"unicode/utf8"
2015-01-12 03:56:17 +00:00
)
2015-01-08 13:07:04 +00:00
2015-01-11 18:01:24 +00:00
// Max returns the largest integer
2015-01-01 19:49:30 +00:00
func Max(first int, items ...int) int {
max := first
for _, item := range items {
if item > max {
max = item
}
}
return max
}
// Max32 returns the smallest 32-bit integer
func Min32(first int32, second int32) int32 {
if first <= second {
return first
}
return second
}
2015-01-11 18:01:24 +00:00
// Max32 returns the largest 32-bit integer
2015-01-08 17:37:08 +00:00
func Max32(first int32, second int32) int32 {
if first > second {
return first
}
return second
}
2015-03-18 16:59:14 +00:00
// Constrain32 limits the given 32-bit integer with the upper and lower bounds
func Constrain32(val int32, min int32, max int32) int32 {
if val < min {
return min
}
if val > max {
return max
}
return val
}
2015-01-12 03:56:17 +00:00
// Constrain limits the given integer with the upper and lower bounds
func Constrain(val int, min int, max int) int {
if val < min {
return min
2015-01-01 19:49:30 +00:00
}
2015-01-12 03:56:17 +00:00
if val > max {
return max
}
return val
2015-01-01 19:49:30 +00:00
}
2015-01-08 13:07:04 +00:00
2015-01-11 18:01:24 +00:00
// DurWithin limits the given time.Duration with the upper and lower bounds
2015-01-08 13:07:04 +00:00
func DurWithin(
val time.Duration, min time.Duration, max time.Duration) time.Duration {
if val < min {
return min
}
if val > max {
return max
}
return val
}
2015-01-12 03:56:17 +00:00
func Between(val int, min int, max int) bool {
return val >= min && val <= max
}
2015-01-12 03:56:17 +00:00
// IsTty returns true is stdin is a terminal
func IsTty() bool {
return int(C.isatty(C.int(os.Stdin.Fd()))) != 0
}
func TrimRight(runes []rune) []rune {
var i int
for i = len(runes) - 1; i >= 0; i-- {
char := runes[i]
if char != ' ' && char != '\t' {
break
}
}
return runes[0 : i+1]
}
func BytesToRunes(bytea []byte) []rune {
runes := make([]rune, 0, len(bytea))
for i := 0; i < len(bytea); {
if bytea[i] < utf8.RuneSelf {
runes = append(runes, rune(bytea[i]))
i++
} else {
r, sz := utf8.DecodeRune(bytea[i:])
i += sz
runes = append(runes, r)
}
}
return runes
}