DRYer
This commit is contained in:
parent
c88a171b28
commit
a0d30f4dd8
@ -22,7 +22,7 @@ var SSHExe = (&utils.Once[string]{Run: func() string {
|
|||||||
if ans != "" {
|
if ans != "" {
|
||||||
return ans
|
return ans
|
||||||
}
|
}
|
||||||
ans = utils.Which("ssh", "/usr/local/bin", "/opt/bin", "/opt/homebrew/bin", "/usr/bin", "/bin", "/usr/sbin", "/sbin")
|
ans = utils.Which("ssh", utils.DefaultExeSearchPaths()...)
|
||||||
if ans == "" {
|
if ans == "" {
|
||||||
ans = "ssh"
|
ans = "ssh"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -13,6 +13,16 @@ import (
|
|||||||
|
|
||||||
var _ = fmt.Print
|
var _ = fmt.Print
|
||||||
|
|
||||||
|
var DefaultExeSearchPaths = (&Once[[]string]{Run: func() []string {
|
||||||
|
candidates := [...]string{"/usr/local/bin", "/opt/bin", "/opt/homebrew/bin", "/usr/bin", "/bin", "/usr/sbin", "/sbin"}
|
||||||
|
ans := make([]string, 0, len(candidates))
|
||||||
|
for _, x := range candidates {
|
||||||
|
if s, err := os.Stat(x); err != nil && s.IsDir() {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ans
|
||||||
|
}}).Get
|
||||||
|
|
||||||
func Which(cmd string, paths ...string) string {
|
func Which(cmd string, paths ...string) string {
|
||||||
if strings.Contains(cmd, string(os.PathSeparator)) {
|
if strings.Contains(cmd, string(os.PathSeparator)) {
|
||||||
return ""
|
return ""
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user