internal/rosa/make: alternative configure script
All checks were successful
Test / Create distribution (push) Successful in 1m5s
Test / Sandbox (push) Successful in 2m37s
Test / Hakurei (push) Successful in 3m49s
Test / ShareFS (push) Successful in 3m57s
Test / Hpkg (push) Successful in 4m21s
Test / Sandbox (race detector) (push) Successful in 5m2s
Test / Hakurei (race detector) (push) Successful in 5m53s
Test / Flake checks (push) Successful in 1m39s

This enables using the configure helper with non-autotools configure scripts.

Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
2026-03-01 10:41:57 +09:00
parent 6159c74e96
commit e92971e0c2

View File

@@ -53,6 +53,8 @@ type MakeAttr struct {
// Whether to skip running the configure script.
SkipConfigure bool
// Alternative name for the configure script.
ConfigureName string
// Flags passed to the configure script.
Configure [][2]string
// Extra make targets.
@@ -102,9 +104,12 @@ func (t Toolchain) NewViaMake(
var configure string
if !attr.SkipConfigure {
configure += `
configure = attr.ConfigureName
if configure == "" {
configure += `
/usr/src/` + name + `/configure \
--prefix=/system`
}
if attr.Host != `""` {
configure += ` \
@@ -121,10 +126,15 @@ func (t Toolchain) NewViaMake(
slices.Collect(func(yield func(string) bool) {
for _, v := range attr.Configure {
s := v[0]
if v[1] == "" || (v[0] != "" &&
if v[0] != "" &&
v[0][0] >= 'a' &&
v[0][0] <= 'z') {
v[0][0] <= 'z' {
s = "--" + s
} else if len(v[0]) > 1 &&
v[0][0] == 'D' &&
v[0][1] >= 'a' &&
v[0][1] <= 'z' {
s = "-" + s
}
if v[1] != "" {
s += "=" + v[1]
@@ -152,10 +162,11 @@ func (t Toolchain) NewViaMake(
makeTargets = nil
}
finalExtra := []pkg.Artifact{
t.Load(Make),
var finalExtra []pkg.Artifact
if !t.isStage0() {
finalExtra = append(finalExtra, t.Load(Make))
}
if attr.OmitDefaults || attr.Flag&TEarly == 0 {
if !attr.OmitDefaults && attr.Flag&TEarly == 0 {
finalExtra = append(finalExtra,
t.Load(Gawk),
t.Load(Coreutils),