All checks were successful
Test / Create distribution (push) Successful in 35s
Test / Sandbox (push) Successful in 2m27s
Test / Hakurei (push) Successful in 3m15s
Test / Hpkg (push) Successful in 4m11s
Test / Sandbox (race detector) (push) Successful in 4m18s
Test / Hakurei (race detector) (push) Successful in 5m2s
Test / Flake checks (push) Successful in 1m30s
This is cleaner and makes more sense. The longer LDFLAGS was never a valid concern since it is always inserted by a script. Signed-off-by: Ophestra <cat@gensokyo.uk>
34 lines
944 B
Go
34 lines
944 B
Go
package info
|
|
|
|
import (
|
|
"log"
|
|
|
|
"hakurei.app/container/check"
|
|
)
|
|
|
|
// Absolute paths to the Hakurei installation.
|
|
//
|
|
// These are set by the linker.
|
|
var hakureiPath, hsuPath string
|
|
|
|
// MustHakureiPath returns the [check.Absolute] path to hakurei.
|
|
func MustHakureiPath() *check.Absolute { return mustCheckPath(log.Fatal, "hakurei", hakureiPath) }
|
|
|
|
// MustHsuPath returns the [check.Absolute] to hsu.
|
|
func MustHsuPath() *check.Absolute { return mustCheckPath(log.Fatal, "hsu", hsuPath) }
|
|
|
|
// mustCheckPath checks a pathname to not be zero, then [check.NewAbs], calling fatal if either step fails.
|
|
func mustCheckPath(fatal func(v ...any), name, pathname string) *check.Absolute {
|
|
if pathname != "" {
|
|
if a, err := check.NewAbs(pathname); err != nil {
|
|
fatal(err.Error())
|
|
return nil // unreachable
|
|
} else {
|
|
return a
|
|
}
|
|
} else {
|
|
fatal("invalid " + name + " path, this program is compiled incorrectly")
|
|
return nil // unreachable
|
|
}
|
|
}
|